/**
* See the NOTICE file distributed with this work for additional information
* regarding copyright ownership.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import React from 'react';
import { render } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import times from 'lodash/times';
import { push } from 'connected-react-router';
import * as urlFor from 'src/shared/helpers/urlHelper';
import { createSelectedSpecies } from 'tests/fixtures/selected-species';
import {
SpeciesSelectorAppBar,
placeholderMessage
} from './SpeciesSelectorAppBar';
jest.mock('react-router-dom', () => ({
Link: (props: any) =>
{props.children}
}));
jest.mock('connected-react-router', () => ({
push: jest.fn(() => ({ type: 'push' }))
}));
jest.mock(
'ensemblRoot/src/shared/components/communication-framework/ConversationIcon',
() => () => ConversationIcon
);
const defaultProps = {
selectedSpecies: times(5, () => createSelectedSpecies()),
push
};
describe('', () => {
afterEach(() => {
jest.resetAllMocks();
});
it('shows placeholder message if no species are selected', () => {
const props = { ...defaultProps, selectedSpecies: [] };
const { container } = render();
expect(container.querySelector('.placeholderMessage')?.textContent).toBe(
placeholderMessage
);
});
it('does not show placeholder message if there are selected species', () => {
const { container } = render();
expect(container.querySelector('.placeholderMessage')).toBeFalsy();
});
it('renders the list of selected species if there are some', () => {
const { container } = render();
expect(container.querySelectorAll('.species').length).toBe(
defaultProps.selectedSpecies.length
);
});
it('opens the species page when a SelectedSpecies tab button is clicked', () => {
const { container } = render();
const firstSelectedSpecies = container.querySelector(
'.species'
) as HTMLElement;
userEvent.click(firstSelectedSpecies);
const firstSpeciesGenomeId = defaultProps.selectedSpecies[0].genome_id;
const speciesPageUrl = urlFor.speciesPage({
genomeId: firstSpeciesGenomeId
});
expect(push).toBeCalledWith(speciesPageUrl);
});
});