-
Notifications
You must be signed in to change notification settings - Fork 51
Expand file tree
/
Copy pathmigrated-arm-rule-tests.ts
More file actions
142 lines (122 loc) · 7.61 KB
/
migrated-arm-rule-tests.ts
File metadata and controls
142 lines (122 loc) · 7.61 KB
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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
import { LintResultMessage, OpenApiTypes } from "@microsoft.azure/openapi-validator-core"
import { assertValidationRuleCount, collectTestMessagesFromValidator } from "./utilities/tests-helper"
describe("IndividualAzureTests", () => {
test("body top level resource with extra", async () => {
const fileNames = ["body-top-level-properties.json"]
const ruleName = "BodyTopLevelProperties"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 2)
})
test("body top level resource with real swagger", async () => {
const fileNames = ["body-top-level-properties-real-swagger.json"]
const ruleName = "BodyTopLevelProperties"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 1)
})
test("body top level resource with managedByExtended should pass", async () => {
const fileNames = ["body-top-level-properties-managedByExtended.json"]
const ruleName = "BodyTopLevelProperties"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 0)
})
test("tracked resource must have patch", async () => {
const fileNames = ["armResource/trackedResourceNoPatch.json", "armResource/trackedResourceCommon.json"]
const ruleName = "TrackedResourcePatchOperation"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 1)
})
test("required properties in resource model", async () => {
const fileNames = ["ext-resource-validation.json"]
const ruleName = "RequiredPropertiesMissingInResourceModel"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 4)
})
test("[positive] required properties in resource model with reference", async () => {
const fileNames = ["ext-resource-validation-with-reference.json", "common-types/types.json"]
const ruleName = "RequiredPropertiesMissingInResourceModel"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 0)
})
test("operation api implementation", async () => {
const fileNames = ["operations-api-validation.json"]
const ruleName = "OperationsAPIImplementation"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 1)
})
test("operation api implementation for valid operations api", async () => {
const fileNames = ["operations-api-validation-no-errors.json"]
const ruleName = "OperationsAPIImplementation"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 0)
})
test("operation api implementation should have error for only a subscription level operations path", async () => {
const fileNames = ["operations-api-validation-subscription-level.json"]
const ruleName = "OperationsAPIImplementation"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 1)
})
test("resource property bag multiple level violations", async () => {
const fileNames = ["arm-resource-properties-bag-multiple-level-violations.json"]
const ruleName = "ArmResourcePropertiesBag"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 2)
})
test("resource property bag multiple violations", async () => {
const fileNames = ["arm-resource-properties-bag-multiple-violations.json"]
const ruleName = "ArmResourcePropertiesBag"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 2)
})
test("resource property bag with tracked resource", async () => {
const fileNames = ["arm-resource-properties-bag.json"]
const ruleName = "ArmResourcePropertiesBag"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 1)
})
test("resource property bag with reference and tracked resource", async () => {
const fileNames = ["arm-resource-properties-bag-with-reference.json"]
const ruleName = "ArmResourcePropertiesBag"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 2)
})
test("resource property bag with proxy resource", async () => {
const fileNames = ["arm-resource-properties-bag-proxy-resource.json"]
const ruleName = "ArmResourcePropertiesBag"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 1)
})
test("resource property bag with reference and proxy resource", async () => {
const fileNames = ["arm-resource-properties-bag-with-reference-proxy-resources.json"]
const ruleName = "ArmResourcePropertiesBag"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 2)
})
test("resource property bag with multiple level reference", async () => {
const fileNames = ["arm-resource-properties-bag-with-multiple-level-reference.json"]
const ruleName = "ArmResourcePropertiesBag"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 2)
})
test("provider namespace does not match file path", async () => {
const fileNames = ["resource-manager/Microsoft.Network/network-interface-invalid.json"]
const ruleName = "PathResourceProviderMatchNamespace"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileNames, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 1)
})
test("xms-pageable list by RG and subscription", async () => {
const fileName = ["armResource/xmsPageableListByRGAndSubscription.json", "armResource/trackedResourceCommon.json"]
const ruleName = "XmsPageableListByRGAndSubscriptions"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileName, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 1)
})
test("private link apis missing", async () => {
const fileName = "PrivateLinkAPIsMissing.json"
const ruleName = "ImplementPrivateEndpointAPIs"
const messages: LintResultMessage[] = await collectTestMessagesFromValidator(fileName, OpenApiTypes.arm, ruleName)
assertValidationRuleCount(messages, ruleName, 1)
})
})