@microsoft/terraform-cdk-constructs 1.2.0 → 1.3.1
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 +54630 -26185
- package/API.md +72091 -23784
- package/lib/azure-actiongroup/index.d.ts +0 -10
- package/lib/azure-actiongroup/index.js +1 -11
- package/lib/azure-actiongroup/lib/action-group.d.ts +0 -10
- package/lib/azure-actiongroup/lib/action-group.js +6 -32
- package/lib/azure-actiongroup/lib/index.d.ts +1 -4
- package/lib/azure-actiongroup/lib/index.js +2 -5
- package/lib/azure-activitylogalert/index.d.ts +0 -10
- package/lib/azure-activitylogalert/index.js +1 -11
- package/lib/azure-activitylogalert/lib/activity-log-alert.d.ts +0 -10
- package/lib/azure-activitylogalert/lib/activity-log-alert.js +6 -32
- package/lib/azure-activitylogalert/lib/index.d.ts +1 -4
- package/lib/azure-activitylogalert/lib/index.js +2 -5
- package/lib/azure-aks/index.d.ts +0 -8
- package/lib/azure-aks/index.js +1 -11
- package/lib/azure-aks/lib/aks-cluster.d.ts +4 -13
- package/lib/azure-aks/lib/aks-cluster.js +13 -36
- package/lib/azure-aks/lib/index.d.ts +1 -10
- package/lib/azure-aks/lib/index.js +2 -21
- package/lib/azure-diagnosticsettings/index.d.ts +0 -6
- package/lib/azure-diagnosticsettings/index.js +1 -7
- package/lib/azure-diagnosticsettings/lib/diagnostic-settings.d.ts +0 -10
- package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +6 -32
- package/lib/azure-diagnosticsettings/lib/index.d.ts +1 -7
- package/lib/azure-diagnosticsettings/lib/index.js +2 -8
- package/lib/azure-dnsforwardingruleset/index.d.ts +1 -0
- package/lib/azure-dnsforwardingruleset/index.js +18 -0
- package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset-schemas.d.ts +24 -0
- package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset-schemas.js +206 -0
- package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.d.ts +174 -0
- package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +214 -0
- package/lib/azure-dnsforwardingruleset/lib/forwarding-rule-schemas.d.ts +24 -0
- package/lib/azure-dnsforwardingruleset/lib/forwarding-rule-schemas.js +242 -0
- package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.d.ts +193 -0
- package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +193 -0
- package/lib/azure-dnsforwardingruleset/lib/index.d.ts +6 -0
- package/lib/azure-dnsforwardingruleset/lib/index.js +23 -0
- package/lib/azure-dnsforwardingruleset/lib/virtual-network-link-schemas.d.ts +24 -0
- package/lib/azure-dnsforwardingruleset/lib/virtual-network-link-schemas.js +199 -0
- package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.d.ts +160 -0
- package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +178 -0
- package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.integ.d.ts +9 -0
- package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.integ.js +133 -0
- package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.spec.d.ts +9 -0
- package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.spec.js +350 -0
- package/lib/azure-dnsforwardingruleset/test/forwarding-rule.spec.d.ts +9 -0
- package/lib/azure-dnsforwardingruleset/test/forwarding-rule.spec.js +397 -0
- package/lib/azure-dnsforwardingruleset/test/virtual-network-link.spec.d.ts +9 -0
- package/lib/azure-dnsforwardingruleset/test/virtual-network-link.spec.js +285 -0
- package/lib/azure-dnsresolver/index.d.ts +1 -0
- package/lib/azure-dnsresolver/index.js +18 -0
- package/lib/azure-dnsresolver/lib/dns-resolver-schemas.d.ts +24 -0
- package/lib/azure-dnsresolver/lib/dns-resolver-schemas.js +218 -0
- package/lib/azure-dnsresolver/lib/dns-resolver.d.ts +170 -0
- package/lib/azure-dnsresolver/lib/dns-resolver.js +236 -0
- package/lib/azure-dnsresolver/lib/inbound-endpoint-schemas.d.ts +24 -0
- package/lib/azure-dnsresolver/lib/inbound-endpoint-schemas.js +261 -0
- package/lib/azure-dnsresolver/lib/inbound-endpoint.d.ts +189 -0
- package/lib/azure-dnsresolver/lib/inbound-endpoint.js +243 -0
- package/lib/azure-dnsresolver/lib/index.d.ts +6 -0
- package/lib/azure-dnsresolver/lib/index.js +23 -0
- package/lib/azure-dnsresolver/lib/outbound-endpoint-schemas.d.ts +24 -0
- package/lib/azure-dnsresolver/lib/outbound-endpoint-schemas.js +231 -0
- package/lib/azure-dnsresolver/lib/outbound-endpoint.d.ts +175 -0
- package/lib/azure-dnsresolver/lib/outbound-endpoint.js +234 -0
- package/lib/azure-dnsresolver/test/dns-resolver.integ.d.ts +14 -0
- package/lib/azure-dnsresolver/test/dns-resolver.integ.js +117 -0
- package/lib/azure-dnsresolver/test/dns-resolver.spec.d.ts +9 -0
- package/lib/azure-dnsresolver/test/dns-resolver.spec.js +353 -0
- package/lib/azure-dnsresolver/test/inbound-endpoint.integ.d.ts +9 -0
- package/lib/azure-dnsresolver/test/inbound-endpoint.integ.js +151 -0
- package/lib/azure-dnsresolver/test/inbound-endpoint.spec.d.ts +9 -0
- package/lib/azure-dnsresolver/test/inbound-endpoint.spec.js +441 -0
- package/lib/azure-dnsresolver/test/outbound-endpoint.integ.d.ts +9 -0
- package/lib/azure-dnsresolver/test/outbound-endpoint.integ.js +149 -0
- package/lib/azure-dnsresolver/test/outbound-endpoint.spec.d.ts +9 -0
- package/lib/azure-dnsresolver/test/outbound-endpoint.spec.js +301 -0
- package/lib/azure-dnszone/index.d.ts +1 -0
- package/lib/azure-dnszone/index.js +18 -0
- package/lib/azure-dnszone/lib/dns-zone-schemas.d.ts +24 -0
- package/lib/azure-dnszone/lib/dns-zone-schemas.js +191 -0
- package/lib/azure-dnszone/lib/dns-zone.d.ts +182 -0
- package/lib/azure-dnszone/lib/dns-zone.js +228 -0
- package/lib/azure-dnszone/lib/index.d.ts +2 -0
- package/lib/azure-dnszone/lib/index.js +19 -0
- package/lib/azure-dnszone/test/dns-zone.integ.d.ts +9 -0
- package/lib/azure-dnszone/test/dns-zone.integ.js +85 -0
- package/lib/azure-dnszone/test/dns-zone.spec.d.ts +9 -0
- package/lib/azure-dnszone/test/dns-zone.spec.js +285 -0
- package/lib/azure-metricalert/index.d.ts +0 -10
- package/lib/azure-metricalert/index.js +1 -11
- package/lib/azure-metricalert/lib/index.d.ts +1 -4
- package/lib/azure-metricalert/lib/index.js +2 -5
- package/lib/azure-metricalert/lib/metric-alert.d.ts +0 -10
- package/lib/azure-metricalert/lib/metric-alert.js +6 -32
- package/lib/azure-networkinterface/index.d.ts +0 -3
- package/lib/azure-networkinterface/index.js +1 -4
- package/lib/azure-networkinterface/lib/index.d.ts +1 -5
- package/lib/azure-networkinterface/lib/index.js +2 -5
- package/lib/azure-networkinterface/lib/network-interface.d.ts +4 -9
- package/lib/azure-networkinterface/lib/network-interface.js +14 -29
- package/lib/azure-networkinterface/test/network-interface.integ.js +20 -6
- package/lib/azure-networksecuritygroup/index.d.ts +0 -5
- package/lib/azure-networksecuritygroup/index.js +1 -6
- package/lib/azure-networksecuritygroup/lib/index.d.ts +2 -5
- package/lib/azure-networksecuritygroup/lib/index.js +17 -14
- package/lib/azure-networksecuritygroup/lib/network-security-group.d.ts +4 -13
- package/lib/azure-networksecuritygroup/lib/network-security-group.js +14 -36
- package/lib/azure-policyassignment/index.d.ts +1 -0
- package/lib/azure-policyassignment/index.js +18 -0
- package/lib/azure-policyassignment/lib/index.d.ts +2 -0
- package/lib/azure-policyassignment/lib/index.js +19 -0
- package/lib/azure-policyassignment/lib/policy-assignment-schemas.d.ts +25 -0
- package/lib/azure-policyassignment/lib/policy-assignment-schemas.js +260 -0
- package/lib/azure-policyassignment/lib/policy-assignment.d.ts +349 -0
- package/lib/azure-policyassignment/lib/policy-assignment.js +237 -0
- package/lib/azure-policyassignment/test/policy-assignment.integ.d.ts +13 -0
- package/lib/azure-policyassignment/test/policy-assignment.integ.js +153 -0
- package/lib/azure-policyassignment/test/policy-assignment.spec.d.ts +9 -0
- package/lib/azure-policyassignment/test/policy-assignment.spec.js +651 -0
- package/lib/azure-policydefinition/index.d.ts +1 -0
- package/lib/azure-policydefinition/index.js +18 -0
- package/lib/azure-policydefinition/lib/index.d.ts +2 -0
- package/lib/azure-policydefinition/lib/index.js +19 -0
- package/lib/azure-policydefinition/lib/policy-definition-schemas.d.ts +25 -0
- package/lib/azure-policydefinition/lib/policy-definition-schemas.js +210 -0
- package/lib/azure-policydefinition/lib/policy-definition.d.ts +281 -0
- package/lib/azure-policydefinition/lib/policy-definition.js +236 -0
- package/lib/azure-policydefinition/test/policy-definition.integ.d.ts +9 -0
- package/lib/azure-policydefinition/test/policy-definition.integ.js +137 -0
- package/lib/azure-policydefinition/test/policy-definition.spec.d.ts +9 -0
- package/lib/azure-policydefinition/test/policy-definition.spec.js +806 -0
- package/lib/azure-privatednszone/index.d.ts +1 -0
- package/lib/azure-privatednszone/index.js +18 -0
- package/lib/azure-privatednszone/lib/index.d.ts +2 -0
- package/lib/azure-privatednszone/lib/index.js +19 -0
- package/lib/azure-privatednszone/lib/private-dns-zone-schemas.d.ts +24 -0
- package/lib/azure-privatednszone/lib/private-dns-zone-schemas.js +254 -0
- package/lib/azure-privatednszone/lib/private-dns-zone.d.ts +178 -0
- package/lib/azure-privatednszone/lib/private-dns-zone.js +272 -0
- package/lib/azure-privatednszone/test/private-dns-zone.integ.d.ts +9 -0
- package/lib/azure-privatednszone/test/private-dns-zone.integ.js +84 -0
- package/lib/azure-privatednszone/test/private-dns-zone.spec.d.ts +9 -0
- package/lib/azure-privatednszone/test/private-dns-zone.spec.js +341 -0
- package/lib/azure-privatednszonelink/index.d.ts +1 -0
- package/lib/azure-privatednszonelink/index.js +18 -0
- package/lib/azure-privatednszonelink/lib/index.d.ts +2 -0
- package/lib/azure-privatednszonelink/lib/index.js +19 -0
- package/lib/azure-privatednszonelink/lib/private-dns-zone-link-schemas.d.ts +24 -0
- package/lib/azure-privatednszonelink/lib/private-dns-zone-link-schemas.js +262 -0
- package/lib/azure-privatednszonelink/lib/private-dns-zone-link.d.ts +202 -0
- package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +250 -0
- package/lib/azure-privatednszonelink/test/private-dns-zone-link.integ.d.ts +9 -0
- package/lib/azure-privatednszonelink/test/private-dns-zone-link.integ.js +110 -0
- package/lib/azure-privatednszonelink/test/private-dns-zone-link.spec.d.ts +9 -0
- package/lib/azure-privatednszonelink/test/private-dns-zone-link.spec.js +465 -0
- package/lib/azure-publicipaddress/index.d.ts +0 -5
- package/lib/azure-publicipaddress/index.js +1 -6
- package/lib/azure-publicipaddress/lib/index.d.ts +2 -9
- package/lib/azure-publicipaddress/lib/index.js +17 -17
- package/lib/azure-publicipaddress/lib/public-ip-address.d.ts +4 -13
- package/lib/azure-publicipaddress/lib/public-ip-address.js +14 -36
- package/lib/azure-resourcegroup/index.d.ts +0 -37
- package/lib/azure-resourcegroup/index.js +1 -39
- package/lib/azure-resourcegroup/lib/index.d.ts +1 -44
- package/lib/azure-resourcegroup/lib/index.js +2 -43
- package/lib/azure-resourcegroup/lib/resource-group.d.ts +9 -23
- package/lib/azure-resourcegroup/lib/resource-group.js +23 -56
- package/lib/azure-resourcegroup/test/resource-group.spec.js +13 -19
- package/lib/azure-roleassignment/index.d.ts +1 -0
- package/lib/azure-roleassignment/index.js +18 -0
- package/lib/azure-roleassignment/lib/index.d.ts +2 -0
- package/lib/azure-roleassignment/lib/index.js +19 -0
- package/lib/azure-roleassignment/lib/role-assignment-schemas.d.ts +25 -0
- package/lib/azure-roleassignment/lib/role-assignment-schemas.js +238 -0
- package/lib/azure-roleassignment/lib/role-assignment.d.ts +294 -0
- package/lib/azure-roleassignment/lib/role-assignment.js +257 -0
- package/lib/azure-roleassignment/test/role-assignment.integ.d.ts +12 -0
- package/lib/azure-roleassignment/test/role-assignment.integ.js +101 -0
- package/lib/azure-roleassignment/test/role-assignment.spec.d.ts +9 -0
- package/lib/azure-roleassignment/test/role-assignment.spec.js +633 -0
- package/lib/azure-roledefinition/index.d.ts +1 -0
- package/lib/azure-roledefinition/index.js +18 -0
- package/lib/azure-roledefinition/lib/index.d.ts +2 -0
- package/lib/azure-roledefinition/lib/index.js +19 -0
- package/lib/azure-roledefinition/lib/role-definition-schemas.d.ts +25 -0
- package/lib/azure-roledefinition/lib/role-definition-schemas.js +195 -0
- package/lib/azure-roledefinition/lib/role-definition.d.ts +236 -0
- package/lib/azure-roledefinition/lib/role-definition.js +192 -0
- package/lib/azure-roledefinition/test/role-definition.integ.d.ts +12 -0
- package/lib/azure-roledefinition/test/role-definition.integ.js +142 -0
- package/lib/azure-roledefinition/test/role-definition.spec.d.ts +9 -0
- package/lib/azure-roledefinition/test/role-definition.spec.js +946 -0
- package/lib/azure-storageaccount/index.d.ts +0 -19
- package/lib/azure-storageaccount/index.js +1 -20
- package/lib/azure-storageaccount/lib/index.d.ts +1 -7
- package/lib/azure-storageaccount/lib/index.js +2 -8
- package/lib/azure-storageaccount/lib/storage-account.d.ts +4 -9
- package/lib/azure-storageaccount/lib/storage-account.js +15 -29
- package/lib/azure-subnet/index.d.ts +0 -3
- package/lib/azure-subnet/index.js +1 -4
- package/lib/azure-subnet/lib/index.d.ts +1 -4
- package/lib/azure-subnet/lib/index.js +2 -5
- package/lib/azure-subnet/lib/subnet.d.ts +3 -14
- package/lib/azure-subnet/lib/subnet.js +28 -47
- package/lib/azure-subnet/test/subnet.integ.js +19 -7
- package/lib/azure-subnet/test/subnet.spec.js +1 -2
- package/lib/azure-virtualmachine/index.d.ts +0 -6
- package/lib/azure-virtualmachine/index.js +1 -7
- package/lib/azure-virtualmachine/lib/index.d.ts +1 -10
- package/lib/azure-virtualmachine/lib/index.js +2 -21
- package/lib/azure-virtualmachine/lib/virtual-machine.d.ts +4 -13
- package/lib/azure-virtualmachine/lib/virtual-machine.js +15 -36
- package/lib/azure-virtualnetwork/index.d.ts +0 -9
- package/lib/azure-virtualnetwork/index.js +1 -11
- package/lib/azure-virtualnetwork/lib/index.d.ts +2 -9
- package/lib/azure-virtualnetwork/lib/index.js +17 -20
- package/lib/azure-virtualnetwork/lib/virtual-network.d.ts +4 -13
- package/lib/azure-virtualnetwork/lib/virtual-network.js +15 -36
- package/lib/azure-virtualnetworkmanager/index.d.ts +1 -0
- package/lib/azure-virtualnetworkmanager/index.js +18 -0
- package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration-schemas.d.ts +48 -0
- package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration-schemas.js +265 -0
- package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.d.ts +185 -0
- package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +206 -0
- package/lib/azure-virtualnetworkmanager/lib/index.d.ts +14 -0
- package/lib/azure-virtualnetworkmanager/lib/index.js +31 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group-schemas.d.ts +32 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group-schemas.js +189 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group-static-member-schemas.d.ts +32 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group-static-member-schemas.js +201 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.d.ts +135 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +163 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group.d.ts +139 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group.js +158 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration-schemas.d.ts +32 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration-schemas.js +182 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.d.ts +144 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +164 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection-schemas.d.ts +38 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection-schemas.js +206 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.d.ts +142 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +162 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-schemas.d.ts +39 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-schemas.js +359 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.d.ts +221 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +204 -0
- package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager-schemas.d.ts +32 -0
- package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager-schemas.js +236 -0
- package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.d.ts +337 -0
- package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +283 -0
- package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.d.ts +25 -0
- package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.js +402 -0
- package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.d.ts +9 -0
- package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.js +1652 -0
- package/lib/azure-vmss/index.d.ts +0 -5
- package/lib/azure-vmss/index.js +1 -6
- package/lib/azure-vmss/lib/index.d.ts +0 -7
- package/lib/azure-vmss/lib/index.js +1 -21
- package/lib/azure-vmss/lib/virtual-machine-scale-set.d.ts +5 -13
- package/lib/azure-vmss/lib/virtual-machine-scale-set.js +29 -53
- package/lib/core-azure/lib/azapi/azapi-resource-tags.spec.d.ts +10 -0
- package/lib/core-azure/lib/azapi/azapi-resource-tags.spec.js +218 -0
- package/lib/core-azure/lib/azapi/azapi-resource.d.ts +206 -26
- package/lib/core-azure/lib/azapi/azapi-resource.js +379 -91
- package/lib/core-azure/lib/azapi/azapi-resource.spec.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 +5 -3
- 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/resource-schema-validator.d.ts +118 -0
- package/lib/core-azure/lib/azapi/resource-schema-validator.js +236 -0
- package/lib/core-azure/lib/azapi/resource-version-manager.d.ts +103 -0
- package/lib/core-azure/lib/azapi/resource-version-manager.js +168 -0
- package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +11 -6
- package/lib/core-azure/lib/index.d.ts +2 -2
- package/lib/core-azure/lib/index.js +5 -5
- 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 +19 -0
- package/lib/index.js +21 -2
- package/lib/testing/index.js +2 -2
- package/lib/testing/lib/cleanup.d.ts +1 -0
- package/lib/testing/lib/cleanup.js +19 -12
- package/lib/testing/lib/metadata.js +19 -16
- package/package.json +1 -1
- package/scripts/cleanup-test-resources.ts +22 -4
- package/scripts/generate-index.js +25 -8
|
@@ -0,0 +1,285 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Comprehensive tests for the DnsForwardingRulesetVirtualNetworkLink implementation
|
|
4
|
+
*
|
|
5
|
+
* This test suite validates the DnsForwardingRulesetVirtualNetworkLink class using the
|
|
6
|
+
* AzapiResource framework. Tests cover automatic version resolution,
|
|
7
|
+
* explicit version pinning, schema validation, property transformation,
|
|
8
|
+
* parent-child resource relationships, and full backward compatibility.
|
|
9
|
+
*/
|
|
10
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
11
|
+
const cdktf_1 = require("cdktf");
|
|
12
|
+
const cdktf = require("cdktf");
|
|
13
|
+
const api_version_manager_1 = require("../../core-azure/lib/version-manager/api-version-manager");
|
|
14
|
+
const version_interfaces_1 = require("../../core-azure/lib/version-manager/interfaces/version-interfaces");
|
|
15
|
+
const virtual_network_link_1 = require("../lib/virtual-network-link");
|
|
16
|
+
const virtual_network_link_schemas_1 = require("../lib/virtual-network-link-schemas");
|
|
17
|
+
describe("DnsForwardingRulesetVirtualNetworkLink - Implementation", () => {
|
|
18
|
+
let app;
|
|
19
|
+
let stack;
|
|
20
|
+
let manager;
|
|
21
|
+
const mockRulesetId = "/subscriptions/12345678-1234-1234-1234-123456789012/resourceGroups/test-rg/providers/Microsoft.Network/dnsForwardingRulesets/test-ruleset";
|
|
22
|
+
const mockVirtualNetworkId = "/subscriptions/12345678-1234-1234-1234-123456789012/resourceGroups/test-rg/providers/Microsoft.Network/virtualNetworks/test-vnet";
|
|
23
|
+
beforeEach(() => {
|
|
24
|
+
app = cdktf_1.Testing.app();
|
|
25
|
+
stack = new cdktf.TerraformStack(app, "TestStack");
|
|
26
|
+
manager = api_version_manager_1.ApiVersionManager.instance();
|
|
27
|
+
// Ensure schemas are registered
|
|
28
|
+
try {
|
|
29
|
+
manager.registerResourceType(virtual_network_link_schemas_1.VIRTUAL_NETWORK_LINK_TYPE, virtual_network_link_schemas_1.ALL_VIRTUAL_NETWORK_LINK_VERSIONS);
|
|
30
|
+
}
|
|
31
|
+
catch (error) {
|
|
32
|
+
// Ignore if already registered
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
describe("Constructor and Basic Properties", () => {
|
|
36
|
+
it("should create Virtual Network Link with automatic latest version resolution", () => {
|
|
37
|
+
const props = {
|
|
38
|
+
name: "my-vnet-link",
|
|
39
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
40
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
41
|
+
};
|
|
42
|
+
const link = new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", props);
|
|
43
|
+
expect(link).toBeInstanceOf(virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink);
|
|
44
|
+
expect(link.resolvedApiVersion).toBe("2022-07-01");
|
|
45
|
+
expect(link.props).toBe(props);
|
|
46
|
+
});
|
|
47
|
+
it("should create Virtual Network Link with explicit version pinning", () => {
|
|
48
|
+
const props = {
|
|
49
|
+
name: "my-vnet-link",
|
|
50
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
51
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
52
|
+
apiVersion: "2022-07-01",
|
|
53
|
+
};
|
|
54
|
+
const link = new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", props);
|
|
55
|
+
expect(link.resolvedApiVersion).toBe("2022-07-01");
|
|
56
|
+
});
|
|
57
|
+
it("should create Virtual Network Link with metadata", () => {
|
|
58
|
+
const props = {
|
|
59
|
+
name: "my-vnet-link",
|
|
60
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
61
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
62
|
+
metadata: {
|
|
63
|
+
environment: "production",
|
|
64
|
+
team: "platform",
|
|
65
|
+
},
|
|
66
|
+
};
|
|
67
|
+
const link = new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", props);
|
|
68
|
+
expect(link).toBeDefined();
|
|
69
|
+
expect(link.props.metadata).toEqual({
|
|
70
|
+
environment: "production",
|
|
71
|
+
team: "platform",
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
describe("Framework Integration", () => {
|
|
76
|
+
it("should resolve latest API version automatically", () => {
|
|
77
|
+
const link = new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", {
|
|
78
|
+
name: "my-vnet-link",
|
|
79
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
80
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
81
|
+
});
|
|
82
|
+
expect(link.resolvedApiVersion).toBe("2022-07-01");
|
|
83
|
+
expect(link.latestVersion()).toBe("2022-07-01");
|
|
84
|
+
});
|
|
85
|
+
it("should provide version configuration", () => {
|
|
86
|
+
const link = new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", {
|
|
87
|
+
name: "my-vnet-link",
|
|
88
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
89
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
90
|
+
});
|
|
91
|
+
expect(link.versionConfig).toBeDefined();
|
|
92
|
+
expect(link.versionConfig.version).toBe("2022-07-01");
|
|
93
|
+
expect(link.versionConfig.supportLevel).toBe(version_interfaces_1.VersionSupportLevel.ACTIVE);
|
|
94
|
+
});
|
|
95
|
+
it("should provide supported versions", () => {
|
|
96
|
+
const link = new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", {
|
|
97
|
+
name: "my-vnet-link",
|
|
98
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
99
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
100
|
+
});
|
|
101
|
+
const versions = link.supportedVersions();
|
|
102
|
+
expect(versions).toContain("2022-07-01");
|
|
103
|
+
expect(versions.length).toBeGreaterThan(0);
|
|
104
|
+
});
|
|
105
|
+
});
|
|
106
|
+
describe("Parent-Child Resource Relationship", () => {
|
|
107
|
+
it("should use dnsForwardingRulesetId as parent ID", () => {
|
|
108
|
+
const link = new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", {
|
|
109
|
+
name: "my-vnet-link",
|
|
110
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
111
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
112
|
+
});
|
|
113
|
+
// Verify the link was created successfully with proper parent
|
|
114
|
+
expect(link).toBeDefined();
|
|
115
|
+
expect(link.props.dnsForwardingRulesetId).toBe(mockRulesetId);
|
|
116
|
+
});
|
|
117
|
+
it("should correctly handle child resource in Terraform synthesis", () => {
|
|
118
|
+
new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", {
|
|
119
|
+
name: "my-vnet-link",
|
|
120
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
121
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
122
|
+
});
|
|
123
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
124
|
+
expect(synthesized).toContain("virtualNetworkLinks");
|
|
125
|
+
expect(synthesized).toContain(mockRulesetId);
|
|
126
|
+
});
|
|
127
|
+
});
|
|
128
|
+
describe("Public Methods - Virtual Network Link Properties", () => {
|
|
129
|
+
it("should provide provisioning state", () => {
|
|
130
|
+
const link = new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", {
|
|
131
|
+
name: "my-vnet-link",
|
|
132
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
133
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
134
|
+
});
|
|
135
|
+
expect(link.provisioningState).toBeDefined();
|
|
136
|
+
expect(typeof link.provisioningState).toBe("string");
|
|
137
|
+
});
|
|
138
|
+
it("should provide metadata", () => {
|
|
139
|
+
const link = new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", {
|
|
140
|
+
name: "my-vnet-link",
|
|
141
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
142
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
143
|
+
metadata: { key: "value" },
|
|
144
|
+
});
|
|
145
|
+
expect(link.metadata).toBeDefined();
|
|
146
|
+
expect(typeof link.metadata).toBe("string");
|
|
147
|
+
});
|
|
148
|
+
});
|
|
149
|
+
describe("Outputs", () => {
|
|
150
|
+
it("should create all required outputs", () => {
|
|
151
|
+
const link = new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", {
|
|
152
|
+
name: "my-vnet-link",
|
|
153
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
154
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
155
|
+
});
|
|
156
|
+
expect(link.idOutput).toBeDefined();
|
|
157
|
+
expect(link.nameOutput).toBeDefined();
|
|
158
|
+
expect(link.provisioningStateOutput).toBeDefined();
|
|
159
|
+
});
|
|
160
|
+
it("should have correct logical IDs for outputs", () => {
|
|
161
|
+
new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", {
|
|
162
|
+
name: "my-vnet-link",
|
|
163
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
164
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
165
|
+
});
|
|
166
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
167
|
+
expect(synthesized).toContain('"id"');
|
|
168
|
+
expect(synthesized).toContain('"name"');
|
|
169
|
+
expect(synthesized).toContain('"provisioning_state"');
|
|
170
|
+
});
|
|
171
|
+
});
|
|
172
|
+
describe("Ignore Changes Configuration", () => {
|
|
173
|
+
it("should apply ignore changes lifecycle rules", () => {
|
|
174
|
+
new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", {
|
|
175
|
+
name: "my-vnet-link",
|
|
176
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
177
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
178
|
+
ignoreChanges: ["metadata"],
|
|
179
|
+
});
|
|
180
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
181
|
+
expect(synthesized).toContain("ignore_changes");
|
|
182
|
+
});
|
|
183
|
+
it("should handle multiple ignore changes properties", () => {
|
|
184
|
+
new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", {
|
|
185
|
+
name: "my-vnet-link",
|
|
186
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
187
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
188
|
+
ignoreChanges: ["metadata", "name"],
|
|
189
|
+
});
|
|
190
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
191
|
+
expect(synthesized).toBeDefined();
|
|
192
|
+
});
|
|
193
|
+
});
|
|
194
|
+
describe("CDK Terraform Integration", () => {
|
|
195
|
+
it("should synthesize to valid Terraform configuration", () => {
|
|
196
|
+
new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "SynthTest", {
|
|
197
|
+
name: "my-vnet-link",
|
|
198
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
199
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
200
|
+
});
|
|
201
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
202
|
+
expect(synthesized).toBeDefined();
|
|
203
|
+
const stackConfig = JSON.parse(synthesized);
|
|
204
|
+
expect(stackConfig.resource).toBeDefined();
|
|
205
|
+
});
|
|
206
|
+
it("should generate correct resource type in Terraform", () => {
|
|
207
|
+
new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "SynthTest", {
|
|
208
|
+
name: "my-vnet-link",
|
|
209
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
210
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
211
|
+
});
|
|
212
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
213
|
+
expect(synthesized).toContain("virtualNetworkLinks");
|
|
214
|
+
expect(synthesized).toContain("2022-07-01");
|
|
215
|
+
});
|
|
216
|
+
it("should include all properties in Terraform body", () => {
|
|
217
|
+
new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "SynthTest", {
|
|
218
|
+
name: "my-vnet-link",
|
|
219
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
220
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
221
|
+
metadata: { env: "test" },
|
|
222
|
+
});
|
|
223
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
224
|
+
expect(synthesized).toContain(mockVirtualNetworkId);
|
|
225
|
+
});
|
|
226
|
+
});
|
|
227
|
+
describe("Resource Identification", () => {
|
|
228
|
+
it("should provide resource ID", () => {
|
|
229
|
+
const link = new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", {
|
|
230
|
+
name: "my-vnet-link",
|
|
231
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
232
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
233
|
+
});
|
|
234
|
+
expect(link.id).toBeDefined();
|
|
235
|
+
expect(typeof link.id).toBe("string");
|
|
236
|
+
});
|
|
237
|
+
it("should provide resource name from props when specified", () => {
|
|
238
|
+
const link = new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", {
|
|
239
|
+
name: "my-vnet-link",
|
|
240
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
241
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
242
|
+
});
|
|
243
|
+
expect(link.name).toBe("my-vnet-link");
|
|
244
|
+
});
|
|
245
|
+
});
|
|
246
|
+
describe("JSII Compliance", () => {
|
|
247
|
+
it("should have proper return types for all public methods", () => {
|
|
248
|
+
const link = new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", {
|
|
249
|
+
name: "my-vnet-link",
|
|
250
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
251
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
252
|
+
});
|
|
253
|
+
// All getter methods should return strings for Terraform interpolations
|
|
254
|
+
expect(typeof link.provisioningState).toBe("string");
|
|
255
|
+
expect(typeof link.metadata).toBe("string");
|
|
256
|
+
});
|
|
257
|
+
});
|
|
258
|
+
describe("Schema Registration", () => {
|
|
259
|
+
it("should register schemas successfully", () => {
|
|
260
|
+
const link = new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink", {
|
|
261
|
+
name: "my-vnet-link",
|
|
262
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
263
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
264
|
+
});
|
|
265
|
+
// If the link was created successfully, schemas were registered
|
|
266
|
+
expect(link).toBeDefined();
|
|
267
|
+
expect(link.resolvedApiVersion).toBe("2022-07-01");
|
|
268
|
+
});
|
|
269
|
+
it("should handle multiple instantiations without errors", () => {
|
|
270
|
+
new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink1", {
|
|
271
|
+
name: "my-vnet-link-1",
|
|
272
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
273
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
274
|
+
});
|
|
275
|
+
// Second instantiation should not throw an error even if schemas are already registered
|
|
276
|
+
const link2 = new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(stack, "TestLink2", {
|
|
277
|
+
name: "my-vnet-link-2",
|
|
278
|
+
dnsForwardingRulesetId: mockRulesetId,
|
|
279
|
+
virtualNetworkId: mockVirtualNetworkId,
|
|
280
|
+
});
|
|
281
|
+
expect(link2).toBeDefined();
|
|
282
|
+
});
|
|
283
|
+
});
|
|
284
|
+
});
|
|
285
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"virtual-network-link.spec.js","sourceRoot":"","sources":["../../../src/azure-dnsforwardingruleset/test/virtual-network-link.spec.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Comprehensive tests for the DnsForwardingRulesetVirtualNetworkLink implementation\n *\n * This test suite validates the DnsForwardingRulesetVirtualNetworkLink class using the\n * AzapiResource framework. Tests cover automatic version resolution,\n * explicit version pinning, schema validation, property transformation,\n * parent-child resource relationships, and full backward compatibility.\n */\n\nimport { Testing } from \"cdktf\";\nimport * as cdktf from \"cdktf\";\nimport { ApiVersionManager } from \"../../core-azure/lib/version-manager/api-version-manager\";\nimport { VersionSupportLevel } from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\nimport {\n  DnsForwardingRulesetVirtualNetworkLink,\n  DnsForwardingRulesetVirtualNetworkLinkProps,\n} from \"../lib/virtual-network-link\";\nimport {\n  ALL_VIRTUAL_NETWORK_LINK_VERSIONS,\n  VIRTUAL_NETWORK_LINK_TYPE,\n} from \"../lib/virtual-network-link-schemas\";\n\ndescribe(\"DnsForwardingRulesetVirtualNetworkLink - Implementation\", () => {\n  let app: cdktf.App;\n  let stack: cdktf.TerraformStack;\n  let manager: ApiVersionManager;\n\n  const mockRulesetId =\n    \"/subscriptions/12345678-1234-1234-1234-123456789012/resourceGroups/test-rg/providers/Microsoft.Network/dnsForwardingRulesets/test-ruleset\";\n  const mockVirtualNetworkId =\n    \"/subscriptions/12345678-1234-1234-1234-123456789012/resourceGroups/test-rg/providers/Microsoft.Network/virtualNetworks/test-vnet\";\n\n  beforeEach(() => {\n    app = Testing.app();\n    stack = new cdktf.TerraformStack(app, \"TestStack\");\n    manager = ApiVersionManager.instance();\n\n    // Ensure schemas are registered\n    try {\n      manager.registerResourceType(\n        VIRTUAL_NETWORK_LINK_TYPE,\n        ALL_VIRTUAL_NETWORK_LINK_VERSIONS,\n      );\n    } catch (error) {\n      // Ignore if already registered\n    }\n  });\n\n  describe(\"Constructor and Basic Properties\", () => {\n    it(\"should create Virtual Network Link with automatic latest version resolution\", () => {\n      const props: DnsForwardingRulesetVirtualNetworkLinkProps = {\n        name: \"my-vnet-link\",\n        dnsForwardingRulesetId: mockRulesetId,\n        virtualNetworkId: mockVirtualNetworkId,\n      };\n\n      const link = new DnsForwardingRulesetVirtualNetworkLink(\n        stack,\n        \"TestLink\",\n        props,\n      );\n\n      expect(link).toBeInstanceOf(DnsForwardingRulesetVirtualNetworkLink);\n      expect(link.resolvedApiVersion).toBe(\"2022-07-01\");\n      expect(link.props).toBe(props);\n    });\n\n    it(\"should create Virtual Network Link with explicit version pinning\", () => {\n      const props: DnsForwardingRulesetVirtualNetworkLinkProps = {\n        name: \"my-vnet-link\",\n        dnsForwardingRulesetId: mockRulesetId,\n        virtualNetworkId: mockVirtualNetworkId,\n        apiVersion: \"2022-07-01\",\n      };\n\n      const link = new DnsForwardingRulesetVirtualNetworkLink(\n        stack,\n        \"TestLink\",\n        props,\n      );\n\n      expect(link.resolvedApiVersion).toBe(\"2022-07-01\");\n    });\n\n    it(\"should create Virtual Network Link with metadata\", () => {\n      const props: DnsForwardingRulesetVirtualNetworkLinkProps = {\n        name: \"my-vnet-link\",\n        dnsForwardingRulesetId: mockRulesetId,\n        virtualNetworkId: mockVirtualNetworkId,\n        metadata: {\n          environment: \"production\",\n          team: \"platform\",\n        },\n      };\n\n      const link = new DnsForwardingRulesetVirtualNetworkLink(\n        stack,\n        \"TestLink\",\n        props,\n      );\n\n      expect(link).toBeDefined();\n      expect(link.props.metadata).toEqual({\n        environment: \"production\",\n        team: \"platform\",\n      });\n    });\n  });\n\n  describe(\"Framework Integration\", () => {\n    it(\"should resolve latest API version automatically\", () => {\n      const link = new DnsForwardingRulesetVirtualNetworkLink(\n        stack,\n        \"TestLink\",\n        {\n          name: \"my-vnet-link\",\n          dnsForwardingRulesetId: mockRulesetId,\n          virtualNetworkId: mockVirtualNetworkId,\n        },\n      );\n\n      expect(link.resolvedApiVersion).toBe(\"2022-07-01\");\n      expect(link.latestVersion()).toBe(\"2022-07-01\");\n    });\n\n    it(\"should provide version configuration\", () => {\n      const link = new DnsForwardingRulesetVirtualNetworkLink(\n        stack,\n        \"TestLink\",\n        {\n          name: \"my-vnet-link\",\n          dnsForwardingRulesetId: mockRulesetId,\n          virtualNetworkId: mockVirtualNetworkId,\n        },\n      );\n\n      expect(link.versionConfig).toBeDefined();\n      expect(link.versionConfig.version).toBe(\"2022-07-01\");\n      expect(link.versionConfig.supportLevel).toBe(VersionSupportLevel.ACTIVE);\n    });\n\n    it(\"should provide supported versions\", () => {\n      const link = new DnsForwardingRulesetVirtualNetworkLink(\n        stack,\n        \"TestLink\",\n        {\n          name: \"my-vnet-link\",\n          dnsForwardingRulesetId: mockRulesetId,\n          virtualNetworkId: mockVirtualNetworkId,\n        },\n      );\n\n      const versions = link.supportedVersions();\n      expect(versions).toContain(\"2022-07-01\");\n      expect(versions.length).toBeGreaterThan(0);\n    });\n  });\n\n  describe(\"Parent-Child Resource Relationship\", () => {\n    it(\"should use dnsForwardingRulesetId as parent ID\", () => {\n      const link = new DnsForwardingRulesetVirtualNetworkLink(\n        stack,\n        \"TestLink\",\n        {\n          name: \"my-vnet-link\",\n          dnsForwardingRulesetId: mockRulesetId,\n          virtualNetworkId: mockVirtualNetworkId,\n        },\n      );\n\n      // Verify the link was created successfully with proper parent\n      expect(link).toBeDefined();\n      expect(link.props.dnsForwardingRulesetId).toBe(mockRulesetId);\n    });\n\n    it(\"should correctly handle child resource in Terraform synthesis\", () => {\n      new DnsForwardingRulesetVirtualNetworkLink(stack, \"TestLink\", {\n        name: \"my-vnet-link\",\n        dnsForwardingRulesetId: mockRulesetId,\n        virtualNetworkId: mockVirtualNetworkId,\n      });\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toContain(\"virtualNetworkLinks\");\n      expect(synthesized).toContain(mockRulesetId);\n    });\n  });\n\n  describe(\"Public Methods - Virtual Network Link Properties\", () => {\n    it(\"should provide provisioning state\", () => {\n      const link = new DnsForwardingRulesetVirtualNetworkLink(\n        stack,\n        \"TestLink\",\n        {\n          name: \"my-vnet-link\",\n          dnsForwardingRulesetId: mockRulesetId,\n          virtualNetworkId: mockVirtualNetworkId,\n        },\n      );\n\n      expect(link.provisioningState).toBeDefined();\n      expect(typeof link.provisioningState).toBe(\"string\");\n    });\n\n    it(\"should provide metadata\", () => {\n      const link = new DnsForwardingRulesetVirtualNetworkLink(\n        stack,\n        \"TestLink\",\n        {\n          name: \"my-vnet-link\",\n          dnsForwardingRulesetId: mockRulesetId,\n          virtualNetworkId: mockVirtualNetworkId,\n          metadata: { key: \"value\" },\n        },\n      );\n\n      expect(link.metadata).toBeDefined();\n      expect(typeof link.metadata).toBe(\"string\");\n    });\n  });\n\n  describe(\"Outputs\", () => {\n    it(\"should create all required outputs\", () => {\n      const link = new DnsForwardingRulesetVirtualNetworkLink(\n        stack,\n        \"TestLink\",\n        {\n          name: \"my-vnet-link\",\n          dnsForwardingRulesetId: mockRulesetId,\n          virtualNetworkId: mockVirtualNetworkId,\n        },\n      );\n\n      expect(link.idOutput).toBeDefined();\n      expect(link.nameOutput).toBeDefined();\n      expect(link.provisioningStateOutput).toBeDefined();\n    });\n\n    it(\"should have correct logical IDs for outputs\", () => {\n      new DnsForwardingRulesetVirtualNetworkLink(stack, \"TestLink\", {\n        name: \"my-vnet-link\",\n        dnsForwardingRulesetId: mockRulesetId,\n        virtualNetworkId: mockVirtualNetworkId,\n      });\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toContain('\"id\"');\n      expect(synthesized).toContain('\"name\"');\n      expect(synthesized).toContain('\"provisioning_state\"');\n    });\n  });\n\n  describe(\"Ignore Changes Configuration\", () => {\n    it(\"should apply ignore changes lifecycle rules\", () => {\n      new DnsForwardingRulesetVirtualNetworkLink(stack, \"TestLink\", {\n        name: \"my-vnet-link\",\n        dnsForwardingRulesetId: mockRulesetId,\n        virtualNetworkId: mockVirtualNetworkId,\n        ignoreChanges: [\"metadata\"],\n      });\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toContain(\"ignore_changes\");\n    });\n\n    it(\"should handle multiple ignore changes properties\", () => {\n      new DnsForwardingRulesetVirtualNetworkLink(stack, \"TestLink\", {\n        name: \"my-vnet-link\",\n        dnsForwardingRulesetId: mockRulesetId,\n        virtualNetworkId: mockVirtualNetworkId,\n        ignoreChanges: [\"metadata\", \"name\"],\n      });\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toBeDefined();\n    });\n  });\n\n  describe(\"CDK Terraform Integration\", () => {\n    it(\"should synthesize to valid Terraform configuration\", () => {\n      new DnsForwardingRulesetVirtualNetworkLink(stack, \"SynthTest\", {\n        name: \"my-vnet-link\",\n        dnsForwardingRulesetId: mockRulesetId,\n        virtualNetworkId: mockVirtualNetworkId,\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 generate correct resource type in Terraform\", () => {\n      new DnsForwardingRulesetVirtualNetworkLink(stack, \"SynthTest\", {\n        name: \"my-vnet-link\",\n        dnsForwardingRulesetId: mockRulesetId,\n        virtualNetworkId: mockVirtualNetworkId,\n      });\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toContain(\"virtualNetworkLinks\");\n      expect(synthesized).toContain(\"2022-07-01\");\n    });\n\n    it(\"should include all properties in Terraform body\", () => {\n      new DnsForwardingRulesetVirtualNetworkLink(stack, \"SynthTest\", {\n        name: \"my-vnet-link\",\n        dnsForwardingRulesetId: mockRulesetId,\n        virtualNetworkId: mockVirtualNetworkId,\n        metadata: { env: \"test\" },\n      });\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toContain(mockVirtualNetworkId);\n    });\n  });\n\n  describe(\"Resource Identification\", () => {\n    it(\"should provide resource ID\", () => {\n      const link = new DnsForwardingRulesetVirtualNetworkLink(\n        stack,\n        \"TestLink\",\n        {\n          name: \"my-vnet-link\",\n          dnsForwardingRulesetId: mockRulesetId,\n          virtualNetworkId: mockVirtualNetworkId,\n        },\n      );\n\n      expect(link.id).toBeDefined();\n      expect(typeof link.id).toBe(\"string\");\n    });\n\n    it(\"should provide resource name from props when specified\", () => {\n      const link = new DnsForwardingRulesetVirtualNetworkLink(\n        stack,\n        \"TestLink\",\n        {\n          name: \"my-vnet-link\",\n          dnsForwardingRulesetId: mockRulesetId,\n          virtualNetworkId: mockVirtualNetworkId,\n        },\n      );\n\n      expect(link.name).toBe(\"my-vnet-link\");\n    });\n  });\n\n  describe(\"JSII Compliance\", () => {\n    it(\"should have proper return types for all public methods\", () => {\n      const link = new DnsForwardingRulesetVirtualNetworkLink(\n        stack,\n        \"TestLink\",\n        {\n          name: \"my-vnet-link\",\n          dnsForwardingRulesetId: mockRulesetId,\n          virtualNetworkId: mockVirtualNetworkId,\n        },\n      );\n\n      // All getter methods should return strings for Terraform interpolations\n      expect(typeof link.provisioningState).toBe(\"string\");\n      expect(typeof link.metadata).toBe(\"string\");\n    });\n  });\n\n  describe(\"Schema Registration\", () => {\n    it(\"should register schemas successfully\", () => {\n      const link = new DnsForwardingRulesetVirtualNetworkLink(\n        stack,\n        \"TestLink\",\n        {\n          name: \"my-vnet-link\",\n          dnsForwardingRulesetId: mockRulesetId,\n          virtualNetworkId: mockVirtualNetworkId,\n        },\n      );\n\n      // If the link was created successfully, schemas were registered\n      expect(link).toBeDefined();\n      expect(link.resolvedApiVersion).toBe(\"2022-07-01\");\n    });\n\n    it(\"should handle multiple instantiations without errors\", () => {\n      new DnsForwardingRulesetVirtualNetworkLink(stack, \"TestLink1\", {\n        name: \"my-vnet-link-1\",\n        dnsForwardingRulesetId: mockRulesetId,\n        virtualNetworkId: mockVirtualNetworkId,\n      });\n\n      // Second instantiation should not throw an error even if schemas are already registered\n      const link2 = new DnsForwardingRulesetVirtualNetworkLink(\n        stack,\n        \"TestLink2\",\n        {\n          name: \"my-vnet-link-2\",\n          dnsForwardingRulesetId: mockRulesetId,\n          virtualNetworkId: mockVirtualNetworkId,\n        },\n      );\n\n      expect(link2).toBeDefined();\n    });\n  });\n});\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./lib";
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./lib"), exports);
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXp1cmUtZG5zcmVzb2x2ZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHdDQUFzQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2xpYlwiO1xuIl19
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* API schemas for Azure DNS Private Resolver across all supported versions
|
|
3
|
+
*
|
|
4
|
+
* This file defines the complete API schemas for Microsoft.Network/dnsResolvers
|
|
5
|
+
* across all supported API versions. The schemas are used by the VersionedAzapiResource
|
|
6
|
+
* framework for validation, transformation, and version management.
|
|
7
|
+
*/
|
|
8
|
+
import { ApiSchema, VersionConfig } from "../../core-azure/lib/version-manager/interfaces/version-interfaces";
|
|
9
|
+
/**
|
|
10
|
+
* API Schema for DNS Resolver version 2022-07-01
|
|
11
|
+
*/
|
|
12
|
+
export declare const DNS_RESOLVER_SCHEMA_2022_07_01: ApiSchema;
|
|
13
|
+
/**
|
|
14
|
+
* Version configuration for DNS Resolver 2022-07-01
|
|
15
|
+
*/
|
|
16
|
+
export declare const DNS_RESOLVER_VERSION_2022_07_01: VersionConfig;
|
|
17
|
+
/**
|
|
18
|
+
* All supported DNS Resolver versions for registration
|
|
19
|
+
*/
|
|
20
|
+
export declare const ALL_DNS_RESOLVER_VERSIONS: VersionConfig[];
|
|
21
|
+
/**
|
|
22
|
+
* Resource type constant
|
|
23
|
+
*/
|
|
24
|
+
export declare const DNS_RESOLVER_TYPE = "Microsoft.Network/dnsResolvers";
|
|
@@ -0,0 +1,218 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* API schemas for Azure DNS Private Resolver across all supported versions
|
|
4
|
+
*
|
|
5
|
+
* This file defines the complete API schemas for Microsoft.Network/dnsResolvers
|
|
6
|
+
* across all supported API versions. The schemas are used by the VersionedAzapiResource
|
|
7
|
+
* framework for validation, transformation, and version management.
|
|
8
|
+
*/
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.DNS_RESOLVER_TYPE = exports.ALL_DNS_RESOLVER_VERSIONS = exports.DNS_RESOLVER_VERSION_2022_07_01 = exports.DNS_RESOLVER_SCHEMA_2022_07_01 = void 0;
|
|
11
|
+
const version_interfaces_1 = require("../../core-azure/lib/version-manager/interfaces/version-interfaces");
|
|
12
|
+
// =============================================================================
|
|
13
|
+
// COMMON PROPERTY DEFINITIONS
|
|
14
|
+
// =============================================================================
|
|
15
|
+
/**
|
|
16
|
+
* Common property definitions shared across all DNS Resolver versions
|
|
17
|
+
*/
|
|
18
|
+
const COMMON_PROPERTIES = {
|
|
19
|
+
location: {
|
|
20
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
21
|
+
required: true,
|
|
22
|
+
description: "The Azure region where the DNS Resolver will be created. DNS Resolvers are regional resources.",
|
|
23
|
+
validation: [
|
|
24
|
+
{
|
|
25
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
26
|
+
message: "Location is required for DNS Resolvers",
|
|
27
|
+
},
|
|
28
|
+
],
|
|
29
|
+
},
|
|
30
|
+
tags: {
|
|
31
|
+
dataType: version_interfaces_1.PropertyType.OBJECT,
|
|
32
|
+
required: false,
|
|
33
|
+
defaultValue: {},
|
|
34
|
+
description: "A dictionary of tags to apply to the DNS Resolver for organizational, billing, or other purposes",
|
|
35
|
+
validation: [
|
|
36
|
+
{
|
|
37
|
+
ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
|
|
38
|
+
value: version_interfaces_1.PropertyType.OBJECT,
|
|
39
|
+
message: "Tags must be an object with string key-value pairs",
|
|
40
|
+
},
|
|
41
|
+
],
|
|
42
|
+
},
|
|
43
|
+
name: {
|
|
44
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
45
|
+
required: true,
|
|
46
|
+
description: "The name of the DNS Resolver. Must be unique within the resource group.",
|
|
47
|
+
validation: [
|
|
48
|
+
{
|
|
49
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
50
|
+
message: "DNS Resolver name is required",
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
ruleType: version_interfaces_1.ValidationRuleType.PATTERN_MATCH,
|
|
54
|
+
value: "^[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?$",
|
|
55
|
+
message: "DNS Resolver name must start and end with alphanumeric characters and can contain hyphens",
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
ruleType: version_interfaces_1.ValidationRuleType.VALUE_RANGE,
|
|
59
|
+
value: { minLength: 1, maxLength: 80 },
|
|
60
|
+
message: "DNS Resolver name must be between 1 and 80 characters",
|
|
61
|
+
},
|
|
62
|
+
],
|
|
63
|
+
},
|
|
64
|
+
virtualNetworkId: {
|
|
65
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
66
|
+
required: true,
|
|
67
|
+
description: "The resource ID of the virtual network where the DNS Resolver will be deployed. The resolver requires a dedicated subnet.",
|
|
68
|
+
validation: [
|
|
69
|
+
{
|
|
70
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
71
|
+
message: "Virtual Network ID is required for DNS Resolvers",
|
|
72
|
+
},
|
|
73
|
+
{
|
|
74
|
+
ruleType: version_interfaces_1.ValidationRuleType.PATTERN_MATCH,
|
|
75
|
+
value: "^/subscriptions/[^/]+/resourceGroups/[^/]+/providers/Microsoft.Network/virtualNetworks/[^/]+$",
|
|
76
|
+
message: "Virtual Network ID must be a valid Azure resource ID",
|
|
77
|
+
},
|
|
78
|
+
],
|
|
79
|
+
},
|
|
80
|
+
ignoreChanges: {
|
|
81
|
+
dataType: version_interfaces_1.PropertyType.ARRAY,
|
|
82
|
+
required: false,
|
|
83
|
+
description: "Array of property names to ignore during updates",
|
|
84
|
+
validation: [
|
|
85
|
+
{
|
|
86
|
+
ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
|
|
87
|
+
value: version_interfaces_1.PropertyType.ARRAY,
|
|
88
|
+
message: "IgnoreChanges must be an array of strings",
|
|
89
|
+
},
|
|
90
|
+
],
|
|
91
|
+
},
|
|
92
|
+
};
|
|
93
|
+
// =============================================================================
|
|
94
|
+
// READ-ONLY PROPERTY DEFINITIONS
|
|
95
|
+
// =============================================================================
|
|
96
|
+
/**
|
|
97
|
+
* Read-only properties that are populated by Azure after creation
|
|
98
|
+
* These properties should not be included in the request body
|
|
99
|
+
*/
|
|
100
|
+
const READ_ONLY_PROPERTIES = {
|
|
101
|
+
dnsResolverState: {
|
|
102
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
103
|
+
required: false,
|
|
104
|
+
description: "The state of the DNS Resolver. Can be 'Connected' or 'Disconnected' (read-only)",
|
|
105
|
+
validation: [
|
|
106
|
+
{
|
|
107
|
+
ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
|
|
108
|
+
value: version_interfaces_1.PropertyType.STRING,
|
|
109
|
+
message: "DnsResolverState must be a string",
|
|
110
|
+
},
|
|
111
|
+
],
|
|
112
|
+
},
|
|
113
|
+
provisioningState: {
|
|
114
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
115
|
+
required: false,
|
|
116
|
+
description: "The provisioning state of the DNS Resolver resource (read-only)",
|
|
117
|
+
validation: [
|
|
118
|
+
{
|
|
119
|
+
ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
|
|
120
|
+
value: version_interfaces_1.PropertyType.STRING,
|
|
121
|
+
message: "ProvisioningState must be a string",
|
|
122
|
+
},
|
|
123
|
+
],
|
|
124
|
+
},
|
|
125
|
+
resourceGuid: {
|
|
126
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
127
|
+
required: false,
|
|
128
|
+
description: "The unique identifier for the DNS Resolver resource (read-only)",
|
|
129
|
+
validation: [
|
|
130
|
+
{
|
|
131
|
+
ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
|
|
132
|
+
value: version_interfaces_1.PropertyType.STRING,
|
|
133
|
+
message: "ResourceGuid must be a string",
|
|
134
|
+
},
|
|
135
|
+
],
|
|
136
|
+
},
|
|
137
|
+
};
|
|
138
|
+
// =============================================================================
|
|
139
|
+
// VERSION-SPECIFIC SCHEMAS
|
|
140
|
+
// =============================================================================
|
|
141
|
+
/**
|
|
142
|
+
* API Schema for DNS Resolver version 2022-07-01
|
|
143
|
+
*/
|
|
144
|
+
exports.DNS_RESOLVER_SCHEMA_2022_07_01 = {
|
|
145
|
+
resourceType: "Microsoft.Network/dnsResolvers",
|
|
146
|
+
version: "2022-07-01",
|
|
147
|
+
properties: {
|
|
148
|
+
...COMMON_PROPERTIES,
|
|
149
|
+
...READ_ONLY_PROPERTIES,
|
|
150
|
+
},
|
|
151
|
+
required: ["location", "name", "virtualNetworkId"],
|
|
152
|
+
optional: ["tags", "ignoreChanges"],
|
|
153
|
+
deprecated: [],
|
|
154
|
+
transformationRules: {},
|
|
155
|
+
validationRules: [
|
|
156
|
+
{
|
|
157
|
+
property: "location",
|
|
158
|
+
rules: [
|
|
159
|
+
{
|
|
160
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
161
|
+
message: "Location is required for DNS Resolvers",
|
|
162
|
+
},
|
|
163
|
+
],
|
|
164
|
+
},
|
|
165
|
+
{
|
|
166
|
+
property: "name",
|
|
167
|
+
rules: [
|
|
168
|
+
{
|
|
169
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
170
|
+
message: "Name is required for DNS Resolvers",
|
|
171
|
+
},
|
|
172
|
+
],
|
|
173
|
+
},
|
|
174
|
+
{
|
|
175
|
+
property: "virtualNetworkId",
|
|
176
|
+
rules: [
|
|
177
|
+
{
|
|
178
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
179
|
+
message: "Virtual Network ID is required for DNS Resolvers",
|
|
180
|
+
},
|
|
181
|
+
],
|
|
182
|
+
},
|
|
183
|
+
],
|
|
184
|
+
};
|
|
185
|
+
// =============================================================================
|
|
186
|
+
// VERSION CONFIGURATIONS
|
|
187
|
+
// =============================================================================
|
|
188
|
+
/**
|
|
189
|
+
* Version configuration for DNS Resolver 2022-07-01
|
|
190
|
+
*/
|
|
191
|
+
exports.DNS_RESOLVER_VERSION_2022_07_01 = {
|
|
192
|
+
version: "2022-07-01",
|
|
193
|
+
schema: exports.DNS_RESOLVER_SCHEMA_2022_07_01,
|
|
194
|
+
supportLevel: version_interfaces_1.VersionSupportLevel.ACTIVE,
|
|
195
|
+
releaseDate: "2022-07-01",
|
|
196
|
+
deprecationDate: undefined,
|
|
197
|
+
sunsetDate: undefined,
|
|
198
|
+
breakingChanges: [],
|
|
199
|
+
migrationGuide: "/docs/dns-resolver/migration-2022-07-01",
|
|
200
|
+
changeLog: [
|
|
201
|
+
{
|
|
202
|
+
changeType: "added",
|
|
203
|
+
description: "Stable release of DNS Resolver API with support for hybrid DNS scenarios and conditional forwarding",
|
|
204
|
+
breaking: false,
|
|
205
|
+
},
|
|
206
|
+
],
|
|
207
|
+
};
|
|
208
|
+
/**
|
|
209
|
+
* All supported DNS Resolver versions for registration
|
|
210
|
+
*/
|
|
211
|
+
exports.ALL_DNS_RESOLVER_VERSIONS = [
|
|
212
|
+
exports.DNS_RESOLVER_VERSION_2022_07_01,
|
|
213
|
+
];
|
|
214
|
+
/**
|
|
215
|
+
* Resource type constant
|
|
216
|
+
*/
|
|
217
|
+
exports.DNS_RESOLVER_TYPE = "Microsoft.Network/dnsResolvers";
|
|
218
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dns-resolver-schemas.js","sourceRoot":"","sources":["../../../src/azure-dnsresolver/lib/dns-resolver-schemas.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * API schemas for Azure DNS Private Resolver across all supported versions\n *\n * This file defines the complete API schemas for Microsoft.Network/dnsResolvers\n * across all supported API versions. The schemas are used by the VersionedAzapiResource\n * framework for validation, transformation, and version management.\n */\n\nimport {\n  ApiSchema,\n  PropertyDefinition,\n  PropertyType,\n  ValidationRuleType,\n  VersionConfig,\n  VersionSupportLevel,\n} from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n// =============================================================================\n// COMMON PROPERTY DEFINITIONS\n// =============================================================================\n\n/**\n * Common property definitions shared across all DNS Resolver versions\n */\nconst COMMON_PROPERTIES: { [key: string]: PropertyDefinition } = {\n  location: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description:\n      \"The Azure region where the DNS Resolver will be created. DNS Resolvers are regional resources.\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"Location is required for DNS Resolvers\",\n      },\n    ],\n  },\n  tags: {\n    dataType: PropertyType.OBJECT,\n    required: false,\n    defaultValue: {},\n    description:\n      \"A dictionary of tags to apply to the DNS Resolver for organizational, billing, or other purposes\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.OBJECT,\n        message: \"Tags must be an object with string key-value pairs\",\n      },\n    ],\n  },\n  name: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description:\n      \"The name of the DNS Resolver. Must be unique within the resource group.\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"DNS Resolver name is required\",\n      },\n      {\n        ruleType: ValidationRuleType.PATTERN_MATCH,\n        value: \"^[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?$\",\n        message:\n          \"DNS Resolver name must start and end with alphanumeric characters and can contain hyphens\",\n      },\n      {\n        ruleType: ValidationRuleType.VALUE_RANGE,\n        value: { minLength: 1, maxLength: 80 },\n        message: \"DNS Resolver name must be between 1 and 80 characters\",\n      },\n    ],\n  },\n  virtualNetworkId: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description:\n      \"The resource ID of the virtual network where the DNS Resolver will be deployed. The resolver requires a dedicated subnet.\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"Virtual Network ID is required for DNS Resolvers\",\n      },\n      {\n        ruleType: ValidationRuleType.PATTERN_MATCH,\n        value:\n          \"^/subscriptions/[^/]+/resourceGroups/[^/]+/providers/Microsoft.Network/virtualNetworks/[^/]+$\",\n        message: \"Virtual Network ID must be a valid Azure resource ID\",\n      },\n    ],\n  },\n  ignoreChanges: {\n    dataType: PropertyType.ARRAY,\n    required: false,\n    description: \"Array of property names to ignore during updates\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.ARRAY,\n        message: \"IgnoreChanges must be an array of strings\",\n      },\n    ],\n  },\n};\n\n// =============================================================================\n// READ-ONLY PROPERTY DEFINITIONS\n// =============================================================================\n\n/**\n * Read-only properties that are populated by Azure after creation\n * These properties should not be included in the request body\n */\nconst READ_ONLY_PROPERTIES: { [key: string]: PropertyDefinition } = {\n  dnsResolverState: {\n    dataType: PropertyType.STRING,\n    required: false,\n    description:\n      \"The state of the DNS Resolver. Can be 'Connected' or 'Disconnected' (read-only)\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.STRING,\n        message: \"DnsResolverState must be a string\",\n      },\n    ],\n  },\n  provisioningState: {\n    dataType: PropertyType.STRING,\n    required: false,\n    description:\n      \"The provisioning state of the DNS Resolver resource (read-only)\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.STRING,\n        message: \"ProvisioningState must be a string\",\n      },\n    ],\n  },\n  resourceGuid: {\n    dataType: PropertyType.STRING,\n    required: false,\n    description:\n      \"The unique identifier for the DNS Resolver resource (read-only)\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.STRING,\n        message: \"ResourceGuid must be a string\",\n      },\n    ],\n  },\n};\n\n// =============================================================================\n// VERSION-SPECIFIC SCHEMAS\n// =============================================================================\n\n/**\n * API Schema for DNS Resolver version 2022-07-01\n */\nexport const DNS_RESOLVER_SCHEMA_2022_07_01: ApiSchema = {\n  resourceType: \"Microsoft.Network/dnsResolvers\",\n  version: \"2022-07-01\",\n  properties: {\n    ...COMMON_PROPERTIES,\n    ...READ_ONLY_PROPERTIES,\n  },\n  required: [\"location\", \"name\", \"virtualNetworkId\"],\n  optional: [\"tags\", \"ignoreChanges\"],\n  deprecated: [],\n  transformationRules: {},\n  validationRules: [\n    {\n      property: \"location\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Location is required for DNS Resolvers\",\n        },\n      ],\n    },\n    {\n      property: \"name\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Name is required for DNS Resolvers\",\n        },\n      ],\n    },\n    {\n      property: \"virtualNetworkId\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Virtual Network ID is required for DNS Resolvers\",\n        },\n      ],\n    },\n  ],\n};\n\n// =============================================================================\n// VERSION CONFIGURATIONS\n// =============================================================================\n\n/**\n * Version configuration for DNS Resolver 2022-07-01\n */\nexport const DNS_RESOLVER_VERSION_2022_07_01: VersionConfig = {\n  version: \"2022-07-01\",\n  schema: DNS_RESOLVER_SCHEMA_2022_07_01,\n  supportLevel: VersionSupportLevel.ACTIVE,\n  releaseDate: \"2022-07-01\",\n  deprecationDate: undefined,\n  sunsetDate: undefined,\n  breakingChanges: [],\n  migrationGuide: \"/docs/dns-resolver/migration-2022-07-01\",\n  changeLog: [\n    {\n      changeType: \"added\",\n      description:\n        \"Stable release of DNS Resolver API with support for hybrid DNS scenarios and conditional forwarding\",\n      breaking: false,\n    },\n  ],\n};\n\n/**\n * All supported DNS Resolver versions for registration\n */\nexport const ALL_DNS_RESOLVER_VERSIONS: VersionConfig[] = [\n  DNS_RESOLVER_VERSION_2022_07_01,\n];\n\n/**\n * Resource type constant\n */\nexport const DNS_RESOLVER_TYPE = \"Microsoft.Network/dnsResolvers\";\n"]}
|