]> source.dussan.org Git - sonarqube.git/blob
856efeeb83c294c4197b2da40b6103b4e980e2e7
[sonarqube.git] /
1 /*
2  * SonarQube
3  * Copyright (C) 2009-2021 SonarSource SA
4  * mailto:info AT sonarsource DOT com
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 3 of the License, or (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public License
17  * along with this program; if not, write to the Free Software Foundation,
18  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
19  */
20 import { shallow } from 'enzyme';
21 import * as React from 'react';
22 import { mockComponent } from '../../../../../../helpers/mocks/component';
23 import { mockCurrentUser, mockLoggedInUser, mockMetric } from '../../../../../../helpers/testMocks';
24 import { waitAndUpdate } from '../../../../../../helpers/testUtils';
25 import { ProjectInformation } from '../ProjectInformation';
26 import { ProjectInformationPages } from '../ProjectInformationPages';
27
28 jest.mock('../../../../../../api/measures', () => {
29   const { mockMeasure } = jest.requireActual('../../../../../../helpers/testMocks');
30   return {
31     getMeasures: jest.fn().mockResolvedValue([mockMeasure()])
32   };
33 });
34
35 it('should render correctly', async () => {
36   expect(shallowRender()).toMatchSnapshot('default');
37   expect(shallowRender({ currentUser: mockLoggedInUser() })).toMatchSnapshot('logged in user');
38   expect(shallowRender({ component: mockComponent({ visibility: 'private' }) })).toMatchSnapshot(
39     'private'
40   );
41   const wrapper = shallowRender();
42   await waitAndUpdate(wrapper);
43   expect(wrapper).toMatchSnapshot('measures loaded');
44 });
45
46 it('should handle page change', async () => {
47   const wrapper = shallowRender();
48
49   wrapper.instance().setPage(ProjectInformationPages.badges);
50
51   await waitAndUpdate(wrapper);
52
53   expect(wrapper.state().page).toBe(ProjectInformationPages.badges);
54 });
55
56 function shallowRender(props: Partial<ProjectInformation['props']> = {}) {
57   return shallow<ProjectInformation>(
58     <ProjectInformation
59       component={mockComponent()}
60       currentUser={mockCurrentUser()}
61       fetchMetrics={jest.fn()}
62       metrics={{
63         coverage: mockMetric()
64       }}
65       onComponentChange={jest.fn()}
66       {...props}
67     />
68   );
69 }