@microsoft/terraform-cdk-constructs 1.7.1 → 1.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +46476 -27231
- package/API.md +68443 -28286
- package/lib/azure-actiongroup/lib/action-group.js +1 -1
- package/lib/azure-activitylogalert/lib/activity-log-alert.js +1 -1
- package/lib/azure-aks/lib/aks-cluster.js +1 -1
- package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +1 -1
- package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +1 -1
- package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +1 -1
- package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +1 -1
- package/lib/azure-dnsresolver/lib/dns-resolver.js +1 -1
- package/lib/azure-dnsresolver/lib/inbound-endpoint.js +1 -1
- package/lib/azure-dnsresolver/lib/outbound-endpoint.js +1 -1
- package/lib/azure-dnszone/lib/dns-zone.js +1 -1
- package/lib/azure-dnszone/lib/index.d.ts +1 -0
- package/lib/azure-dnszone/lib/index.js +2 -1
- package/lib/azure-dnszone/lib/records/dns-record-schemas.d.ts +68 -0
- package/lib/azure-dnszone/lib/records/dns-record-schemas.js +813 -0
- package/lib/azure-dnszone/lib/records/dns-records.d.ts +688 -0
- package/lib/azure-dnszone/lib/records/dns-records.js +924 -0
- package/lib/azure-dnszone/lib/records/index.d.ts +19 -0
- package/lib/azure-dnszone/lib/records/index.js +38 -0
- package/lib/azure-dnszone/test/dns-records.integ.d.ts +21 -0
- package/lib/azure-dnszone/test/dns-records.integ.js +321 -0
- package/lib/azure-dnszone/test/dns-records.spec.d.ts +20 -0
- package/lib/azure-dnszone/test/dns-records.spec.js +950 -0
- package/lib/azure-loganalyticsworkspace/index.d.ts +6 -0
- package/lib/azure-loganalyticsworkspace/index.js +23 -0
- package/lib/azure-loganalyticsworkspace/lib/index.d.ts +5 -0
- package/lib/azure-loganalyticsworkspace/lib/index.js +22 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace-schemas.d.ts +51 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace-schemas.js +255 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.d.ts +301 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.js +213 -0
- package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.d.ts +9 -0
- package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.js +71 -0
- package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.d.ts +8 -0
- package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.js +504 -0
- package/lib/azure-metricalert/lib/metric-alert.js +1 -1
- package/lib/azure-networkinterface/lib/network-interface.js +1 -1
- package/lib/azure-networksecuritygroup/lib/network-security-group.js +1 -1
- package/lib/azure-networkwatcher/index.d.ts +14 -0
- package/lib/azure-networkwatcher/index.js +31 -0
- package/lib/azure-networkwatcher/lib/index.d.ts +5 -0
- package/lib/azure-networkwatcher/lib/index.js +22 -0
- package/lib/azure-networkwatcher/lib/network-watcher-schemas.d.ts +47 -0
- package/lib/azure-networkwatcher/lib/network-watcher-schemas.js +167 -0
- package/lib/azure-networkwatcher/lib/network-watcher.d.ts +181 -0
- package/lib/azure-networkwatcher/lib/network-watcher.js +187 -0
- package/lib/azure-networkwatcher/test/network-watcher.integ.d.ts +12 -0
- package/lib/azure-networkwatcher/test/network-watcher.integ.js +84 -0
- package/lib/azure-networkwatcher/test/network-watcher.spec.d.ts +8 -0
- package/lib/azure-networkwatcher/test/network-watcher.spec.js +312 -0
- package/lib/azure-policyassignment/lib/policy-assignment.js +1 -1
- package/lib/azure-policydefinition/lib/policy-definition.js +1 -1
- package/lib/azure-policysetdefinition/index.d.ts +10 -0
- package/lib/azure-policysetdefinition/index.js +27 -0
- package/lib/azure-policysetdefinition/lib/index.d.ts +5 -0
- package/lib/azure-policysetdefinition/lib/index.js +22 -0
- package/lib/azure-policysetdefinition/lib/policy-set-definition-schemas.d.ts +50 -0
- package/lib/azure-policysetdefinition/lib/policy-set-definition-schemas.js +255 -0
- package/lib/azure-policysetdefinition/lib/policy-set-definition.d.ts +426 -0
- package/lib/azure-policysetdefinition/lib/policy-set-definition.js +255 -0
- package/lib/azure-policysetdefinition/test/policy-set-definition.integ.d.ts +9 -0
- package/lib/azure-policysetdefinition/test/policy-set-definition.integ.js +56 -0
- package/lib/azure-policysetdefinition/test/policy-set-definition.spec.d.ts +8 -0
- package/lib/azure-policysetdefinition/test/policy-set-definition.spec.js +745 -0
- package/lib/azure-privatednszone/lib/index.d.ts +1 -0
- package/lib/azure-privatednszone/lib/index.js +2 -1
- package/lib/azure-privatednszone/lib/private-dns-zone.d.ts +0 -2
- package/lib/azure-privatednszone/lib/private-dns-zone.js +6 -13
- package/lib/azure-privatednszone/lib/records/index.d.ts +7 -0
- package/lib/azure-privatednszone/lib/records/index.js +26 -0
- package/lib/azure-privatednszone/lib/records/private-dns-record-schemas.d.ts +52 -0
- package/lib/azure-privatednszone/lib/records/private-dns-record-schemas.js +683 -0
- package/lib/azure-privatednszone/lib/records/private-dns-records.d.ts +523 -0
- package/lib/azure-privatednszone/lib/records/private-dns-records.js +739 -0
- package/lib/azure-privatednszone/test/private-dns-records.integ.d.ts +19 -0
- package/lib/azure-privatednszone/test/private-dns-records.integ.js +245 -0
- package/lib/azure-privatednszone/test/private-dns-records.spec.d.ts +18 -0
- package/lib/azure-privatednszone/test/private-dns-records.spec.js +756 -0
- package/lib/azure-privatednszone/test/private-dns-zone.spec.js +5 -5
- package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +1 -1
- package/lib/azure-publicipaddress/lib/public-ip-address.js +1 -1
- package/lib/azure-resourcegroup/lib/resource-group.js +1 -1
- package/lib/azure-roleassignment/lib/role-assignment.js +1 -1
- package/lib/azure-roledefinition/lib/role-definition.js +1 -1
- package/lib/azure-storageaccount/lib/storage-account.js +1 -1
- package/lib/azure-subnet/lib/subnet.js +1 -1
- package/lib/azure-virtualmachine/lib/virtual-machine.js +1 -1
- package/lib/azure-virtualnetwork/lib/virtual-network.js +1 -1
- package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway-schemas.js +2 -2
- package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.d.ts +4 -2
- package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.js +8 -5
- package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.spec.js +109 -1
- package/lib/azure-virtualnetworkgatewayconnection/lib/virtual-network-gateway-connection.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/network-group.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +1 -1
- package/lib/azure-vmss/lib/virtual-machine-scale-set.js +1 -1
- package/lib/core-azure/lib/azapi/azapi-resource.js +4 -4
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
- package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +1 -1
- package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
- package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
- package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
- package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +1 -1
- package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
- package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
- package/lib/index.d.ts +23 -0
- package/lib/index.js +25 -2
- package/lib/testing/index.js +2 -2
- package/lib/testing/lib/cleanup.js +1 -1
- package/lib/testing/lib/metadata.js +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,312 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Comprehensive tests for the NetworkWatcher implementation
|
|
4
|
+
*
|
|
5
|
+
* This test suite validates the NetworkWatcher class using the AzapiResource framework.
|
|
6
|
+
* Tests cover automatic version resolution, explicit version pinning, schema validation,
|
|
7
|
+
* property configurations, and resource creation.
|
|
8
|
+
*/
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
const cdktf_1 = require("cdktf");
|
|
11
|
+
const cdktf = require("cdktf");
|
|
12
|
+
const network_watcher_1 = require("../lib/network-watcher");
|
|
13
|
+
describe("NetworkWatcher - Implementation", () => {
|
|
14
|
+
let app;
|
|
15
|
+
let stack;
|
|
16
|
+
beforeEach(() => {
|
|
17
|
+
app = cdktf_1.Testing.app();
|
|
18
|
+
stack = new cdktf.TerraformStack(app, "TestStack");
|
|
19
|
+
});
|
|
20
|
+
// =============================================================================
|
|
21
|
+
// Constructor and Basic Properties
|
|
22
|
+
// =============================================================================
|
|
23
|
+
describe("Constructor and Basic Properties", () => {
|
|
24
|
+
it("should create a Network Watcher with minimal configuration", () => {
|
|
25
|
+
const props = {
|
|
26
|
+
name: "test-network-watcher",
|
|
27
|
+
location: "eastus",
|
|
28
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
29
|
+
};
|
|
30
|
+
const networkWatcher = new network_watcher_1.NetworkWatcher(stack, "TestNetworkWatcher", props);
|
|
31
|
+
expect(networkWatcher).toBeInstanceOf(network_watcher_1.NetworkWatcher);
|
|
32
|
+
expect(networkWatcher.props).toBe(props);
|
|
33
|
+
expect(networkWatcher.props.name).toBe("test-network-watcher");
|
|
34
|
+
expect(networkWatcher.props.location).toBe("eastus");
|
|
35
|
+
});
|
|
36
|
+
it("should create a Network Watcher with tags", () => {
|
|
37
|
+
const props = {
|
|
38
|
+
name: "tagged-network-watcher",
|
|
39
|
+
location: "westus2",
|
|
40
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
41
|
+
tags: {
|
|
42
|
+
environment: "production",
|
|
43
|
+
team: "networking",
|
|
44
|
+
},
|
|
45
|
+
};
|
|
46
|
+
const networkWatcher = new network_watcher_1.NetworkWatcher(stack, "TaggedNetworkWatcher", props);
|
|
47
|
+
expect(networkWatcher.props.tags).toEqual({
|
|
48
|
+
environment: "production",
|
|
49
|
+
team: "networking",
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
it("should create a Network Watcher with conventional naming", () => {
|
|
53
|
+
const props = {
|
|
54
|
+
name: "NetworkWatcher_eastus",
|
|
55
|
+
location: "eastus",
|
|
56
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/NetworkWatcherRG",
|
|
57
|
+
};
|
|
58
|
+
const networkWatcher = new network_watcher_1.NetworkWatcher(stack, "ConventionalNetworkWatcher", props);
|
|
59
|
+
expect(networkWatcher.props.name).toBe("NetworkWatcher_eastus");
|
|
60
|
+
});
|
|
61
|
+
});
|
|
62
|
+
// =============================================================================
|
|
63
|
+
// Version Resolution
|
|
64
|
+
// =============================================================================
|
|
65
|
+
describe("Version Resolution", () => {
|
|
66
|
+
it("should use latest version 2024-01-01 when no version specified", () => {
|
|
67
|
+
const networkWatcher = new network_watcher_1.NetworkWatcher(stack, "DefaultVersion", {
|
|
68
|
+
name: "default-version-nw",
|
|
69
|
+
location: "eastus",
|
|
70
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
71
|
+
});
|
|
72
|
+
expect(networkWatcher.resolvedApiVersion).toBe("2024-01-01");
|
|
73
|
+
});
|
|
74
|
+
it("should use explicit version when specified", () => {
|
|
75
|
+
const networkWatcher = new network_watcher_1.NetworkWatcher(stack, "PinnedVersion", {
|
|
76
|
+
name: "pinned-version-nw",
|
|
77
|
+
location: "eastus",
|
|
78
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
79
|
+
apiVersion: "2023-11-01",
|
|
80
|
+
});
|
|
81
|
+
expect(networkWatcher.resolvedApiVersion).toBe("2023-11-01");
|
|
82
|
+
});
|
|
83
|
+
it("should use latest version 2024-01-01 when explicitly specified", () => {
|
|
84
|
+
const networkWatcher = new network_watcher_1.NetworkWatcher(stack, "LatestVersion", {
|
|
85
|
+
name: "latest-version-nw",
|
|
86
|
+
location: "eastus",
|
|
87
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
88
|
+
apiVersion: "2024-01-01",
|
|
89
|
+
});
|
|
90
|
+
expect(networkWatcher.resolvedApiVersion).toBe("2024-01-01");
|
|
91
|
+
});
|
|
92
|
+
});
|
|
93
|
+
// =============================================================================
|
|
94
|
+
// Property Transformation
|
|
95
|
+
// =============================================================================
|
|
96
|
+
describe("Property Transformation", () => {
|
|
97
|
+
it("should generate correct Azure API format via createResourceBody", () => {
|
|
98
|
+
const props = {
|
|
99
|
+
name: "transform-test",
|
|
100
|
+
location: "eastus",
|
|
101
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
102
|
+
};
|
|
103
|
+
const networkWatcher = new network_watcher_1.NetworkWatcher(stack, "TransformTest", props);
|
|
104
|
+
// Access the protected createResourceBody method
|
|
105
|
+
const resourceBody = networkWatcher.createResourceBody(props);
|
|
106
|
+
expect(resourceBody).toHaveProperty("properties");
|
|
107
|
+
expect(resourceBody.properties).toEqual({});
|
|
108
|
+
});
|
|
109
|
+
it("should have empty properties block for Network Watcher", () => {
|
|
110
|
+
const props = {
|
|
111
|
+
name: "empty-props-test",
|
|
112
|
+
location: "eastus",
|
|
113
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
114
|
+
tags: {
|
|
115
|
+
test: "value",
|
|
116
|
+
},
|
|
117
|
+
};
|
|
118
|
+
const networkWatcher = new network_watcher_1.NetworkWatcher(stack, "EmptyPropsTest", props);
|
|
119
|
+
const resourceBody = networkWatcher.createResourceBody(props);
|
|
120
|
+
// Network Watcher properties should be empty - tags are handled at resource level
|
|
121
|
+
expect(Object.keys(resourceBody.properties).length).toBe(0);
|
|
122
|
+
});
|
|
123
|
+
});
|
|
124
|
+
// =============================================================================
|
|
125
|
+
// Integration with Base Class
|
|
126
|
+
// =============================================================================
|
|
127
|
+
describe("Integration with Base Class", () => {
|
|
128
|
+
it("should inherit from AzapiResource", () => {
|
|
129
|
+
const networkWatcher = new network_watcher_1.NetworkWatcher(stack, "InheritanceTest", {
|
|
130
|
+
name: "inheritance-test",
|
|
131
|
+
location: "eastus",
|
|
132
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
133
|
+
});
|
|
134
|
+
// Verify it has AzapiResource properties
|
|
135
|
+
expect(networkWatcher).toHaveProperty("terraformResource");
|
|
136
|
+
expect(networkWatcher).toHaveProperty("resolvedApiVersion");
|
|
137
|
+
});
|
|
138
|
+
it("should have correct resourceType", () => {
|
|
139
|
+
const networkWatcher = new network_watcher_1.NetworkWatcher(stack, "ResourceTypeTest", {
|
|
140
|
+
name: "resource-type-test",
|
|
141
|
+
location: "eastus",
|
|
142
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
143
|
+
});
|
|
144
|
+
// Access the protected resourceType method
|
|
145
|
+
const resourceType = networkWatcher.resourceType();
|
|
146
|
+
expect(resourceType).toBe("Microsoft.Network/networkWatchers");
|
|
147
|
+
});
|
|
148
|
+
it("should resolve parent ID correctly", () => {
|
|
149
|
+
const resourceGroupId = "/subscriptions/test-sub/resourceGroups/test-rg";
|
|
150
|
+
const props = {
|
|
151
|
+
name: "parent-id-test",
|
|
152
|
+
location: "eastus",
|
|
153
|
+
resourceGroupId,
|
|
154
|
+
};
|
|
155
|
+
const networkWatcher = new network_watcher_1.NetworkWatcher(stack, "ParentIdTest", props);
|
|
156
|
+
// Access the protected resolveParentId method
|
|
157
|
+
const parentId = networkWatcher.resolveParentId(props);
|
|
158
|
+
expect(parentId).toBe(resourceGroupId);
|
|
159
|
+
});
|
|
160
|
+
it("should generate resource outputs", () => {
|
|
161
|
+
const networkWatcher = new network_watcher_1.NetworkWatcher(stack, "OutputsTest", {
|
|
162
|
+
name: "outputs-test",
|
|
163
|
+
location: "eastus",
|
|
164
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
165
|
+
});
|
|
166
|
+
expect(networkWatcher.idOutput).toBeInstanceOf(cdktf.TerraformOutput);
|
|
167
|
+
expect(networkWatcher.nameOutput).toBeInstanceOf(cdktf.TerraformOutput);
|
|
168
|
+
expect(networkWatcher.locationOutput).toBeInstanceOf(cdktf.TerraformOutput);
|
|
169
|
+
expect(networkWatcher.provisioningStateOutput).toBeInstanceOf(cdktf.TerraformOutput);
|
|
170
|
+
expect(networkWatcher.id).toMatch(/^\$\{.*\.id\}$/);
|
|
171
|
+
});
|
|
172
|
+
});
|
|
173
|
+
// =============================================================================
|
|
174
|
+
// CDK Terraform Integration
|
|
175
|
+
// =============================================================================
|
|
176
|
+
describe("CDK Terraform Integration", () => {
|
|
177
|
+
it("should synthesize to valid Terraform configuration", () => {
|
|
178
|
+
new network_watcher_1.NetworkWatcher(stack, "SynthTest", {
|
|
179
|
+
name: "synth-test",
|
|
180
|
+
location: "eastus",
|
|
181
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
182
|
+
});
|
|
183
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
184
|
+
expect(synthesized).toBeDefined();
|
|
185
|
+
const stackConfig = JSON.parse(synthesized);
|
|
186
|
+
expect(stackConfig.resource).toBeDefined();
|
|
187
|
+
});
|
|
188
|
+
it("should handle multiple Network Watchers in the same stack (different regions)", () => {
|
|
189
|
+
// Note: In practice, Azure only allows one Network Watcher per region per subscription
|
|
190
|
+
// but CDK can synthesize multiple in the same stack for different regions
|
|
191
|
+
const nw1 = new network_watcher_1.NetworkWatcher(stack, "NetworkWatcher1", {
|
|
192
|
+
name: "nw-eastus",
|
|
193
|
+
location: "eastus",
|
|
194
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
195
|
+
});
|
|
196
|
+
const nw2 = new network_watcher_1.NetworkWatcher(stack, "NetworkWatcher2", {
|
|
197
|
+
name: "nw-westus2",
|
|
198
|
+
location: "westus2",
|
|
199
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
200
|
+
apiVersion: "2023-11-01",
|
|
201
|
+
});
|
|
202
|
+
expect(nw1.resolvedApiVersion).toBe("2024-01-01");
|
|
203
|
+
expect(nw2.resolvedApiVersion).toBe("2023-11-01");
|
|
204
|
+
expect(nw1.props.location).toBe("eastus");
|
|
205
|
+
expect(nw2.props.location).toBe("westus2");
|
|
206
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
207
|
+
expect(synthesized).toBeDefined();
|
|
208
|
+
});
|
|
209
|
+
});
|
|
210
|
+
// =============================================================================
|
|
211
|
+
// Location Requirement
|
|
212
|
+
// =============================================================================
|
|
213
|
+
describe("Location Requirement", () => {
|
|
214
|
+
it("should require location for Network Watcher", () => {
|
|
215
|
+
const networkWatcher = new network_watcher_1.NetworkWatcher(stack, "LocationTest", {
|
|
216
|
+
name: "location-test",
|
|
217
|
+
location: "centralus",
|
|
218
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
219
|
+
});
|
|
220
|
+
// Access the protected requiresLocation method
|
|
221
|
+
const requiresLocation = networkWatcher.requiresLocation();
|
|
222
|
+
expect(requiresLocation).toBe(true);
|
|
223
|
+
});
|
|
224
|
+
it("should accept various Azure regions", () => {
|
|
225
|
+
const regions = [
|
|
226
|
+
"eastus",
|
|
227
|
+
"westus2",
|
|
228
|
+
"northeurope",
|
|
229
|
+
"southeastasia",
|
|
230
|
+
"brazilsouth",
|
|
231
|
+
];
|
|
232
|
+
regions.forEach((region, index) => {
|
|
233
|
+
const props = {
|
|
234
|
+
name: `nw-${region}`,
|
|
235
|
+
location: region,
|
|
236
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
237
|
+
};
|
|
238
|
+
expect(() => {
|
|
239
|
+
new network_watcher_1.NetworkWatcher(stack, `RegionTest${index}`, props);
|
|
240
|
+
}).not.toThrow();
|
|
241
|
+
});
|
|
242
|
+
});
|
|
243
|
+
});
|
|
244
|
+
// =============================================================================
|
|
245
|
+
// Naming Conventions
|
|
246
|
+
// =============================================================================
|
|
247
|
+
describe("Naming Conventions", () => {
|
|
248
|
+
it("should accept Azure default Network Watcher naming convention", () => {
|
|
249
|
+
// Azure typically creates Network Watchers with names like "NetworkWatcher_<region>"
|
|
250
|
+
const props = {
|
|
251
|
+
name: "NetworkWatcher_eastus",
|
|
252
|
+
location: "eastus",
|
|
253
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/NetworkWatcherRG",
|
|
254
|
+
};
|
|
255
|
+
expect(() => {
|
|
256
|
+
new network_watcher_1.NetworkWatcher(stack, "AzureDefaultNaming", props);
|
|
257
|
+
}).not.toThrow();
|
|
258
|
+
});
|
|
259
|
+
it("should accept custom naming with hyphens", () => {
|
|
260
|
+
const props = {
|
|
261
|
+
name: "my-custom-network-watcher",
|
|
262
|
+
location: "eastus",
|
|
263
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
264
|
+
};
|
|
265
|
+
expect(() => {
|
|
266
|
+
new network_watcher_1.NetworkWatcher(stack, "CustomNaming", props);
|
|
267
|
+
}).not.toThrow();
|
|
268
|
+
});
|
|
269
|
+
it("should accept naming with periods", () => {
|
|
270
|
+
const props = {
|
|
271
|
+
name: "nw.prod.eastus",
|
|
272
|
+
location: "eastus",
|
|
273
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
274
|
+
};
|
|
275
|
+
expect(() => {
|
|
276
|
+
new network_watcher_1.NetworkWatcher(stack, "PeriodNaming", props);
|
|
277
|
+
}).not.toThrow();
|
|
278
|
+
});
|
|
279
|
+
});
|
|
280
|
+
// =============================================================================
|
|
281
|
+
// Complete Example Configuration
|
|
282
|
+
// =============================================================================
|
|
283
|
+
describe("Complete Example Configuration", () => {
|
|
284
|
+
it("should handle comprehensive Network Watcher configuration", () => {
|
|
285
|
+
const props = {
|
|
286
|
+
name: "comprehensive-network-watcher",
|
|
287
|
+
location: "eastus",
|
|
288
|
+
resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
|
|
289
|
+
apiVersion: "2024-01-01",
|
|
290
|
+
tags: {
|
|
291
|
+
environment: "production",
|
|
292
|
+
team: "platform",
|
|
293
|
+
"cost-center": "networking",
|
|
294
|
+
"managed-by": "terraform-cdk",
|
|
295
|
+
},
|
|
296
|
+
};
|
|
297
|
+
const networkWatcher = new network_watcher_1.NetworkWatcher(stack, "ComprehensiveConfig", props);
|
|
298
|
+
expect(networkWatcher.props.name).toBe("comprehensive-network-watcher");
|
|
299
|
+
expect(networkWatcher.props.location).toBe("eastus");
|
|
300
|
+
expect(networkWatcher.resolvedApiVersion).toBe("2024-01-01");
|
|
301
|
+
expect(networkWatcher.props.tags).toEqual({
|
|
302
|
+
environment: "production",
|
|
303
|
+
team: "platform",
|
|
304
|
+
"cost-center": "networking",
|
|
305
|
+
"managed-by": "terraform-cdk",
|
|
306
|
+
});
|
|
307
|
+
const resourceBody = networkWatcher.createResourceBody(props);
|
|
308
|
+
expect(resourceBody.properties).toEqual({});
|
|
309
|
+
});
|
|
310
|
+
});
|
|
311
|
+
});
|
|
312
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-watcher.spec.js","sourceRoot":"","sources":["../../../src/azure-networkwatcher/test/network-watcher.spec.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Comprehensive tests for the NetworkWatcher implementation\n *\n * This test suite validates the NetworkWatcher class using the AzapiResource framework.\n * Tests cover automatic version resolution, explicit version pinning, schema validation,\n * property configurations, and resource creation.\n */\n\nimport { Testing } from \"cdktf\";\nimport * as cdktf from \"cdktf\";\nimport { NetworkWatcher, NetworkWatcherProps } from \"../lib/network-watcher\";\n\ndescribe(\"NetworkWatcher - Implementation\", () => {\n  let app: cdktf.App;\n  let stack: cdktf.TerraformStack;\n\n  beforeEach(() => {\n    app = Testing.app();\n    stack = new cdktf.TerraformStack(app, \"TestStack\");\n  });\n\n  // =============================================================================\n  // Constructor and Basic Properties\n  // =============================================================================\n\n  describe(\"Constructor and Basic Properties\", () => {\n    it(\"should create a Network Watcher with minimal configuration\", () => {\n      const props: NetworkWatcherProps = {\n        name: \"test-network-watcher\",\n        location: \"eastus\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n      };\n\n      const networkWatcher = new NetworkWatcher(\n        stack,\n        \"TestNetworkWatcher\",\n        props,\n      );\n\n      expect(networkWatcher).toBeInstanceOf(NetworkWatcher);\n      expect(networkWatcher.props).toBe(props);\n      expect(networkWatcher.props.name).toBe(\"test-network-watcher\");\n      expect(networkWatcher.props.location).toBe(\"eastus\");\n    });\n\n    it(\"should create a Network Watcher with tags\", () => {\n      const props: NetworkWatcherProps = {\n        name: \"tagged-network-watcher\",\n        location: \"westus2\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        tags: {\n          environment: \"production\",\n          team: \"networking\",\n        },\n      };\n\n      const networkWatcher = new NetworkWatcher(\n        stack,\n        \"TaggedNetworkWatcher\",\n        props,\n      );\n\n      expect(networkWatcher.props.tags).toEqual({\n        environment: \"production\",\n        team: \"networking\",\n      });\n    });\n\n    it(\"should create a Network Watcher with conventional naming\", () => {\n      const props: NetworkWatcherProps = {\n        name: \"NetworkWatcher_eastus\",\n        location: \"eastus\",\n        resourceGroupId:\n          \"/subscriptions/test-sub/resourceGroups/NetworkWatcherRG\",\n      };\n\n      const networkWatcher = new NetworkWatcher(\n        stack,\n        \"ConventionalNetworkWatcher\",\n        props,\n      );\n\n      expect(networkWatcher.props.name).toBe(\"NetworkWatcher_eastus\");\n    });\n  });\n\n  // =============================================================================\n  // Version Resolution\n  // =============================================================================\n\n  describe(\"Version Resolution\", () => {\n    it(\"should use latest version 2024-01-01 when no version specified\", () => {\n      const networkWatcher = new NetworkWatcher(stack, \"DefaultVersion\", {\n        name: \"default-version-nw\",\n        location: \"eastus\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n      });\n\n      expect(networkWatcher.resolvedApiVersion).toBe(\"2024-01-01\");\n    });\n\n    it(\"should use explicit version when specified\", () => {\n      const networkWatcher = new NetworkWatcher(stack, \"PinnedVersion\", {\n        name: \"pinned-version-nw\",\n        location: \"eastus\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        apiVersion: \"2023-11-01\",\n      });\n\n      expect(networkWatcher.resolvedApiVersion).toBe(\"2023-11-01\");\n    });\n\n    it(\"should use latest version 2024-01-01 when explicitly specified\", () => {\n      const networkWatcher = new NetworkWatcher(stack, \"LatestVersion\", {\n        name: \"latest-version-nw\",\n        location: \"eastus\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        apiVersion: \"2024-01-01\",\n      });\n\n      expect(networkWatcher.resolvedApiVersion).toBe(\"2024-01-01\");\n    });\n  });\n\n  // =============================================================================\n  // Property Transformation\n  // =============================================================================\n\n  describe(\"Property Transformation\", () => {\n    it(\"should generate correct Azure API format via createResourceBody\", () => {\n      const props: NetworkWatcherProps = {\n        name: \"transform-test\",\n        location: \"eastus\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n      };\n\n      const networkWatcher = new NetworkWatcher(stack, \"TransformTest\", props);\n\n      // Access the protected createResourceBody method\n      const resourceBody = (networkWatcher as any).createResourceBody(props);\n\n      expect(resourceBody).toHaveProperty(\"properties\");\n      expect(resourceBody.properties).toEqual({});\n    });\n\n    it(\"should have empty properties block for Network Watcher\", () => {\n      const props: NetworkWatcherProps = {\n        name: \"empty-props-test\",\n        location: \"eastus\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        tags: {\n          test: \"value\",\n        },\n      };\n\n      const networkWatcher = new NetworkWatcher(stack, \"EmptyPropsTest\", props);\n      const resourceBody = (networkWatcher as any).createResourceBody(props);\n\n      // Network Watcher properties should be empty - tags are handled at resource level\n      expect(Object.keys(resourceBody.properties).length).toBe(0);\n    });\n  });\n\n  // =============================================================================\n  // Integration with Base Class\n  // =============================================================================\n\n  describe(\"Integration with Base Class\", () => {\n    it(\"should inherit from AzapiResource\", () => {\n      const networkWatcher = new NetworkWatcher(stack, \"InheritanceTest\", {\n        name: \"inheritance-test\",\n        location: \"eastus\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n      });\n\n      // Verify it has AzapiResource properties\n      expect(networkWatcher).toHaveProperty(\"terraformResource\");\n      expect(networkWatcher).toHaveProperty(\"resolvedApiVersion\");\n    });\n\n    it(\"should have correct resourceType\", () => {\n      const networkWatcher = new NetworkWatcher(stack, \"ResourceTypeTest\", {\n        name: \"resource-type-test\",\n        location: \"eastus\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n      });\n\n      // Access the protected resourceType method\n      const resourceType = (networkWatcher as any).resourceType();\n      expect(resourceType).toBe(\"Microsoft.Network/networkWatchers\");\n    });\n\n    it(\"should resolve parent ID correctly\", () => {\n      const resourceGroupId = \"/subscriptions/test-sub/resourceGroups/test-rg\";\n\n      const props: NetworkWatcherProps = {\n        name: \"parent-id-test\",\n        location: \"eastus\",\n        resourceGroupId,\n      };\n\n      const networkWatcher = new NetworkWatcher(stack, \"ParentIdTest\", props);\n\n      // Access the protected resolveParentId method\n      const parentId = (networkWatcher as any).resolveParentId(props);\n      expect(parentId).toBe(resourceGroupId);\n    });\n\n    it(\"should generate resource outputs\", () => {\n      const networkWatcher = new NetworkWatcher(stack, \"OutputsTest\", {\n        name: \"outputs-test\",\n        location: \"eastus\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n      });\n\n      expect(networkWatcher.idOutput).toBeInstanceOf(cdktf.TerraformOutput);\n      expect(networkWatcher.nameOutput).toBeInstanceOf(cdktf.TerraformOutput);\n      expect(networkWatcher.locationOutput).toBeInstanceOf(\n        cdktf.TerraformOutput,\n      );\n      expect(networkWatcher.provisioningStateOutput).toBeInstanceOf(\n        cdktf.TerraformOutput,\n      );\n      expect(networkWatcher.id).toMatch(/^\\$\\{.*\\.id\\}$/);\n    });\n  });\n\n  // =============================================================================\n  // CDK Terraform Integration\n  // =============================================================================\n\n  describe(\"CDK Terraform Integration\", () => {\n    it(\"should synthesize to valid Terraform configuration\", () => {\n      new NetworkWatcher(stack, \"SynthTest\", {\n        name: \"synth-test\",\n        location: \"eastus\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n      });\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toBeDefined();\n\n      const stackConfig = JSON.parse(synthesized);\n      expect(stackConfig.resource).toBeDefined();\n    });\n\n    it(\"should handle multiple Network Watchers in the same stack (different regions)\", () => {\n      // Note: In practice, Azure only allows one Network Watcher per region per subscription\n      // but CDK can synthesize multiple in the same stack for different regions\n      const nw1 = new NetworkWatcher(stack, \"NetworkWatcher1\", {\n        name: \"nw-eastus\",\n        location: \"eastus\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n      });\n\n      const nw2 = new NetworkWatcher(stack, \"NetworkWatcher2\", {\n        name: \"nw-westus2\",\n        location: \"westus2\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        apiVersion: \"2023-11-01\",\n      });\n\n      expect(nw1.resolvedApiVersion).toBe(\"2024-01-01\");\n      expect(nw2.resolvedApiVersion).toBe(\"2023-11-01\");\n      expect(nw1.props.location).toBe(\"eastus\");\n      expect(nw2.props.location).toBe(\"westus2\");\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toBeDefined();\n    });\n  });\n\n  // =============================================================================\n  // Location Requirement\n  // =============================================================================\n\n  describe(\"Location Requirement\", () => {\n    it(\"should require location for Network Watcher\", () => {\n      const networkWatcher = new NetworkWatcher(stack, \"LocationTest\", {\n        name: \"location-test\",\n        location: \"centralus\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n      });\n\n      // Access the protected requiresLocation method\n      const requiresLocation = (networkWatcher as any).requiresLocation();\n      expect(requiresLocation).toBe(true);\n    });\n\n    it(\"should accept various Azure regions\", () => {\n      const regions = [\n        \"eastus\",\n        \"westus2\",\n        \"northeurope\",\n        \"southeastasia\",\n        \"brazilsouth\",\n      ];\n\n      regions.forEach((region, index) => {\n        const props: NetworkWatcherProps = {\n          name: `nw-${region}`,\n          location: region,\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        };\n\n        expect(() => {\n          new NetworkWatcher(stack, `RegionTest${index}`, props);\n        }).not.toThrow();\n      });\n    });\n  });\n\n  // =============================================================================\n  // Naming Conventions\n  // =============================================================================\n\n  describe(\"Naming Conventions\", () => {\n    it(\"should accept Azure default Network Watcher naming convention\", () => {\n      // Azure typically creates Network Watchers with names like \"NetworkWatcher_<region>\"\n      const props: NetworkWatcherProps = {\n        name: \"NetworkWatcher_eastus\",\n        location: \"eastus\",\n        resourceGroupId:\n          \"/subscriptions/test-sub/resourceGroups/NetworkWatcherRG\",\n      };\n\n      expect(() => {\n        new NetworkWatcher(stack, \"AzureDefaultNaming\", props);\n      }).not.toThrow();\n    });\n\n    it(\"should accept custom naming with hyphens\", () => {\n      const props: NetworkWatcherProps = {\n        name: \"my-custom-network-watcher\",\n        location: \"eastus\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n      };\n\n      expect(() => {\n        new NetworkWatcher(stack, \"CustomNaming\", props);\n      }).not.toThrow();\n    });\n\n    it(\"should accept naming with periods\", () => {\n      const props: NetworkWatcherProps = {\n        name: \"nw.prod.eastus\",\n        location: \"eastus\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n      };\n\n      expect(() => {\n        new NetworkWatcher(stack, \"PeriodNaming\", props);\n      }).not.toThrow();\n    });\n  });\n\n  // =============================================================================\n  // Complete Example Configuration\n  // =============================================================================\n\n  describe(\"Complete Example Configuration\", () => {\n    it(\"should handle comprehensive Network Watcher configuration\", () => {\n      const props: NetworkWatcherProps = {\n        name: \"comprehensive-network-watcher\",\n        location: \"eastus\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        apiVersion: \"2024-01-01\",\n        tags: {\n          environment: \"production\",\n          team: \"platform\",\n          \"cost-center\": \"networking\",\n          \"managed-by\": \"terraform-cdk\",\n        },\n      };\n\n      const networkWatcher = new NetworkWatcher(\n        stack,\n        \"ComprehensiveConfig\",\n        props,\n      );\n\n      expect(networkWatcher.props.name).toBe(\"comprehensive-network-watcher\");\n      expect(networkWatcher.props.location).toBe(\"eastus\");\n      expect(networkWatcher.resolvedApiVersion).toBe(\"2024-01-01\");\n      expect(networkWatcher.props.tags).toEqual({\n        environment: \"production\",\n        team: \"platform\",\n        \"cost-center\": \"networking\",\n        \"managed-by\": \"terraform-cdk\",\n      });\n\n      const resourceBody = (networkWatcher as any).createResourceBody(props);\n      expect(resourceBody.properties).toEqual({});\n    });\n  });\n});\n"]}
|
|
@@ -236,7 +236,7 @@ class PolicyAssignment extends azapi_resource_1.AzapiResource {
|
|
|
236
236
|
}
|
|
237
237
|
exports.PolicyAssignment = PolicyAssignment;
|
|
238
238
|
_a = JSII_RTTI_SYMBOL_1;
|
|
239
|
-
PolicyAssignment[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PolicyAssignment", version: "1.
|
|
239
|
+
PolicyAssignment[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PolicyAssignment", version: "1.9.0" };
|
|
240
240
|
(() => {
|
|
241
241
|
azapi_resource_1.AzapiResource.registerSchemas(policy_assignment_schemas_1.POLICY_ASSIGNMENT_TYPE, policy_assignment_schemas_1.ALL_POLICY_ASSIGNMENT_VERSIONS);
|
|
242
242
|
})();
|
|
@@ -260,7 +260,7 @@ class PolicyDefinition extends azapi_resource_1.AzapiResource {
|
|
|
260
260
|
}
|
|
261
261
|
exports.PolicyDefinition = PolicyDefinition;
|
|
262
262
|
_a = JSII_RTTI_SYMBOL_1;
|
|
263
|
-
PolicyDefinition[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PolicyDefinition", version: "1.
|
|
263
|
+
PolicyDefinition[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PolicyDefinition", version: "1.9.0" };
|
|
264
264
|
(() => {
|
|
265
265
|
azapi_resource_1.AzapiResource.registerSchemas(policy_definition_schemas_1.POLICY_DEFINITION_TYPE, policy_definition_schemas_1.ALL_POLICY_DEFINITION_VERSIONS);
|
|
266
266
|
})();
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Azure Policy Set Definition (Initiative) module
|
|
3
|
+
*
|
|
4
|
+
* This module provides constructs for creating and managing Azure Policy Set Definitions
|
|
5
|
+
* (also known as Initiatives in Azure Portal).
|
|
6
|
+
*
|
|
7
|
+
* Policy Set Definitions allow you to group multiple policy definitions together
|
|
8
|
+
* and assign them as a single unit for easier governance and compliance management.
|
|
9
|
+
*/
|
|
10
|
+
export * from "./lib";
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Azure Policy Set Definition (Initiative) module
|
|
4
|
+
*
|
|
5
|
+
* This module provides constructs for creating and managing Azure Policy Set Definitions
|
|
6
|
+
* (also known as Initiatives in Azure Portal).
|
|
7
|
+
*
|
|
8
|
+
* Policy Set Definitions allow you to group multiple policy definitions together
|
|
9
|
+
* and assign them as a single unit for easier governance and compliance management.
|
|
10
|
+
*/
|
|
11
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
12
|
+
if (k2 === undefined) k2 = k;
|
|
13
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
14
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
15
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
16
|
+
}
|
|
17
|
+
Object.defineProperty(o, k2, desc);
|
|
18
|
+
}) : (function(o, m, k, k2) {
|
|
19
|
+
if (k2 === undefined) k2 = k;
|
|
20
|
+
o[k2] = m[k];
|
|
21
|
+
}));
|
|
22
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
23
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
__exportStar(require("./lib"), exports);
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXp1cmUtcG9saWN5c2V0ZGVmaW5pdGlvbi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7O0dBUUc7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFSCx3Q0FBc0IiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEF6dXJlIFBvbGljeSBTZXQgRGVmaW5pdGlvbiAoSW5pdGlhdGl2ZSkgbW9kdWxlXG4gKlxuICogVGhpcyBtb2R1bGUgcHJvdmlkZXMgY29uc3RydWN0cyBmb3IgY3JlYXRpbmcgYW5kIG1hbmFnaW5nIEF6dXJlIFBvbGljeSBTZXQgRGVmaW5pdGlvbnNcbiAqIChhbHNvIGtub3duIGFzIEluaXRpYXRpdmVzIGluIEF6dXJlIFBvcnRhbCkuXG4gKlxuICogUG9saWN5IFNldCBEZWZpbml0aW9ucyBhbGxvdyB5b3UgdG8gZ3JvdXAgbXVsdGlwbGUgcG9saWN5IGRlZmluaXRpb25zIHRvZ2V0aGVyXG4gKiBhbmQgYXNzaWduIHRoZW0gYXMgYSBzaW5nbGUgdW5pdCBmb3IgZWFzaWVyIGdvdmVybmFuY2UgYW5kIGNvbXBsaWFuY2UgbWFuYWdlbWVudC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tIFwiLi9saWJcIjtcbiJdfQ==
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Azure Policy Set Definition (Initiative) construct exports
|
|
4
|
+
*/
|
|
5
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
8
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
9
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
10
|
+
}
|
|
11
|
+
Object.defineProperty(o, k2, desc);
|
|
12
|
+
}) : (function(o, m, k, k2) {
|
|
13
|
+
if (k2 === undefined) k2 = k;
|
|
14
|
+
o[k2] = m[k];
|
|
15
|
+
}));
|
|
16
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
17
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
18
|
+
};
|
|
19
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
20
|
+
__exportStar(require("./policy-set-definition-schemas"), exports);
|
|
21
|
+
__exportStar(require("./policy-set-definition"), exports);
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXp1cmUtcG9saWN5c2V0ZGVmaW5pdGlvbi9saWIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOztHQUVHOzs7Ozs7Ozs7Ozs7Ozs7O0FBRUgsa0VBQWdEO0FBQ2hELDBEQUF3QyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQXp1cmUgUG9saWN5IFNldCBEZWZpbml0aW9uIChJbml0aWF0aXZlKSBjb25zdHJ1Y3QgZXhwb3J0c1xuICovXG5cbmV4cG9ydCAqIGZyb20gXCIuL3BvbGljeS1zZXQtZGVmaW5pdGlvbi1zY2hlbWFzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9wb2xpY3ktc2V0LWRlZmluaXRpb25cIjtcbiJdfQ==
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* API schemas for Azure Policy Set Definition (Initiative) across all supported versions
|
|
3
|
+
*
|
|
4
|
+
* This file defines the complete API schemas for Microsoft.Authorization/policySetDefinitions
|
|
5
|
+
* across all supported API versions. The schemas are used by the AzapiResource
|
|
6
|
+
* framework for validation, transformation, and version management.
|
|
7
|
+
*
|
|
8
|
+
* Policy Set Definitions (also known as Initiatives) are collections of policy definitions
|
|
9
|
+
* that allow you to group policies and assign them together as a single unit.
|
|
10
|
+
*/
|
|
11
|
+
import { ApiSchema, VersionConfig } from "../../core-azure/lib/version-manager/interfaces/version-interfaces";
|
|
12
|
+
/**
|
|
13
|
+
* API Schema for Policy Set Definition version 2023-04-01
|
|
14
|
+
*
|
|
15
|
+
* This is the latest stable version for Policy Set Definitions.
|
|
16
|
+
* It includes support for:
|
|
17
|
+
* - Policy definition references with parameters
|
|
18
|
+
* - Policy definition groups for organization
|
|
19
|
+
* - Metadata for categorization
|
|
20
|
+
* - Parameter definitions for the initiative
|
|
21
|
+
*/
|
|
22
|
+
export declare const POLICY_SET_DEFINITION_SCHEMA_2023_04_01: ApiSchema;
|
|
23
|
+
/**
|
|
24
|
+
* API Schema for Policy Set Definition version 2021-06-01
|
|
25
|
+
*
|
|
26
|
+
* This is a stable version for backward compatibility.
|
|
27
|
+
* It includes support for:
|
|
28
|
+
* - Policy definition references with parameters
|
|
29
|
+
* - Policy definition groups for organization
|
|
30
|
+
* - Metadata for categorization
|
|
31
|
+
* - Parameter definitions for the initiative
|
|
32
|
+
*/
|
|
33
|
+
export declare const POLICY_SET_DEFINITION_SCHEMA_2021_06_01: ApiSchema;
|
|
34
|
+
/**
|
|
35
|
+
* Version configuration for Policy Set Definition 2023-04-01
|
|
36
|
+
*/
|
|
37
|
+
export declare const POLICY_SET_DEFINITION_VERSION_2023_04_01: VersionConfig;
|
|
38
|
+
/**
|
|
39
|
+
* Version configuration for Policy Set Definition 2021-06-01
|
|
40
|
+
*/
|
|
41
|
+
export declare const POLICY_SET_DEFINITION_VERSION_2021_06_01: VersionConfig;
|
|
42
|
+
/**
|
|
43
|
+
* All supported Policy Set Definition versions for registration
|
|
44
|
+
* Ordered with latest stable version first
|
|
45
|
+
*/
|
|
46
|
+
export declare const ALL_POLICY_SET_DEFINITION_VERSIONS: VersionConfig[];
|
|
47
|
+
/**
|
|
48
|
+
* Resource type constant
|
|
49
|
+
*/
|
|
50
|
+
export declare const POLICY_SET_DEFINITION_TYPE = "Microsoft.Authorization/policySetDefinitions";
|