-
Notifications
You must be signed in to change notification settings - Fork 2.3k
/
Copy pathSecurityRequirement.test.tsx
87 lines (79 loc) · 2.8 KB
/
SecurityRequirement.test.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
import * as React from 'react';
import { mount } from 'enzyme';
import {
createStore,
OpenAPIParser,
OperationModel,
RedocNormalizedOptions,
SecuritySchemesModel,
} from '../../services';
import { StoreProvider } from '../StoreBuilder';
import { SecurityRequirementModel } from '../../services/models/SecurityRequirement';
import { SecurityRequirements } from '../SecurityRequirement/SecurityRequirement';
import { withTheme } from '../testProviders';
import { SecurityDefs } from '../SecuritySchemes/SecuritySchemes';
import * as simpleSecurityFixture from './fixtures/simple-security-fixture.json';
describe('SecurityRequirement', () => {
it('should render authDefinition', async () => {
const store = await createStore(simpleSecurityFixture, undefined, {
showSecuritySchemeType: true,
});
store.spec.contentItems.forEach((item: OperationModel) => {
if (item.security) {
const component = mount(
withTheme(
<StoreProvider value={store}>
<SecurityRequirements securities={item.security} />,
</StoreProvider>,
),
);
expect(component.html()).toMatchSnapshot();
component.find('svg').simulate('click');
//Security expanded
expect(component.html()).toMatchSnapshot();
}
});
});
it('should render SecurityDefs', async () => {
const parser = new OpenAPIParser(
simpleSecurityFixture,
undefined,
new RedocNormalizedOptions({}),
);
const component = mount(
withTheme(<SecurityDefs securitySchemes={new SecuritySchemesModel(parser)} />),
);
expect(component.html()).toMatchSnapshot();
});
it("should render 'None' when empty object in security open api", () => {
const options = new RedocNormalizedOptions({});
const parser = new OpenAPIParser(
{ openapi: '3.0', info: { title: 'test', version: '0' }, paths: {} },
undefined,
options,
);
const securityRequirement = [new SecurityRequirementModel({}, parser)];
const component = mount(
withTheme(<SecurityRequirements securities={securityRequirement} key={1} />),
);
expect(component.find('span').at(0).text()).toEqual('None');
});
it('should hide authDefinition', async () => {
const store = await createStore(simpleSecurityFixture, undefined, {
hideSecuritySection: true,
});
store.spec.contentItems.forEach((item: OperationModel) => {
if (item.security) {
const component = mount(
withTheme(
<StoreProvider value={store}>
<SecurityRequirements securities={item.security} />,
</StoreProvider>,
),
);
expect(component.html().includes('Authorizations')).toBe(false);
expect(component.html().includes('svg')).toBe(false);
}
});
});
});