DataSourcesListPage.test.tsx 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. import React from 'react';
  2. import { shallow } from 'enzyme';
  3. import { DataSourcesListPage, Props } from './DataSourcesListPage';
  4. import { DataSource, NavModel } from 'app/types';
  5. import { LayoutModes } from '../../core/components/LayoutSelector/LayoutSelector';
  6. import { getMockDataSources } from './__mocks__/dataSourcesMocks';
  7. const setup = (propOverrides?: object) => {
  8. const props: Props = {
  9. dataSources: [] as DataSource[],
  10. layoutMode: LayoutModes.Grid,
  11. loadDataSources: jest.fn(),
  12. navModel: {} as NavModel,
  13. dataSourcesCount: 0,
  14. searchQuery: '',
  15. setDataSourcesSearchQuery: jest.fn(),
  16. setDataSourcesLayoutMode: jest.fn(),
  17. };
  18. Object.assign(props, propOverrides);
  19. return shallow(<DataSourcesListPage {...props} />);
  20. };
  21. describe('Render', () => {
  22. it('should render component', () => {
  23. const wrapper = setup();
  24. expect(wrapper).toMatchSnapshot();
  25. });
  26. it('should render action bar and datasources', () => {
  27. const wrapper = setup({
  28. dataSources: getMockDataSources(5),
  29. dataSourcesCount: 5,
  30. });
  31. expect(wrapper).toMatchSnapshot();
  32. });
  33. });