import React from 'react'; import _ from 'lodash'; import { render } from '../../utils/test-react-testing-library'; import { DetailContext, DetailContextProps } from '../../pages/Version'; import DetailSidebarFundButton from './DetailSidebarFundButton'; const ComponentToBeRendered: React.FC<{ contextValue: DetailContextProps }> = ({ contextValue }) => ( ); const detailContextValue: DetailContextProps = { packageName: 'foo', readMe: 'test', enableLoading: () => {}, isLoading: false, hasNotBeenFound: false, packageMeta: { _uplinks: {}, latest: { name: '@verdaccio/local-storage', version: '8.0.1-next.1', dist: { fileCount: 0, unpackedSize: 0, tarball: 'http://localhost:8080/bootstrap/-/bootstrap-4.3.1.tgz' }, homepage: 'https://verdaccio.org', bugs: { url: 'https://github.com/verdaccio/monorepo/issues', }, }, }, }; describe('test DetailSidebarFundButton', () => { test('should not display the button if fund is missing', () => { const wrapper = render(); expect(wrapper.queryByText('Fund')).toBeNull(); }); test('should not display the button if url is missing', () => { const value = _.merge(detailContextValue, { packageMeta: { latest: { funding: {}, }, }, }); const wrapper = render(); expect(wrapper.queryByText('Fund')).toBeNull(); }); test('should not display the button if url is not a string', () => { const value = _.merge(detailContextValue, { packageMeta: { latest: { funding: { url: null, }, }, }, }); const wrapper = render(); expect(wrapper.queryByText('Fund')).toBeNull(); }); test('should not display the button if url is not an url', () => { const value = _.merge(detailContextValue, { packageMeta: { latest: { funding: { url: 'somethign different as url', }, }, }, }); const wrapper = render(); expect(wrapper.queryByText('Fund')).toBeNull(); }); test('should display the button if url is a valid url', () => { const value = _.merge(detailContextValue, { packageMeta: { latest: { funding: { url: 'https://opencollective.com/verdaccio', }, }, }, }); const wrapper = render(); expect(wrapper.getByText('Fund')).toBeTruthy(); }); });