import React from 'react'; import { create } from 'react-test-renderer'; import { mount } from 'enzyme'; import { containerRendersView, TestRouterWrapper } from 'lib/testHelpers'; import { clusterConnectConnectorConfigPath } from 'lib/paths'; import ConfigContainer from 'components/Connect/Details/Config/ConfigContainer'; import Config, { ConfigProps } from 'components/Connect/Details/Config/Config'; import { connector } from 'redux/reducers/connect/__test__/fixtures'; jest.mock('components/common/PageLoader/PageLoader', () => 'mock-PageLoader'); jest.mock('components/common/JSONEditor/JSONEditor', () => 'mock-JSONEditor'); describe('Config', () => { containerRendersView(, Config); describe('view', () => { const pathname = clusterConnectConnectorConfigPath( ':clusterName', ':connectName', ':connectorName' ); const clusterName = 'my-cluster'; const connectName = 'my-connect'; const connectorName = 'my-connector'; const setupWrapper = (props: Partial = {}) => ( ); it('matches snapshot', () => { const wrapper = create(setupWrapper()); expect(wrapper.toJSON()).toMatchSnapshot(); }); it('matches snapshot when fetching config', () => { const wrapper = create(setupWrapper({ isConfigFetching: true })); expect(wrapper.toJSON()).toMatchSnapshot(); }); it('matches snapshot when no config', () => { const wrapper = create(setupWrapper({ config: null })); expect(wrapper.toJSON()).toMatchSnapshot(); }); it('fetches config on mount', () => { const fetchConfig = jest.fn(); mount(setupWrapper({ fetchConfig })); expect(fetchConfig).toHaveBeenCalledTimes(1); expect(fetchConfig).toHaveBeenCalledWith( clusterName, connectName, connectorName, true ); }); }); });