@microsoft/terraform-cdk-constructs 1.3.1 → 1.5.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 +32238 -27310
- package/API.md +43714 -35942
- 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-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-policyassignment/lib/policy-assignment.js +1 -1
- package/lib/azure-policydefinition/lib/policy-definition.js +1 -1
- package/lib/azure-privatednszone/lib/private-dns-zone.js +1 -1
- 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/index.d.ts +4 -0
- package/lib/azure-virtualnetworkgateway/index.js +21 -0
- package/lib/azure-virtualnetworkgateway/lib/index.d.ts +5 -0
- package/lib/azure-virtualnetworkgateway/lib/index.js +22 -0
- package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway-schemas.d.ts +32 -0
- package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway-schemas.js +298 -0
- package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.d.ts +368 -0
- package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.js +285 -0
- package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.integ.d.ts +12 -0
- package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.integ.js +129 -0
- package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.spec.d.ts +8 -0
- package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.spec.js +691 -0
- package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/index.d.ts +5 -0
- package/lib/azure-virtualnetworkmanager/lib/index.js +6 -1
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-schemas.d.ts +24 -0
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-schemas.js +169 -0
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr-schemas.d.ts +32 -0
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr-schemas.js +206 -0
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.d.ts +170 -0
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +214 -0
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool.d.ts +175 -0
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +206 -0
- 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/utils/cidr-validator.d.ts +225 -0
- package/lib/azure-virtualnetworkmanager/lib/utils/cidr-validator.js +389 -0
- package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.d.ts +56 -0
- package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +29 -2
- package/lib/azure-virtualnetworkmanager/test/cidr-validator.spec.d.ts +6 -0
- package/lib/azure-virtualnetworkmanager/test/cidr-validator.spec.js +292 -0
- package/lib/azure-virtualnetworkmanager/test/ipam-pool-static-cidr.spec.d.ts +6 -0
- package/lib/azure-virtualnetworkmanager/test/ipam-pool-static-cidr.spec.js +430 -0
- package/lib/azure-virtualnetworkmanager/test/ipam-pool.spec.d.ts +6 -0
- package/lib/azure-virtualnetworkmanager/test/ipam-pool.spec.js +372 -0
- package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.d.ts +2 -1
- package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.js +30 -3
- package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.js +105 -1
- package/lib/azure-vmss/lib/virtual-machine-scale-set.js +1 -1
- package/lib/core-azure/lib/azapi/azapi-resource.js +2 -2
- 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 +2 -0
- package/lib/index.js +4 -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,285 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.VirtualNetworkGateway = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
/**
|
|
7
|
+
* Azure Virtual Network Gateway implementation using AzapiResource framework
|
|
8
|
+
*
|
|
9
|
+
* This class provides a unified implementation for Azure Virtual Network Gateways that
|
|
10
|
+
* automatically handles version management, schema validation, and property
|
|
11
|
+
* transformation across all supported API versions.
|
|
12
|
+
*
|
|
13
|
+
* Supported API Versions:
|
|
14
|
+
* - 2024-01-01 (Active)
|
|
15
|
+
* - 2024-05-01 (Active, Latest)
|
|
16
|
+
*
|
|
17
|
+
* Features:
|
|
18
|
+
* - Automatic latest version resolution when no version is specified
|
|
19
|
+
* - Explicit version pinning for stability requirements
|
|
20
|
+
* - Schema-driven validation and transformation
|
|
21
|
+
* - Full backward compatibility
|
|
22
|
+
* - JSII compliance for multi-language support
|
|
23
|
+
*/
|
|
24
|
+
const cdktf = require("cdktf");
|
|
25
|
+
const virtual_network_gateway_schemas_1 = require("./virtual-network-gateway-schemas");
|
|
26
|
+
const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
|
|
27
|
+
/**
|
|
28
|
+
* Azure Virtual Network Gateway implementation
|
|
29
|
+
*
|
|
30
|
+
* This class provides a single, version-aware implementation that replaces
|
|
31
|
+
* version-specific Virtual Network Gateway classes. It automatically handles version
|
|
32
|
+
* resolution, schema validation, and property transformation while maintaining
|
|
33
|
+
* full backward compatibility.
|
|
34
|
+
*
|
|
35
|
+
* Virtual Network Gateways are used to send encrypted traffic between Azure virtual
|
|
36
|
+
* networks and on-premises locations over the public Internet (VPN) or through
|
|
37
|
+
* Azure ExpressRoute circuits (ExpressRoute).
|
|
38
|
+
*
|
|
39
|
+
* @example
|
|
40
|
+
* // Basic VPN Gateway:
|
|
41
|
+
* const vpnGateway = new VirtualNetworkGateway(this, "vpnGateway", {
|
|
42
|
+
* name: "my-vpn-gateway",
|
|
43
|
+
* location: "eastus",
|
|
44
|
+
* resourceGroupId: resourceGroup.id,
|
|
45
|
+
* gatewayType: "Vpn",
|
|
46
|
+
* vpnType: "RouteBased",
|
|
47
|
+
* sku: {
|
|
48
|
+
* name: "VpnGw1",
|
|
49
|
+
* tier: "VpnGw1"
|
|
50
|
+
* },
|
|
51
|
+
* ipConfigurations: [{
|
|
52
|
+
* name: "default",
|
|
53
|
+
* subnetId: gatewaySubnet.id,
|
|
54
|
+
* publicIPAddressId: publicIp.id
|
|
55
|
+
* }]
|
|
56
|
+
* });
|
|
57
|
+
*
|
|
58
|
+
* @example
|
|
59
|
+
* // VPN Gateway with BGP:
|
|
60
|
+
* const vpnGateway = new VirtualNetworkGateway(this, "vpnGateway", {
|
|
61
|
+
* name: "my-vpn-gateway-bgp",
|
|
62
|
+
* location: "eastus",
|
|
63
|
+
* resourceGroupId: resourceGroup.id,
|
|
64
|
+
* gatewayType: "Vpn",
|
|
65
|
+
* vpnType: "RouteBased",
|
|
66
|
+
* sku: {
|
|
67
|
+
* name: "VpnGw1",
|
|
68
|
+
* tier: "VpnGw1"
|
|
69
|
+
* },
|
|
70
|
+
* enableBgp: true,
|
|
71
|
+
* bgpSettings: {
|
|
72
|
+
* asn: 65515,
|
|
73
|
+
* peerWeight: 0
|
|
74
|
+
* },
|
|
75
|
+
* ipConfigurations: [{
|
|
76
|
+
* name: "default",
|
|
77
|
+
* subnetId: gatewaySubnet.id,
|
|
78
|
+
* publicIPAddressId: publicIp.id
|
|
79
|
+
* }]
|
|
80
|
+
* });
|
|
81
|
+
*
|
|
82
|
+
* @example
|
|
83
|
+
* // Active-Active VPN Gateway:
|
|
84
|
+
* const vpnGateway = new VirtualNetworkGateway(this, "vpnGateway", {
|
|
85
|
+
* name: "my-vpn-gateway-aa",
|
|
86
|
+
* location: "eastus",
|
|
87
|
+
* resourceGroupId: resourceGroup.id,
|
|
88
|
+
* gatewayType: "Vpn",
|
|
89
|
+
* vpnType: "RouteBased",
|
|
90
|
+
* sku: {
|
|
91
|
+
* name: "VpnGw1",
|
|
92
|
+
* tier: "VpnGw1"
|
|
93
|
+
* },
|
|
94
|
+
* activeActive: true,
|
|
95
|
+
* ipConfigurations: [
|
|
96
|
+
* {
|
|
97
|
+
* name: "config1",
|
|
98
|
+
* subnetId: gatewaySubnet.id,
|
|
99
|
+
* publicIPAddressId: publicIp1.id
|
|
100
|
+
* },
|
|
101
|
+
* {
|
|
102
|
+
* name: "config2",
|
|
103
|
+
* subnetId: gatewaySubnet.id,
|
|
104
|
+
* publicIPAddressId: publicIp2.id
|
|
105
|
+
* }
|
|
106
|
+
* ]
|
|
107
|
+
* });
|
|
108
|
+
*
|
|
109
|
+
* @stability stable
|
|
110
|
+
*/
|
|
111
|
+
class VirtualNetworkGateway extends azapi_resource_1.AzapiResource {
|
|
112
|
+
/**
|
|
113
|
+
* Creates a new Azure Virtual Network Gateway using the AzapiResource framework
|
|
114
|
+
*
|
|
115
|
+
* The constructor automatically handles version resolution, schema registration,
|
|
116
|
+
* validation, and resource creation. It maintains full backward compatibility
|
|
117
|
+
* with existing Virtual Network Gateway implementations.
|
|
118
|
+
*
|
|
119
|
+
* @param scope - The scope in which to define this construct
|
|
120
|
+
* @param id - The unique identifier for this instance
|
|
121
|
+
* @param props - Configuration properties for the Virtual Network Gateway
|
|
122
|
+
*/
|
|
123
|
+
constructor(scope, id, props) {
|
|
124
|
+
super(scope, id, props);
|
|
125
|
+
this.props = props;
|
|
126
|
+
// Add extended timeouts for gateway provisioning (30-45 minutes typical)
|
|
127
|
+
this.terraformResource.addOverride("timeouts", {
|
|
128
|
+
create: "60m",
|
|
129
|
+
update: "60m",
|
|
130
|
+
delete: "60m",
|
|
131
|
+
});
|
|
132
|
+
// Create Terraform outputs for easy access and referencing from other resources
|
|
133
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
134
|
+
value: this.id,
|
|
135
|
+
description: "The ID of the Virtual Network Gateway",
|
|
136
|
+
});
|
|
137
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
138
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
139
|
+
description: "The name of the Virtual Network Gateway",
|
|
140
|
+
});
|
|
141
|
+
this.locationOutput = new cdktf.TerraformOutput(this, "location", {
|
|
142
|
+
value: `\${${this.terraformResource.fqn}.location}`,
|
|
143
|
+
description: "The location of the Virtual Network Gateway",
|
|
144
|
+
});
|
|
145
|
+
this.tagsOutput = new cdktf.TerraformOutput(this, "tags", {
|
|
146
|
+
value: `\${${this.terraformResource.fqn}.tags}`,
|
|
147
|
+
description: "The tags assigned to the Virtual Network Gateway",
|
|
148
|
+
});
|
|
149
|
+
// Override logical IDs to match original naming convention
|
|
150
|
+
this.idOutput.overrideLogicalId("id");
|
|
151
|
+
this.nameOutput.overrideLogicalId("name");
|
|
152
|
+
this.locationOutput.overrideLogicalId("location");
|
|
153
|
+
this.tagsOutput.overrideLogicalId("tags");
|
|
154
|
+
// Apply ignore changes if specified
|
|
155
|
+
this._applyIgnoreChanges();
|
|
156
|
+
}
|
|
157
|
+
// =============================================================================
|
|
158
|
+
// REQUIRED ABSTRACT METHODS FROM VersionedAzapiResource
|
|
159
|
+
// =============================================================================
|
|
160
|
+
/**
|
|
161
|
+
* Gets the default API version to use when no explicit version is specified
|
|
162
|
+
* Returns the most recent stable version as the default
|
|
163
|
+
*/
|
|
164
|
+
defaultVersion() {
|
|
165
|
+
return "2024-05-01";
|
|
166
|
+
}
|
|
167
|
+
/**
|
|
168
|
+
* Gets the Azure resource type for Virtual Network Gateways
|
|
169
|
+
*/
|
|
170
|
+
resourceType() {
|
|
171
|
+
return virtual_network_gateway_schemas_1.VIRTUAL_NETWORK_GATEWAY_TYPE;
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* Gets the API schema for the resolved version
|
|
175
|
+
* Uses the framework's schema resolution to get the appropriate schema
|
|
176
|
+
*/
|
|
177
|
+
apiSchema() {
|
|
178
|
+
return this.resolveSchema();
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* Indicates that location is required for Virtual Network Gateways
|
|
182
|
+
*/
|
|
183
|
+
requiresLocation() {
|
|
184
|
+
return true;
|
|
185
|
+
}
|
|
186
|
+
/**
|
|
187
|
+
* Creates the resource body for the Azure API call
|
|
188
|
+
* Transforms the input properties into the JSON format expected by Azure REST API
|
|
189
|
+
*/
|
|
190
|
+
createResourceBody(props) {
|
|
191
|
+
const typedProps = props;
|
|
192
|
+
// Transform IP configurations to Azure API format
|
|
193
|
+
const ipConfigurations = typedProps.ipConfigurations.map((config) => ({
|
|
194
|
+
name: config.name,
|
|
195
|
+
properties: {
|
|
196
|
+
privateIPAllocationMethod: config.privateIPAllocationMethod || "Dynamic",
|
|
197
|
+
subnet: {
|
|
198
|
+
id: config.subnetId,
|
|
199
|
+
},
|
|
200
|
+
publicIPAddress: {
|
|
201
|
+
id: config.publicIPAddressId,
|
|
202
|
+
},
|
|
203
|
+
},
|
|
204
|
+
}));
|
|
205
|
+
return {
|
|
206
|
+
location: this.location,
|
|
207
|
+
tags: this.allTags(),
|
|
208
|
+
properties: {
|
|
209
|
+
gatewayType: typedProps.gatewayType,
|
|
210
|
+
vpnType: typedProps.vpnType || "RouteBased",
|
|
211
|
+
enableBgp: typedProps.enableBgp || false,
|
|
212
|
+
activeActive: typedProps.activeActive || false,
|
|
213
|
+
sku: typedProps.sku,
|
|
214
|
+
ipConfigurations: ipConfigurations,
|
|
215
|
+
bgpSettings: typedProps.bgpSettings,
|
|
216
|
+
vpnGatewayGeneration: typedProps.vpnGatewayGeneration,
|
|
217
|
+
customRoutes: typedProps.customRoutes,
|
|
218
|
+
enablePrivateIpAddress: typedProps.enablePrivateIpAddress,
|
|
219
|
+
gatewayDefaultSite: typedProps.gatewayDefaultSite,
|
|
220
|
+
vpnClientConfiguration: typedProps.vpnClientConfiguration,
|
|
221
|
+
},
|
|
222
|
+
};
|
|
223
|
+
}
|
|
224
|
+
// =============================================================================
|
|
225
|
+
// PUBLIC METHODS FOR VIRTUAL NETWORK GATEWAY OPERATIONS
|
|
226
|
+
// =============================================================================
|
|
227
|
+
/**
|
|
228
|
+
* Get the subscription ID from the Virtual Network Gateway ID
|
|
229
|
+
* Extracts the subscription ID from the Azure resource ID format
|
|
230
|
+
*/
|
|
231
|
+
get subscriptionId() {
|
|
232
|
+
const idParts = this.id.split("/");
|
|
233
|
+
const subscriptionIndex = idParts.indexOf("subscriptions");
|
|
234
|
+
if (subscriptionIndex !== -1 && subscriptionIndex + 1 < idParts.length) {
|
|
235
|
+
return idParts[subscriptionIndex + 1];
|
|
236
|
+
}
|
|
237
|
+
throw new Error("Unable to extract subscription ID from Virtual Network Gateway ID");
|
|
238
|
+
}
|
|
239
|
+
/**
|
|
240
|
+
* Get the full resource identifier for use in other Azure resources
|
|
241
|
+
* Alias for the id property to match original interface
|
|
242
|
+
*/
|
|
243
|
+
get resourceId() {
|
|
244
|
+
return this.id;
|
|
245
|
+
}
|
|
246
|
+
/**
|
|
247
|
+
* Add a tag to the Virtual Network Gateway
|
|
248
|
+
* Note: This modifies the construct props but requires a new deployment to take effect
|
|
249
|
+
*/
|
|
250
|
+
addTag(key, value) {
|
|
251
|
+
if (!this.props.tags) {
|
|
252
|
+
this.props.tags = {};
|
|
253
|
+
}
|
|
254
|
+
this.props.tags[key] = value;
|
|
255
|
+
}
|
|
256
|
+
/**
|
|
257
|
+
* Remove a tag from the Virtual Network Gateway
|
|
258
|
+
* Note: This modifies the construct props but requires a new deployment to take effect
|
|
259
|
+
*/
|
|
260
|
+
removeTag(key) {
|
|
261
|
+
if (this.props.tags && this.props.tags[key]) {
|
|
262
|
+
delete this.props.tags[key];
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
// =============================================================================
|
|
266
|
+
// PRIVATE HELPER METHODS
|
|
267
|
+
// =============================================================================
|
|
268
|
+
/**
|
|
269
|
+
* Applies ignore changes lifecycle rules if specified in props
|
|
270
|
+
*/
|
|
271
|
+
_applyIgnoreChanges() {
|
|
272
|
+
if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {
|
|
273
|
+
this.terraformResource.addOverride("lifecycle", {
|
|
274
|
+
ignore_changes: this.props.ignoreChanges,
|
|
275
|
+
});
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
exports.VirtualNetworkGateway = VirtualNetworkGateway;
|
|
280
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
281
|
+
VirtualNetworkGateway[_a] = { fqn: "@microsoft/terraform-cdk-constructs.VirtualNetworkGateway", version: "1.5.0" };
|
|
282
|
+
(() => {
|
|
283
|
+
azapi_resource_1.AzapiResource.registerSchemas(virtual_network_gateway_schemas_1.VIRTUAL_NETWORK_GATEWAY_TYPE, virtual_network_gateway_schemas_1.ALL_VIRTUAL_NETWORK_GATEWAY_VERSIONS);
|
|
284
|
+
})();
|
|
285
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"virtual-network-gateway.js","sourceRoot":"","sources":["../../../src/azure-virtualnetworkgateway/lib/virtual-network-gateway.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Azure Virtual Network Gateway implementation using AzapiResource framework\n *\n * This class provides a unified implementation for Azure Virtual Network Gateways that\n * automatically handles version management, schema validation, and property\n * transformation across all supported API versions.\n *\n * Supported API Versions:\n * - 2024-01-01 (Active)\n * - 2024-05-01 (Active, Latest)\n *\n * Features:\n * - Automatic latest version resolution when no version is specified\n * - Explicit version pinning for stability requirements\n * - Schema-driven validation and transformation\n * - Full backward compatibility\n * - JSII compliance for multi-language support\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_VIRTUAL_NETWORK_GATEWAY_VERSIONS,\n  VIRTUAL_NETWORK_GATEWAY_TYPE,\n} from \"./virtual-network-gateway-schemas\";\nimport {\n  AzapiResource,\n  AzapiResourceProps,\n} from \"../../core-azure/lib/azapi/azapi-resource\";\nimport { ApiSchema } from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n/**\n * SKU configuration for Virtual Network Gateway\n */\nexport interface VirtualNetworkGatewaySku {\n  /**\n   * Name of the SKU\n   * @example \"Basic\", \"VpnGw1\", \"VpnGw2\", \"VpnGw3\", \"VpnGw4\", \"VpnGw5\", \"ErGw1AZ\", \"ErGw2AZ\", \"ErGw3AZ\"\n   */\n  readonly name: string;\n\n  /**\n   * Tier of the SKU\n   * @example \"Basic\", \"VpnGw1\", \"VpnGw2\", \"VpnGw3\", \"VpnGw4\", \"VpnGw5\", \"ErGw1AZ\", \"ErGw2AZ\", \"ErGw3AZ\"\n   */\n  readonly tier: string;\n}\n\n/**\n * IP configuration for Virtual Network Gateway\n */\nexport interface VirtualNetworkGatewayIpConfiguration {\n  /**\n   * Name of the IP configuration\n   */\n  readonly name: string;\n\n  /**\n   * Private IP allocation method\n   * @defaultValue \"Dynamic\"\n   */\n  readonly privateIPAllocationMethod?: string;\n\n  /**\n   * ID of the subnet to use (must be GatewaySubnet)\n   */\n  readonly subnetId: string;\n\n  /**\n   * ID of the public IP address to use\n   */\n  readonly publicIPAddressId: string;\n}\n\n/**\n * BGP settings for Virtual Network Gateway\n */\nexport interface VirtualNetworkGatewayBgpSettings {\n  /**\n   * BGP ASN (Autonomous System Number)\n   * @example 65515\n   */\n  readonly asn?: number;\n\n  /**\n   * BGP peering address\n   */\n  readonly bgpPeeringAddress?: string;\n\n  /**\n   * Weight added to routes learned from this BGP speaker\n   */\n  readonly peerWeight?: number;\n\n  /**\n   * BGP peering addresses for active-active configuration\n   */\n  readonly bgpPeeringAddresses?: any[];\n}\n\n/**\n * VPN client address pool configuration\n */\nexport interface VirtualNetworkGatewayVpnClientAddressPool {\n  /**\n   * List of address prefixes for VPN client connections\n   */\n  readonly addressPrefixes: string[];\n}\n\n/**\n * VPN client configuration for point-to-site connections\n */\nexport interface VirtualNetworkGatewayVpnClientConfiguration {\n  /**\n   * VPN client address pool\n   */\n  readonly vpnClientAddressPool?: VirtualNetworkGatewayVpnClientAddressPool;\n\n  /**\n   * VPN client protocols\n   * @example [\"IkeV2\", \"SSTP\", \"OpenVPN\"]\n   */\n  readonly vpnClientProtocols?: string[];\n\n  /**\n   * VPN client root certificates\n   */\n  readonly vpnClientRootCertificates?: any[];\n\n  /**\n   * VPN client revoked certificates\n   */\n  readonly vpnClientRevokedCertificates?: any[];\n\n  /**\n   * Radius server address\n   */\n  readonly radiusServerAddress?: string;\n\n  /**\n   * Radius server secret\n   */\n  readonly radiusServerSecret?: string;\n}\n\n/**\n * Custom routes configuration\n */\nexport interface VirtualNetworkGatewayCustomRoutes {\n  /**\n   * List of address prefixes\n   */\n  readonly addressPrefixes?: string[];\n}\n\n/**\n * Gateway default site reference\n */\nexport interface VirtualNetworkGatewayDefaultSite {\n  /**\n   * Resource ID of the local network gateway to use as default site\n   */\n  readonly id: string;\n}\n\n/**\n * Properties for the Azure Virtual Network Gateway\n *\n * Extends AzapiResourceProps with Virtual Network Gateway specific properties\n */\nexport interface VirtualNetworkGatewayProps extends AzapiResourceProps {\n  /**\n   * Gateway type\n   * Must be either \"Vpn\" or \"ExpressRoute\"\n   */\n  readonly gatewayType: \"Vpn\" | \"ExpressRoute\";\n\n  /**\n   * VPN type for VPN gateways\n   * @defaultValue \"RouteBased\"\n   */\n  readonly vpnType?: \"RouteBased\" | \"PolicyBased\";\n\n  /**\n   * SKU configuration for the gateway\n   */\n  readonly sku: VirtualNetworkGatewaySku;\n\n  /**\n   * IP configurations for the gateway\n   * At least one IP configuration is required\n   * Two IP configurations are required for active-active mode\n   */\n  readonly ipConfigurations: VirtualNetworkGatewayIpConfiguration[];\n\n  /**\n   * Enable BGP for the gateway\n   * @defaultValue false\n   */\n  readonly enableBgp?: boolean;\n\n  /**\n   * Enable active-active mode for the gateway\n   * Requires two IP configurations\n   * @defaultValue false\n   */\n  readonly activeActive?: boolean;\n\n  /**\n   * BGP settings for the gateway\n   * Required if enableBgp is true\n   */\n  readonly bgpSettings?: VirtualNetworkGatewayBgpSettings;\n\n  /**\n   * VPN gateway generation\n   * @example \"Generation1\", \"Generation2\"\n   */\n  readonly vpnGatewayGeneration?: string;\n\n  /**\n   * Custom routes for the gateway\n   */\n  readonly customRoutes?: VirtualNetworkGatewayCustomRoutes;\n\n  /**\n   * Enable private IP address for the gateway\n   * @defaultValue false\n   */\n  readonly enablePrivateIpAddress?: boolean;\n\n  /**\n   * Default site for force tunneling\n   */\n  readonly gatewayDefaultSite?: VirtualNetworkGatewayDefaultSite;\n\n  /**\n   * VPN client configuration for point-to-site connections\n   */\n  readonly vpnClientConfiguration?: VirtualNetworkGatewayVpnClientConfiguration;\n\n  /**\n   * Resource group ID where the Gateway will be created\n   * Optional - will use the subscription scope if not provided\n   */\n  readonly resourceGroupId?: string;\n\n  /**\n   * The lifecycle rules to ignore changes\n   * Useful for properties that are externally managed\n   *\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Azure Virtual Network Gateway implementation\n *\n * This class provides a single, version-aware implementation that replaces\n * version-specific Virtual Network Gateway classes. It automatically handles version\n * resolution, schema validation, and property transformation while maintaining\n * full backward compatibility.\n *\n * Virtual Network Gateways are used to send encrypted traffic between Azure virtual\n * networks and on-premises locations over the public Internet (VPN) or through\n * Azure ExpressRoute circuits (ExpressRoute).\n *\n * @example\n * // Basic VPN Gateway:\n * const vpnGateway = new VirtualNetworkGateway(this, \"vpnGateway\", {\n *   name: \"my-vpn-gateway\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   gatewayType: \"Vpn\",\n *   vpnType: \"RouteBased\",\n *   sku: {\n *     name: \"VpnGw1\",\n *     tier: \"VpnGw1\"\n *   },\n *   ipConfigurations: [{\n *     name: \"default\",\n *     subnetId: gatewaySubnet.id,\n *     publicIPAddressId: publicIp.id\n *   }]\n * });\n *\n * @example\n * // VPN Gateway with BGP:\n * const vpnGateway = new VirtualNetworkGateway(this, \"vpnGateway\", {\n *   name: \"my-vpn-gateway-bgp\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   gatewayType: \"Vpn\",\n *   vpnType: \"RouteBased\",\n *   sku: {\n *     name: \"VpnGw1\",\n *     tier: \"VpnGw1\"\n *   },\n *   enableBgp: true,\n *   bgpSettings: {\n *     asn: 65515,\n *     peerWeight: 0\n *   },\n *   ipConfigurations: [{\n *     name: \"default\",\n *     subnetId: gatewaySubnet.id,\n *     publicIPAddressId: publicIp.id\n *   }]\n * });\n *\n * @example\n * // Active-Active VPN Gateway:\n * const vpnGateway = new VirtualNetworkGateway(this, \"vpnGateway\", {\n *   name: \"my-vpn-gateway-aa\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   gatewayType: \"Vpn\",\n *   vpnType: \"RouteBased\",\n *   sku: {\n *     name: \"VpnGw1\",\n *     tier: \"VpnGw1\"\n *   },\n *   activeActive: true,\n *   ipConfigurations: [\n *     {\n *       name: \"config1\",\n *       subnetId: gatewaySubnet.id,\n *       publicIPAddressId: publicIp1.id\n *     },\n *     {\n *       name: \"config2\",\n *       subnetId: gatewaySubnet.id,\n *       publicIPAddressId: publicIp2.id\n *     }\n *   ]\n * });\n *\n * @stability stable\n */\nexport class VirtualNetworkGateway extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      VIRTUAL_NETWORK_GATEWAY_TYPE,\n      ALL_VIRTUAL_NETWORK_GATEWAY_VERSIONS,\n    );\n  }\n\n  /**\n   * The input properties for this Virtual Network Gateway instance\n   */\n  public readonly props: VirtualNetworkGatewayProps;\n\n  // Output properties for easy access and referencing\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly locationOutput: cdktf.TerraformOutput;\n  public readonly tagsOutput: cdktf.TerraformOutput;\n\n  /**\n   * Creates a new Azure Virtual Network Gateway using the AzapiResource framework\n   *\n   * The constructor automatically handles version resolution, schema registration,\n   * validation, and resource creation. It maintains full backward compatibility\n   * with existing Virtual Network Gateway implementations.\n   *\n   * @param scope - The scope in which to define this construct\n   * @param id - The unique identifier for this instance\n   * @param props - Configuration properties for the Virtual Network Gateway\n   */\n  constructor(scope: Construct, id: string, props: VirtualNetworkGatewayProps) {\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Add extended timeouts for gateway provisioning (30-45 minutes typical)\n    this.terraformResource.addOverride(\"timeouts\", {\n      create: \"60m\",\n      update: \"60m\",\n      delete: \"60m\",\n    });\n\n    // Create Terraform outputs for easy access and referencing from other resources\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the Virtual Network Gateway\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the Virtual Network Gateway\",\n    });\n\n    this.locationOutput = new cdktf.TerraformOutput(this, \"location\", {\n      value: `\\${${this.terraformResource.fqn}.location}`,\n      description: \"The location of the Virtual Network Gateway\",\n    });\n\n    this.tagsOutput = new cdktf.TerraformOutput(this, \"tags\", {\n      value: `\\${${this.terraformResource.fqn}.tags}`,\n      description: \"The tags assigned to the Virtual Network Gateway\",\n    });\n\n    // Override logical IDs to match original naming convention\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.locationOutput.overrideLogicalId(\"location\");\n    this.tagsOutput.overrideLogicalId(\"tags\");\n\n    // Apply ignore changes if specified\n    this._applyIgnoreChanges();\n  }\n\n  // =============================================================================\n  // REQUIRED ABSTRACT METHODS FROM VersionedAzapiResource\n  // =============================================================================\n\n  /**\n   * Gets the default API version to use when no explicit version is specified\n   * Returns the most recent stable version as the default\n   */\n  protected defaultVersion(): string {\n    return \"2024-05-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for Virtual Network Gateways\n   */\n  protected resourceType(): string {\n    return VIRTUAL_NETWORK_GATEWAY_TYPE;\n  }\n\n  /**\n   * Gets the API schema for the resolved version\n   * Uses the framework's schema resolution to get the appropriate schema\n   */\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  /**\n   * Indicates that location is required for Virtual Network Gateways\n   */\n  protected requiresLocation(): boolean {\n    return true;\n  }\n\n  /**\n   * Creates the resource body for the Azure API call\n   * Transforms the input properties into the JSON format expected by Azure REST API\n   */\n  protected createResourceBody(props: any): any {\n    const typedProps = props as VirtualNetworkGatewayProps;\n\n    // Transform IP configurations to Azure API format\n    const ipConfigurations = typedProps.ipConfigurations.map((config) => ({\n      name: config.name,\n      properties: {\n        privateIPAllocationMethod:\n          config.privateIPAllocationMethod || \"Dynamic\",\n        subnet: {\n          id: config.subnetId,\n        },\n        publicIPAddress: {\n          id: config.publicIPAddressId,\n        },\n      },\n    }));\n\n    return {\n      location: this.location,\n      tags: this.allTags(),\n      properties: {\n        gatewayType: typedProps.gatewayType,\n        vpnType: typedProps.vpnType || \"RouteBased\",\n        enableBgp: typedProps.enableBgp || false,\n        activeActive: typedProps.activeActive || false,\n        sku: typedProps.sku,\n        ipConfigurations: ipConfigurations,\n        bgpSettings: typedProps.bgpSettings,\n        vpnGatewayGeneration: typedProps.vpnGatewayGeneration,\n        customRoutes: typedProps.customRoutes,\n        enablePrivateIpAddress: typedProps.enablePrivateIpAddress,\n        gatewayDefaultSite: typedProps.gatewayDefaultSite,\n        vpnClientConfiguration: typedProps.vpnClientConfiguration,\n      },\n    };\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR VIRTUAL NETWORK GATEWAY OPERATIONS\n  // =============================================================================\n\n  /**\n   * Get the subscription ID from the Virtual Network Gateway ID\n   * Extracts the subscription ID from the Azure resource ID format\n   */\n  public get subscriptionId(): string {\n    const idParts = this.id.split(\"/\");\n    const subscriptionIndex = idParts.indexOf(\"subscriptions\");\n    if (subscriptionIndex !== -1 && subscriptionIndex + 1 < idParts.length) {\n      return idParts[subscriptionIndex + 1];\n    }\n    throw new Error(\n      \"Unable to extract subscription ID from Virtual Network Gateway ID\",\n    );\n  }\n\n  /**\n   * Get the full resource identifier for use in other Azure resources\n   * Alias for the id property to match original interface\n   */\n  public get resourceId(): string {\n    return this.id;\n  }\n\n  /**\n   * Add a tag to the Virtual Network Gateway\n   * Note: This modifies the construct props but requires a new deployment to take effect\n   */\n  public addTag(key: string, value: string): void {\n    if (!this.props.tags) {\n      (this.props as any).tags = {};\n    }\n    this.props.tags![key] = value;\n  }\n\n  /**\n   * Remove a tag from the Virtual Network Gateway\n   * Note: This modifies the construct props but requires a new deployment to take effect\n   */\n  public removeTag(key: string): void {\n    if (this.props.tags && this.props.tags[key]) {\n      delete this.props.tags[key];\n    }\n  }\n\n  // =============================================================================\n  // PRIVATE HELPER METHODS\n  // =============================================================================\n\n  /**\n   * Applies ignore changes lifecycle rules if specified in props\n   */\n  private _applyIgnoreChanges(): void {\n    if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {\n      this.terraformResource.addOverride(\"lifecycle\", {\n        ignore_changes: this.props.ignoreChanges,\n      });\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Integration test for Azure Virtual Network Gateway
|
|
3
|
+
*
|
|
4
|
+
* This test demonstrates basic usage of the VirtualNetworkGateway construct
|
|
5
|
+
* and validates deployment, idempotency, and cleanup.
|
|
6
|
+
*
|
|
7
|
+
* Note: Virtual Network Gateways take 20-45 minutes to deploy, so this test
|
|
8
|
+
* has an extended timeout.
|
|
9
|
+
*
|
|
10
|
+
* Run with: npm run integration:nostream
|
|
11
|
+
*/
|
|
12
|
+
import "cdktf/lib/testing/adapters/jest";
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Integration test for Azure Virtual Network Gateway
|
|
4
|
+
*
|
|
5
|
+
* This test demonstrates basic usage of the VirtualNetworkGateway construct
|
|
6
|
+
* and validates deployment, idempotency, and cleanup.
|
|
7
|
+
*
|
|
8
|
+
* Note: Virtual Network Gateways take 20-45 minutes to deploy, so this test
|
|
9
|
+
* has an extended timeout.
|
|
10
|
+
*
|
|
11
|
+
* Run with: npm run integration:nostream
|
|
12
|
+
*/
|
|
13
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
+
const cdktf_1 = require("cdktf");
|
|
15
|
+
require("cdktf/lib/testing/adapters/jest");
|
|
16
|
+
const azure_publicipaddress_1 = require("../../azure-publicipaddress");
|
|
17
|
+
const azure_resourcegroup_1 = require("../../azure-resourcegroup");
|
|
18
|
+
const azure_subnet_1 = require("../../azure-subnet");
|
|
19
|
+
const azure_virtualnetwork_1 = require("../../azure-virtualnetwork");
|
|
20
|
+
const provider_1 = require("../../core-azure/lib/azapi/providers-azapi/provider");
|
|
21
|
+
const testing_1 = require("../../testing");
|
|
22
|
+
const metadata_1 = require("../../testing/lib/metadata");
|
|
23
|
+
const virtual_network_gateway_1 = require("../lib/virtual-network-gateway");
|
|
24
|
+
// Generate unique test run metadata for this test suite
|
|
25
|
+
const testMetadata = new metadata_1.TestRunMetadata("virtual-network-gateway-integration", {
|
|
26
|
+
maxAgeHours: 4,
|
|
27
|
+
});
|
|
28
|
+
/**
|
|
29
|
+
* Example stack demonstrating Virtual Network Gateway usage
|
|
30
|
+
*/
|
|
31
|
+
class VirtualNetworkGatewayExampleStack extends testing_1.BaseTestStack {
|
|
32
|
+
constructor(scope, id) {
|
|
33
|
+
super(scope, id, {
|
|
34
|
+
testRunOptions: {
|
|
35
|
+
maxAgeHours: testMetadata.maxAgeHours,
|
|
36
|
+
autoCleanup: testMetadata.autoCleanup,
|
|
37
|
+
cleanupPolicy: testMetadata.cleanupPolicy,
|
|
38
|
+
},
|
|
39
|
+
});
|
|
40
|
+
// Configure AZAPI provider
|
|
41
|
+
new provider_1.AzapiProvider(this, "azapi", {});
|
|
42
|
+
// Generate unique names
|
|
43
|
+
const rgName = this.generateResourceName("Microsoft.Resources/resourceGroups", "vng");
|
|
44
|
+
// Create resource group
|
|
45
|
+
const resourceGroup = new azure_resourcegroup_1.ResourceGroup(this, "rg", {
|
|
46
|
+
name: rgName,
|
|
47
|
+
location: "eastus",
|
|
48
|
+
tags: {
|
|
49
|
+
...this.systemTags(),
|
|
50
|
+
},
|
|
51
|
+
});
|
|
52
|
+
// Create virtual network
|
|
53
|
+
const vnet = new azure_virtualnetwork_1.VirtualNetwork(this, "vnet", {
|
|
54
|
+
name: "vnet-gateway-example",
|
|
55
|
+
location: "eastus",
|
|
56
|
+
resourceGroupId: resourceGroup.id,
|
|
57
|
+
addressSpace: {
|
|
58
|
+
addressPrefixes: ["10.0.0.0/16"],
|
|
59
|
+
},
|
|
60
|
+
tags: {
|
|
61
|
+
...this.systemTags(),
|
|
62
|
+
},
|
|
63
|
+
});
|
|
64
|
+
// Create GatewaySubnet (required for VPN Gateway)
|
|
65
|
+
const gatewaySubnet = new azure_subnet_1.Subnet(this, "gateway-subnet", {
|
|
66
|
+
name: "GatewaySubnet", // Must be named "GatewaySubnet"
|
|
67
|
+
virtualNetworkName: "vnet-gateway-example",
|
|
68
|
+
virtualNetworkId: vnet.id,
|
|
69
|
+
resourceGroupId: resourceGroup.id,
|
|
70
|
+
addressPrefix: "10.0.1.0/24",
|
|
71
|
+
});
|
|
72
|
+
// Create public IP for the gateway
|
|
73
|
+
const publicIp = new azure_publicipaddress_1.PublicIPAddress(this, "public-ip", {
|
|
74
|
+
name: "pip-gateway-example",
|
|
75
|
+
location: "eastus",
|
|
76
|
+
resourceGroupId: resourceGroup.id,
|
|
77
|
+
sku: {
|
|
78
|
+
name: "Standard",
|
|
79
|
+
tier: "Regional",
|
|
80
|
+
},
|
|
81
|
+
publicIPAllocationMethod: "Static",
|
|
82
|
+
tags: {
|
|
83
|
+
...this.systemTags(),
|
|
84
|
+
},
|
|
85
|
+
});
|
|
86
|
+
// Example: Basic VPN Gateway
|
|
87
|
+
new virtual_network_gateway_1.VirtualNetworkGateway(this, "vpn-gateway", {
|
|
88
|
+
name: "vng-basic-example",
|
|
89
|
+
location: "eastus",
|
|
90
|
+
resourceGroupId: resourceGroup.id,
|
|
91
|
+
gatewayType: "Vpn",
|
|
92
|
+
vpnType: "RouteBased",
|
|
93
|
+
sku: {
|
|
94
|
+
name: "VpnGw1",
|
|
95
|
+
tier: "VpnGw1",
|
|
96
|
+
},
|
|
97
|
+
ipConfigurations: [
|
|
98
|
+
{
|
|
99
|
+
name: "default",
|
|
100
|
+
subnetId: gatewaySubnet.id,
|
|
101
|
+
publicIPAddressId: publicIp.id,
|
|
102
|
+
},
|
|
103
|
+
],
|
|
104
|
+
tags: {
|
|
105
|
+
...this.systemTags(),
|
|
106
|
+
example: "basic-vpn",
|
|
107
|
+
},
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
describe("Virtual Network Gateway Integration Test", () => {
|
|
112
|
+
// NOTE: Test is skipped due to 30-45 minute gateway provisioning time.
|
|
113
|
+
// This test has been validated and confirms the gateway deploys successfully.
|
|
114
|
+
// Run manually when needed: npx jest src/azure-virtualnetworkgateway/test/virtual-network-gateway.integ.ts
|
|
115
|
+
//
|
|
116
|
+
// Known issue: Cleanup may fail due to Terraform dependency ordering with the gateway resource.
|
|
117
|
+
// Manual cleanup may be required via Azure Portal if destroy fails.
|
|
118
|
+
it.skip("should deploy, validate idempotency, and cleanup virtual network gateway resources", () => {
|
|
119
|
+
const app = cdktf_1.Testing.app();
|
|
120
|
+
const stack = new VirtualNetworkGatewayExampleStack(app, "test-virtual-network-gateway");
|
|
121
|
+
const synthesized = cdktf_1.Testing.fullSynth(stack);
|
|
122
|
+
// This will:
|
|
123
|
+
// 1. Run terraform apply to deploy resources
|
|
124
|
+
// 2. Run terraform plan to check idempotency (no changes expected)
|
|
125
|
+
// 3. Run terraform destroy to cleanup resources
|
|
126
|
+
(0, testing_1.TerraformApplyCheckAndDestroy)(synthesized, { verifyCleanup: true });
|
|
127
|
+
}, 4500000); // Increased from 3600000 (60 min) to 4500000 (75 min) for gateway provisioning
|
|
128
|
+
});
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"virtual-network-gateway.integ.js","sourceRoot":"","sources":["../../../src/azure-virtualnetworkgateway/test/virtual-network-gateway.integ.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Integration test for Azure Virtual Network Gateway\n *\n * This test demonstrates basic usage of the VirtualNetworkGateway construct\n * and validates deployment, idempotency, and cleanup.\n *\n * Note: Virtual Network Gateways take 20-45 minutes to deploy, so this test\n * has an extended timeout.\n *\n * Run with: npm run integration:nostream\n */\n\nimport { Testing } from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport \"cdktf/lib/testing/adapters/jest\";\nimport { PublicIPAddress } from \"../../azure-publicipaddress\";\nimport { ResourceGroup } from \"../../azure-resourcegroup\";\nimport { Subnet } from \"../../azure-subnet\";\nimport { VirtualNetwork } from \"../../azure-virtualnetwork\";\nimport { AzapiProvider } from \"../../core-azure/lib/azapi/providers-azapi/provider\";\nimport { BaseTestStack, TerraformApplyCheckAndDestroy } from \"../../testing\";\nimport { TestRunMetadata } from \"../../testing/lib/metadata\";\nimport { VirtualNetworkGateway } from \"../lib/virtual-network-gateway\";\n\n// Generate unique test run metadata for this test suite\nconst testMetadata = new TestRunMetadata(\n  \"virtual-network-gateway-integration\",\n  {\n    maxAgeHours: 4,\n  },\n);\n\n/**\n * Example stack demonstrating Virtual Network Gateway usage\n */\nclass VirtualNetworkGatewayExampleStack extends BaseTestStack {\n  constructor(scope: Construct, id: string) {\n    super(scope, id, {\n      testRunOptions: {\n        maxAgeHours: testMetadata.maxAgeHours,\n        autoCleanup: testMetadata.autoCleanup,\n        cleanupPolicy: testMetadata.cleanupPolicy,\n      },\n    });\n\n    // Configure AZAPI provider\n    new AzapiProvider(this, \"azapi\", {});\n\n    // Generate unique names\n    const rgName = this.generateResourceName(\n      \"Microsoft.Resources/resourceGroups\",\n      \"vng\",\n    );\n\n    // Create resource group\n    const resourceGroup = new ResourceGroup(this, \"rg\", {\n      name: rgName,\n      location: \"eastus\",\n      tags: {\n        ...this.systemTags(),\n      },\n    });\n\n    // Create virtual network\n    const vnet = new VirtualNetwork(this, \"vnet\", {\n      name: \"vnet-gateway-example\",\n      location: \"eastus\",\n      resourceGroupId: resourceGroup.id,\n      addressSpace: {\n        addressPrefixes: [\"10.0.0.0/16\"],\n      },\n      tags: {\n        ...this.systemTags(),\n      },\n    });\n\n    // Create GatewaySubnet (required for VPN Gateway)\n    const gatewaySubnet = new Subnet(this, \"gateway-subnet\", {\n      name: \"GatewaySubnet\", // Must be named \"GatewaySubnet\"\n      virtualNetworkName: \"vnet-gateway-example\",\n      virtualNetworkId: vnet.id,\n      resourceGroupId: resourceGroup.id,\n      addressPrefix: \"10.0.1.0/24\",\n    });\n\n    // Create public IP for the gateway\n    const publicIp = new PublicIPAddress(this, \"public-ip\", {\n      name: \"pip-gateway-example\",\n      location: \"eastus\",\n      resourceGroupId: resourceGroup.id,\n      sku: {\n        name: \"Standard\",\n        tier: \"Regional\",\n      },\n      publicIPAllocationMethod: \"Static\",\n      tags: {\n        ...this.systemTags(),\n      },\n    });\n\n    // Example: Basic VPN Gateway\n    new VirtualNetworkGateway(this, \"vpn-gateway\", {\n      name: \"vng-basic-example\",\n      location: \"eastus\",\n      resourceGroupId: resourceGroup.id,\n      gatewayType: \"Vpn\",\n      vpnType: \"RouteBased\",\n      sku: {\n        name: \"VpnGw1\",\n        tier: \"VpnGw1\",\n      },\n      ipConfigurations: [\n        {\n          name: \"default\",\n          subnetId: gatewaySubnet.id,\n          publicIPAddressId: publicIp.id,\n        },\n      ],\n      tags: {\n        ...this.systemTags(),\n        example: \"basic-vpn\",\n      },\n    });\n  }\n}\n\ndescribe(\"Virtual Network Gateway Integration Test\", () => {\n  // NOTE: Test is skipped due to 30-45 minute gateway provisioning time.\n  // This test has been validated and confirms the gateway deploys successfully.\n  // Run manually when needed: npx jest src/azure-virtualnetworkgateway/test/virtual-network-gateway.integ.ts\n  //\n  // Known issue: Cleanup may fail due to Terraform dependency ordering with the gateway resource.\n  // Manual cleanup may be required via Azure Portal if destroy fails.\n  it.skip(\"should deploy, validate idempotency, and cleanup virtual network gateway resources\", () => {\n    const app = Testing.app();\n    const stack = new VirtualNetworkGatewayExampleStack(\n      app,\n      \"test-virtual-network-gateway\",\n    );\n    const synthesized = Testing.fullSynth(stack);\n\n    // This will:\n    // 1. Run terraform apply to deploy resources\n    // 2. Run terraform plan to check idempotency (no changes expected)\n    // 3. Run terraform destroy to cleanup resources\n    TerraformApplyCheckAndDestroy(synthesized, { verifyCleanup: true });\n  }, 4500000); // Increased from 3600000 (60 min) to 4500000 (75 min) for gateway provisioning\n});\n"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Comprehensive tests for the Virtual Network Gateway implementation
|
|
3
|
+
*
|
|
4
|
+
* This test suite validates the VirtualNetworkGateway class using the AzapiResource framework.
|
|
5
|
+
* Tests cover automatic version resolution, explicit version pinning, schema validation,
|
|
6
|
+
* property transformation, and resource creation.
|
|
7
|
+
*/
|
|
8
|
+
export {};
|