import { shallow, ShallowWrapper } from 'enzyme'; import { Mock } from 'ts-mockery'; import ShlinkVersionsContainer from '../../src/common/ShlinkVersionsContainer'; import { NonReachableServer, NotFoundServer, ReachableServer, SelectedServer } from '../../src/servers/data'; describe('', () => { let wrapper: ShallowWrapper; const createWrapper = (selectedServer: SelectedServer) => { wrapper = shallow(); return wrapper; }; afterEach(() => wrapper?.unmount()); test.each([ [ null, 'col-12' ], [ Mock.of({ serverNotFound: true }), 'col-12' ], [ Mock.of({ serverNotReachable: true }), 'col-12' ], [ Mock.of({ printableVersion: 'v1.0.0' }), 'col-lg-10 offset-lg-2 col-md-9 offset-md-3' ], ])('renders proper col classes based on type of selected server', (selectedServer, expectedClasses) => { const wrapper = createWrapper(selectedServer); expect(wrapper.find('div').at(1).prop('className')).toEqual(`text-center ${expectedClasses}`); }); });