@microsoft/terraform-cdk-constructs 1.0.0 → 1.3.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 +89270 -15866
- package/API.md +103201 -10557
- package/README.md +72 -36
- package/docs/monitoring-guide.md +206 -0
- package/docs/testing.md +84 -1
- package/lib/azure-actiongroup/index.d.ts +1 -0
- package/lib/azure-actiongroup/index.js +18 -0
- package/lib/azure-actiongroup/lib/action-group-schemas.d.ts +24 -0
- package/lib/azure-actiongroup/lib/action-group-schemas.js +201 -0
- package/lib/azure-actiongroup/lib/action-group.d.ts +302 -0
- package/lib/azure-actiongroup/lib/action-group.js +175 -0
- package/lib/azure-actiongroup/lib/index.d.ts +2 -0
- package/lib/azure-actiongroup/lib/index.js +19 -0
- package/lib/azure-actiongroup/test/action-group.integ.d.ts +9 -0
- package/lib/azure-actiongroup/test/action-group.integ.js +79 -0
- package/lib/azure-actiongroup/test/action-group.spec.d.ts +8 -0
- package/lib/azure-actiongroup/test/action-group.spec.js +602 -0
- package/lib/azure-activitylogalert/index.d.ts +1 -0
- package/lib/azure-activitylogalert/index.js +18 -0
- package/lib/azure-activitylogalert/lib/activity-log-alert-schemas.d.ts +24 -0
- package/lib/azure-activitylogalert/lib/activity-log-alert-schemas.js +182 -0
- package/lib/azure-activitylogalert/lib/activity-log-alert.d.ts +226 -0
- package/lib/azure-activitylogalert/lib/activity-log-alert.js +186 -0
- package/lib/azure-activitylogalert/lib/index.d.ts +2 -0
- package/lib/azure-activitylogalert/lib/index.js +19 -0
- package/lib/azure-activitylogalert/test/activity-log-alert.integ.d.ts +9 -0
- package/lib/azure-activitylogalert/test/activity-log-alert.integ.js +98 -0
- package/lib/azure-activitylogalert/test/activity-log-alert.spec.d.ts +9 -0
- package/lib/azure-activitylogalert/test/activity-log-alert.spec.js +1101 -0
- package/lib/azure-aks/index.d.ts +1 -0
- package/lib/azure-aks/index.js +18 -0
- package/lib/azure-aks/lib/aks-cluster-schemas.d.ts +505 -0
- package/lib/azure-aks/lib/aks-cluster-schemas.js +572 -0
- package/lib/azure-aks/lib/aks-cluster.d.ts +386 -0
- package/lib/azure-aks/lib/aks-cluster.js +466 -0
- package/lib/azure-aks/lib/index.d.ts +2 -0
- package/lib/azure-aks/lib/index.js +19 -0
- package/lib/azure-aks/test/aks-cluster.integ.d.ts +9 -0
- package/lib/azure-aks/test/aks-cluster.integ.js +260 -0
- package/lib/azure-aks/test/aks-cluster.spec.d.ts +8 -0
- package/lib/azure-aks/test/aks-cluster.spec.js +1396 -0
- package/lib/azure-diagnosticsettings/index.d.ts +1 -0
- package/lib/azure-diagnosticsettings/index.js +18 -0
- package/lib/azure-diagnosticsettings/lib/diagnostic-settings-schemas.d.ts +50 -0
- package/lib/azure-diagnosticsettings/lib/diagnostic-settings-schemas.js +207 -0
- package/lib/azure-diagnosticsettings/lib/diagnostic-settings.d.ts +183 -0
- package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +174 -0
- package/lib/azure-diagnosticsettings/lib/index.d.ts +2 -0
- package/lib/azure-diagnosticsettings/lib/index.js +19 -0
- package/lib/azure-diagnosticsettings/test/diagnostic-settings.spec.d.ts +8 -0
- package/lib/azure-diagnosticsettings/test/diagnostic-settings.spec.js +432 -0
- 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 +1 -0
- package/lib/azure-metricalert/index.js +18 -0
- package/lib/azure-metricalert/lib/index.d.ts +2 -0
- package/lib/azure-metricalert/lib/index.js +19 -0
- package/lib/azure-metricalert/lib/metric-alert-schemas.d.ts +24 -0
- package/lib/azure-metricalert/lib/metric-alert-schemas.js +242 -0
- package/lib/azure-metricalert/lib/metric-alert.d.ts +334 -0
- package/lib/azure-metricalert/lib/metric-alert.js +226 -0
- package/lib/azure-metricalert/test/metric-alert.integ.d.ts +9 -0
- package/lib/azure-metricalert/test/metric-alert.integ.js +123 -0
- package/lib/azure-metricalert/test/metric-alert.spec.d.ts +9 -0
- package/lib/azure-metricalert/test/metric-alert.spec.js +1266 -0
- package/lib/azure-networkinterface/index.d.ts +1 -0
- package/lib/azure-networkinterface/index.js +18 -0
- package/lib/azure-networkinterface/lib/index.d.ts +2 -0
- package/lib/azure-networkinterface/lib/index.js +19 -0
- package/lib/azure-networkinterface/lib/network-interface-schemas.d.ts +32 -0
- package/lib/azure-networkinterface/lib/network-interface-schemas.js +222 -0
- package/lib/azure-networkinterface/lib/network-interface.d.ts +260 -0
- package/lib/azure-networkinterface/lib/network-interface.js +213 -0
- package/lib/azure-networkinterface/test/network-interface.integ.d.ts +9 -0
- package/lib/azure-networkinterface/test/network-interface.integ.js +116 -0
- package/lib/azure-networkinterface/test/network-interface.spec.d.ts +8 -0
- package/lib/azure-networkinterface/test/network-interface.spec.js +655 -0
- package/lib/azure-networksecuritygroup/index.d.ts +1 -0
- package/lib/azure-networksecuritygroup/index.js +18 -0
- package/lib/azure-networksecuritygroup/lib/index.d.ts +2 -0
- package/lib/azure-networksecuritygroup/lib/index.js +19 -0
- package/lib/azure-networksecuritygroup/lib/network-security-group-schemas.d.ts +32 -0
- package/lib/azure-networksecuritygroup/lib/network-security-group-schemas.js +198 -0
- package/lib/azure-networksecuritygroup/lib/network-security-group.d.ts +259 -0
- package/lib/azure-networksecuritygroup/lib/network-security-group.js +226 -0
- package/lib/azure-networksecuritygroup/test/network-security-group.integ.d.ts +9 -0
- package/lib/azure-networksecuritygroup/test/network-security-group.integ.js +151 -0
- package/lib/azure-networksecuritygroup/test/network-security-group.spec.d.ts +8 -0
- package/lib/azure-networksecuritygroup/test/network-security-group.spec.js +652 -0
- 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 +342 -0
- package/lib/azure-policyassignment/lib/policy-assignment.js +228 -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 +260 -0
- package/lib/azure-policydefinition/lib/policy-definition.js +199 -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 +596 -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 +1 -0
- package/lib/azure-publicipaddress/index.js +18 -0
- package/lib/azure-publicipaddress/lib/index.d.ts +2 -0
- package/lib/azure-publicipaddress/lib/index.js +19 -0
- package/lib/azure-publicipaddress/lib/public-ip-address-schemas.d.ts +32 -0
- package/lib/azure-publicipaddress/lib/public-ip-address-schemas.js +227 -0
- package/lib/azure-publicipaddress/lib/public-ip-address.d.ts +247 -0
- package/lib/azure-publicipaddress/lib/public-ip-address.js +245 -0
- package/lib/azure-publicipaddress/test/public-ip-address.integ.d.ts +9 -0
- package/lib/azure-publicipaddress/test/public-ip-address.integ.js +75 -0
- package/lib/azure-publicipaddress/test/public-ip-address.spec.d.ts +15 -0
- package/lib/azure-publicipaddress/test/public-ip-address.spec.js +498 -0
- 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.integ.js +23 -11
- 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-schemas.d.ts +98 -0
- package/lib/azure-storageaccount/lib/storage-account-schemas.js +1 -1
- package/lib/azure-storageaccount/lib/storage-account.d.ts +40 -8
- package/lib/azure-storageaccount/lib/storage-account.js +145 -23
- package/lib/azure-storageaccount/test/storage-account.integ.js +91 -12
- package/lib/azure-subnet/index.d.ts +1 -0
- package/lib/azure-subnet/index.js +18 -0
- package/lib/azure-subnet/lib/index.d.ts +2 -0
- package/lib/azure-subnet/lib/index.js +19 -0
- package/lib/azure-subnet/lib/subnet-schemas.d.ts +32 -0
- package/lib/azure-subnet/lib/subnet-schemas.js +237 -0
- package/lib/azure-subnet/lib/subnet.d.ts +274 -0
- package/lib/azure-subnet/lib/subnet.js +235 -0
- package/lib/azure-subnet/test/subnet.integ.d.ts +11 -0
- package/lib/azure-subnet/test/subnet.integ.js +92 -0
- package/lib/azure-subnet/test/subnet.spec.d.ts +8 -0
- package/lib/azure-subnet/test/subnet.spec.js +395 -0
- package/lib/azure-virtualmachine/index.d.ts +1 -0
- package/lib/azure-virtualmachine/index.js +18 -0
- package/lib/azure-virtualmachine/lib/index.d.ts +2 -0
- package/lib/azure-virtualmachine/lib/index.js +19 -0
- package/lib/azure-virtualmachine/lib/virtual-machine-schemas.d.ts +327 -0
- package/lib/azure-virtualmachine/lib/virtual-machine-schemas.js +544 -0
- package/lib/azure-virtualmachine/lib/virtual-machine.d.ts +368 -0
- package/lib/azure-virtualmachine/lib/virtual-machine.js +441 -0
- package/lib/azure-virtualmachine/test/virtual-machine.integ.d.ts +9 -0
- package/lib/azure-virtualmachine/test/virtual-machine.integ.js +220 -0
- package/lib/azure-virtualmachine/test/virtual-machine.spec.d.ts +9 -0
- package/lib/azure-virtualmachine/test/virtual-machine.spec.js +1032 -0
- package/lib/azure-virtualnetwork/index.d.ts +1 -0
- package/lib/azure-virtualnetwork/index.js +18 -0
- package/lib/azure-virtualnetwork/lib/index.d.ts +2 -0
- package/lib/azure-virtualnetwork/lib/index.js +19 -0
- package/lib/azure-virtualnetwork/lib/virtual-network-schemas.d.ts +32 -0
- package/lib/azure-virtualnetwork/lib/virtual-network-schemas.js +236 -0
- package/lib/azure-virtualnetwork/lib/virtual-network.d.ts +204 -0
- package/lib/azure-virtualnetwork/lib/virtual-network.js +224 -0
- package/lib/azure-virtualnetwork/test/virtual-network.integ.d.ts +9 -0
- package/lib/azure-virtualnetwork/test/virtual-network.integ.js +91 -0
- package/lib/azure-virtualnetwork/test/virtual-network.spec.d.ts +8 -0
- package/lib/azure-virtualnetwork/test/virtual-network.spec.js +398 -0
- 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 +1 -0
- package/lib/azure-vmss/index.js +18 -0
- package/lib/azure-vmss/lib/index.d.ts +2 -0
- package/lib/azure-vmss/lib/index.js +19 -0
- package/lib/azure-vmss/lib/virtual-machine-scale-set.d.ts +250 -0
- package/lib/azure-vmss/lib/virtual-machine-scale-set.js +479 -0
- package/lib/azure-vmss/lib/vmss-schemas.d.ts +472 -0
- package/lib/azure-vmss/lib/vmss-schemas.js +444 -0
- package/lib/azure-vmss/test/virtual-machine-scale-set.integ.d.ts +15 -0
- package/lib/azure-vmss/test/virtual-machine-scale-set.integ.js +261 -0
- package/lib/azure-vmss/test/virtual-machine-scale-set.spec.d.ts +8 -0
- package/lib/azure-vmss/test/virtual-machine-scale-set.spec.js +997 -0
- 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 +268 -48
- package/lib/core-azure/lib/azapi/azapi-resource.js +411 -136
- 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.d.ts +33 -21
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +69 -27
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.d.ts +134 -120
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +209 -59
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-action/index.d.ts +141 -128
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-action/index.js +183 -36
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-id/index.d.ts +55 -43
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-id/index.js +94 -26
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-list/index.d.ts +129 -116
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-list/index.js +155 -32
- package/lib/core-azure/lib/azapi/providers-azapi/data-plane-resource/index.d.ts +187 -174
- package/lib/core-azure/lib/azapi/providers-azapi/data-plane-resource/index.js +267 -48
- package/lib/core-azure/lib/azapi/providers-azapi/index.d.ts +10 -10
- package/lib/core-azure/lib/azapi/providers-azapi/index.js +1 -1
- package/lib/core-azure/lib/azapi/providers-azapi/lazy-index.d.ts +0 -0
- package/lib/core-azure/lib/azapi/providers-azapi/lazy-index.js +13 -0
- package/lib/core-azure/lib/azapi/providers-azapi/provider/index.d.ts +174 -162
- package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +278 -16
- package/lib/core-azure/lib/azapi/providers-azapi/resource/index.d.ts +239 -225
- package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +360 -76
- package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.d.ts +163 -150
- package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +221 -46
- package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.d.ts +162 -149
- package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +249 -50
- 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 +13 -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 +56 -0
- package/lib/index.js +59 -2
- package/lib/testing/index.d.ts +92 -2
- package/lib/testing/index.js +258 -18
- package/lib/testing/lib/cleanup.d.ts +230 -0
- package/lib/testing/lib/cleanup.js +338 -0
- package/lib/testing/lib/metadata.d.ts +151 -0
- package/lib/testing/lib/metadata.js +183 -0
- package/lib/testing/lib/naming.d.ts +96 -0
- package/lib/testing/lib/naming.js +336 -0
- package/node_modules/uuid/LICENSE.md +9 -0
- package/node_modules/uuid/README.md +510 -0
- package/node_modules/uuid/dist/cjs/index.d.ts +15 -0
- package/node_modules/uuid/dist/cjs/index.js +31 -0
- package/node_modules/uuid/dist/cjs/max.d.ts +2 -0
- package/node_modules/uuid/dist/cjs/max.js +3 -0
- package/node_modules/uuid/dist/cjs/md5.d.ts +4 -0
- package/node_modules/uuid/dist/cjs/md5.js +13 -0
- package/node_modules/uuid/dist/cjs/native.d.ts +6 -0
- package/node_modules/uuid/dist/cjs/native.js +4 -0
- package/node_modules/uuid/dist/cjs/nil.d.ts +2 -0
- package/node_modules/uuid/dist/cjs/nil.js +3 -0
- package/node_modules/uuid/dist/cjs/package.json +1 -0
- package/node_modules/uuid/dist/cjs/parse.d.ts +2 -0
- package/node_modules/uuid/dist/cjs/parse.js +11 -0
- package/node_modules/uuid/dist/cjs/regex.d.ts +2 -0
- package/node_modules/uuid/dist/cjs/regex.js +3 -0
- package/node_modules/uuid/dist/cjs/rng.d.ts +1 -0
- package/node_modules/uuid/dist/cjs/rng.js +13 -0
- package/node_modules/uuid/dist/cjs/sha1.d.ts +4 -0
- package/node_modules/uuid/dist/cjs/sha1.js +13 -0
- package/node_modules/uuid/dist/cjs/stringify.d.ts +3 -0
- package/node_modules/uuid/dist/cjs/stringify.js +39 -0
- package/node_modules/uuid/dist/cjs/types.d.ts +21 -0
- package/node_modules/uuid/dist/cjs/types.js +2 -0
- package/node_modules/uuid/dist/cjs/uuid-bin.d.ts +1 -0
- package/node_modules/uuid/dist/cjs/uuid-bin.js +72 -0
- package/node_modules/uuid/dist/cjs/v1.d.ts +11 -0
- package/node_modules/uuid/dist/cjs/v1.js +87 -0
- package/node_modules/uuid/dist/cjs/v1ToV6.d.ts +2 -0
- package/node_modules/uuid/dist/cjs/v1ToV6.js +13 -0
- package/node_modules/uuid/dist/cjs/v3.d.ts +9 -0
- package/node_modules/uuid/dist/cjs/v3.js +14 -0
- package/node_modules/uuid/dist/cjs/v35.d.ts +7 -0
- package/node_modules/uuid/dist/cjs/v35.js +41 -0
- package/node_modules/uuid/dist/cjs/v4.d.ts +4 -0
- package/node_modules/uuid/dist/cjs/v4.js +29 -0
- package/node_modules/uuid/dist/cjs/v5.d.ts +9 -0
- package/node_modules/uuid/dist/cjs/v5.js +14 -0
- package/node_modules/uuid/dist/cjs/v6.d.ts +4 -0
- package/node_modules/uuid/dist/cjs/v6.js +19 -0
- package/node_modules/uuid/dist/cjs/v6ToV1.d.ts +2 -0
- package/node_modules/uuid/dist/cjs/v6ToV1.js +13 -0
- package/node_modules/uuid/dist/cjs/v7.d.ts +9 -0
- package/node_modules/uuid/dist/cjs/v7.js +69 -0
- package/node_modules/uuid/dist/cjs/validate.d.ts +2 -0
- package/node_modules/uuid/dist/cjs/validate.js +7 -0
- package/node_modules/uuid/dist/cjs/version.d.ts +2 -0
- package/node_modules/uuid/dist/cjs/version.js +10 -0
- package/node_modules/uuid/dist/cjs-browser/index.d.ts +15 -0
- package/node_modules/uuid/dist/cjs-browser/index.js +31 -0
- package/node_modules/uuid/dist/cjs-browser/max.d.ts +2 -0
- package/node_modules/uuid/dist/cjs-browser/max.js +3 -0
- package/node_modules/uuid/dist/cjs-browser/md5.d.ts +2 -0
- package/node_modules/uuid/dist/cjs-browser/md5.js +137 -0
- package/node_modules/uuid/dist/cjs-browser/native.d.ts +4 -0
- package/node_modules/uuid/dist/cjs-browser/native.js +4 -0
- package/node_modules/uuid/dist/cjs-browser/nil.d.ts +2 -0
- package/node_modules/uuid/dist/cjs-browser/nil.js +3 -0
- package/node_modules/uuid/dist/cjs-browser/package.json +1 -0
- package/node_modules/uuid/dist/cjs-browser/parse.d.ts +2 -0
- package/node_modules/uuid/dist/cjs-browser/parse.js +11 -0
- package/node_modules/uuid/dist/cjs-browser/regex.d.ts +2 -0
- package/node_modules/uuid/dist/cjs-browser/regex.js +3 -0
- package/node_modules/uuid/dist/cjs-browser/rng.d.ts +1 -0
- package/node_modules/uuid/dist/cjs-browser/rng.js +14 -0
- package/node_modules/uuid/dist/cjs-browser/sha1.d.ts +2 -0
- package/node_modules/uuid/dist/cjs-browser/sha1.js +72 -0
- package/node_modules/uuid/dist/cjs-browser/stringify.d.ts +3 -0
- package/node_modules/uuid/dist/cjs-browser/stringify.js +39 -0
- package/node_modules/uuid/dist/cjs-browser/types.d.ts +21 -0
- package/node_modules/uuid/dist/cjs-browser/types.js +2 -0
- package/node_modules/uuid/dist/cjs-browser/uuid-bin.d.ts +1 -0
- package/node_modules/uuid/dist/cjs-browser/uuid-bin.js +72 -0
- package/node_modules/uuid/dist/cjs-browser/v1.d.ts +11 -0
- package/node_modules/uuid/dist/cjs-browser/v1.js +87 -0
- package/node_modules/uuid/dist/cjs-browser/v1ToV6.d.ts +2 -0
- package/node_modules/uuid/dist/cjs-browser/v1ToV6.js +13 -0
- package/node_modules/uuid/dist/cjs-browser/v3.d.ts +9 -0
- package/node_modules/uuid/dist/cjs-browser/v3.js +14 -0
- package/node_modules/uuid/dist/cjs-browser/v35.d.ts +7 -0
- package/node_modules/uuid/dist/cjs-browser/v35.js +41 -0
- package/node_modules/uuid/dist/cjs-browser/v4.d.ts +4 -0
- package/node_modules/uuid/dist/cjs-browser/v4.js +29 -0
- package/node_modules/uuid/dist/cjs-browser/v5.d.ts +9 -0
- package/node_modules/uuid/dist/cjs-browser/v5.js +14 -0
- package/node_modules/uuid/dist/cjs-browser/v6.d.ts +4 -0
- package/node_modules/uuid/dist/cjs-browser/v6.js +19 -0
- package/node_modules/uuid/dist/cjs-browser/v6ToV1.d.ts +2 -0
- package/node_modules/uuid/dist/cjs-browser/v6ToV1.js +13 -0
- package/node_modules/uuid/dist/cjs-browser/v7.d.ts +9 -0
- package/node_modules/uuid/dist/cjs-browser/v7.js +69 -0
- package/node_modules/uuid/dist/cjs-browser/validate.d.ts +2 -0
- package/node_modules/uuid/dist/cjs-browser/validate.js +7 -0
- package/node_modules/uuid/dist/cjs-browser/version.d.ts +2 -0
- package/node_modules/uuid/dist/cjs-browser/version.js +10 -0
- package/node_modules/uuid/dist/esm/bin/uuid +2 -0
- package/node_modules/uuid/dist/esm/index.d.ts +15 -0
- package/node_modules/uuid/dist/esm/index.js +14 -0
- package/node_modules/uuid/dist/esm/max.d.ts +2 -0
- package/node_modules/uuid/dist/esm/max.js +1 -0
- package/node_modules/uuid/dist/esm/md5.d.ts +4 -0
- package/node_modules/uuid/dist/esm/md5.js +11 -0
- package/node_modules/uuid/dist/esm/native.d.ts +6 -0
- package/node_modules/uuid/dist/esm/native.js +2 -0
- package/node_modules/uuid/dist/esm/nil.d.ts +2 -0
- package/node_modules/uuid/dist/esm/nil.js +1 -0
- package/node_modules/uuid/dist/esm/parse.d.ts +2 -0
- package/node_modules/uuid/dist/esm/parse.js +9 -0
- package/node_modules/uuid/dist/esm/regex.d.ts +2 -0
- package/node_modules/uuid/dist/esm/regex.js +1 -0
- package/node_modules/uuid/dist/esm/rng.d.ts +1 -0
- package/node_modules/uuid/dist/esm/rng.js +10 -0
- package/node_modules/uuid/dist/esm/sha1.d.ts +4 -0
- package/node_modules/uuid/dist/esm/sha1.js +11 -0
- package/node_modules/uuid/dist/esm/stringify.d.ts +3 -0
- package/node_modules/uuid/dist/esm/stringify.js +35 -0
- package/node_modules/uuid/dist/esm/types.d.ts +21 -0
- package/node_modules/uuid/dist/esm/types.js +1 -0
- package/node_modules/uuid/dist/esm/uuid-bin.d.ts +1 -0
- package/node_modules/uuid/dist/esm/uuid-bin.js +70 -0
- package/node_modules/uuid/dist/esm/v1.d.ts +11 -0
- package/node_modules/uuid/dist/esm/v1.js +83 -0
- package/node_modules/uuid/dist/esm/v1ToV6.d.ts +2 -0
- package/node_modules/uuid/dist/esm/v1ToV6.js +10 -0
- package/node_modules/uuid/dist/esm/v3.d.ts +9 -0
- package/node_modules/uuid/dist/esm/v3.js +9 -0
- package/node_modules/uuid/dist/esm/v35.d.ts +7 -0
- package/node_modules/uuid/dist/esm/v35.js +36 -0
- package/node_modules/uuid/dist/esm/v4.d.ts +4 -0
- package/node_modules/uuid/dist/esm/v4.js +27 -0
- package/node_modules/uuid/dist/esm/v5.d.ts +9 -0
- package/node_modules/uuid/dist/esm/v5.js +9 -0
- package/node_modules/uuid/dist/esm/v6.d.ts +4 -0
- package/node_modules/uuid/dist/esm/v6.js +17 -0
- package/node_modules/uuid/dist/esm/v6ToV1.d.ts +2 -0
- package/node_modules/uuid/dist/esm/v6ToV1.js +10 -0
- package/node_modules/uuid/dist/esm/v7.d.ts +9 -0
- package/node_modules/uuid/dist/esm/v7.js +65 -0
- package/node_modules/uuid/dist/esm/validate.d.ts +2 -0
- package/node_modules/uuid/dist/esm/validate.js +5 -0
- package/node_modules/uuid/dist/esm/version.d.ts +2 -0
- package/node_modules/uuid/dist/esm/version.js +8 -0
- package/node_modules/uuid/dist/esm-browser/index.d.ts +15 -0
- package/node_modules/uuid/dist/esm-browser/index.js +14 -0
- package/node_modules/uuid/dist/esm-browser/max.d.ts +2 -0
- package/node_modules/uuid/dist/esm-browser/max.js +1 -0
- package/node_modules/uuid/dist/esm-browser/md5.d.ts +2 -0
- package/node_modules/uuid/dist/esm-browser/md5.js +135 -0
- package/node_modules/uuid/dist/esm-browser/native.d.ts +4 -0
- package/node_modules/uuid/dist/esm-browser/native.js +2 -0
- package/node_modules/uuid/dist/esm-browser/nil.d.ts +2 -0
- package/node_modules/uuid/dist/esm-browser/nil.js +1 -0
- package/node_modules/uuid/dist/esm-browser/parse.d.ts +2 -0
- package/node_modules/uuid/dist/esm-browser/parse.js +9 -0
- package/node_modules/uuid/dist/esm-browser/regex.d.ts +2 -0
- package/node_modules/uuid/dist/esm-browser/regex.js +1 -0
- package/node_modules/uuid/dist/esm-browser/rng.d.ts +1 -0
- package/node_modules/uuid/dist/esm-browser/rng.js +11 -0
- package/node_modules/uuid/dist/esm-browser/sha1.d.ts +2 -0
- package/node_modules/uuid/dist/esm-browser/sha1.js +70 -0
- package/node_modules/uuid/dist/esm-browser/stringify.d.ts +3 -0
- package/node_modules/uuid/dist/esm-browser/stringify.js +35 -0
- package/node_modules/uuid/dist/esm-browser/types.d.ts +21 -0
- package/node_modules/uuid/dist/esm-browser/types.js +1 -0
- package/node_modules/uuid/dist/esm-browser/uuid-bin.d.ts +1 -0
- package/node_modules/uuid/dist/esm-browser/uuid-bin.js +70 -0
- package/node_modules/uuid/dist/esm-browser/v1.d.ts +11 -0
- package/node_modules/uuid/dist/esm-browser/v1.js +83 -0
- package/node_modules/uuid/dist/esm-browser/v1ToV6.d.ts +2 -0
- package/node_modules/uuid/dist/esm-browser/v1ToV6.js +10 -0
- package/node_modules/uuid/dist/esm-browser/v3.d.ts +9 -0
- package/node_modules/uuid/dist/esm-browser/v3.js +9 -0
- package/node_modules/uuid/dist/esm-browser/v35.d.ts +7 -0
- package/node_modules/uuid/dist/esm-browser/v35.js +36 -0
- package/node_modules/uuid/dist/esm-browser/v4.d.ts +4 -0
- package/node_modules/uuid/dist/esm-browser/v4.js +27 -0
- package/node_modules/uuid/dist/esm-browser/v5.d.ts +9 -0
- package/node_modules/uuid/dist/esm-browser/v5.js +9 -0
- package/node_modules/uuid/dist/esm-browser/v6.d.ts +4 -0
- package/node_modules/uuid/dist/esm-browser/v6.js +17 -0
- package/node_modules/uuid/dist/esm-browser/v6ToV1.d.ts +2 -0
- package/node_modules/uuid/dist/esm-browser/v6ToV1.js +10 -0
- package/node_modules/uuid/dist/esm-browser/v7.d.ts +9 -0
- package/node_modules/uuid/dist/esm-browser/v7.js +65 -0
- package/node_modules/uuid/dist/esm-browser/validate.d.ts +2 -0
- package/node_modules/uuid/dist/esm-browser/validate.js +5 -0
- package/node_modules/uuid/dist/esm-browser/version.d.ts +2 -0
- package/node_modules/uuid/dist/esm-browser/version.js +8 -0
- package/node_modules/uuid/package.json +132 -0
- package/package.json +17 -12
- package/scripts/cleanup-test-resources.ts +387 -0
- package/scripts/generate-index.js +25 -8
|
@@ -0,0 +1,350 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Comprehensive tests for the DnsForwardingRuleset implementation
|
|
4
|
+
*
|
|
5
|
+
* This test suite validates the DnsForwardingRuleset class using the
|
|
6
|
+
* AzapiResource framework. Tests cover automatic version resolution,
|
|
7
|
+
* explicit version pinning, schema validation, property transformation,
|
|
8
|
+
* 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 dns_forwarding_ruleset_1 = require("../lib/dns-forwarding-ruleset");
|
|
16
|
+
const dns_forwarding_ruleset_schemas_1 = require("../lib/dns-forwarding-ruleset-schemas");
|
|
17
|
+
describe("DnsForwardingRuleset - Implementation", () => {
|
|
18
|
+
let app;
|
|
19
|
+
let stack;
|
|
20
|
+
let manager;
|
|
21
|
+
const mockOutboundEndpointId = "/subscriptions/12345678-1234-1234-1234-123456789012/resourceGroups/test-rg/providers/Microsoft.Network/dnsResolvers/test-resolver/outboundEndpoints/test-endpoint";
|
|
22
|
+
const mockResourceGroupId = "/subscriptions/12345678-1234-1234-1234-123456789012/resourceGroups/test-rg";
|
|
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(dns_forwarding_ruleset_schemas_1.DNS_FORWARDING_RULESET_TYPE, dns_forwarding_ruleset_schemas_1.ALL_DNS_FORWARDING_RULESET_VERSIONS);
|
|
30
|
+
}
|
|
31
|
+
catch (error) {
|
|
32
|
+
// Ignore if already registered
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
describe("Constructor and Basic Properties", () => {
|
|
36
|
+
it("should create DNS Forwarding Ruleset with automatic latest version resolution", () => {
|
|
37
|
+
const props = {
|
|
38
|
+
name: "my-ruleset",
|
|
39
|
+
location: "eastus",
|
|
40
|
+
resourceGroupId: mockResourceGroupId,
|
|
41
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
42
|
+
};
|
|
43
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", props);
|
|
44
|
+
expect(ruleset).toBeInstanceOf(dns_forwarding_ruleset_1.DnsForwardingRuleset);
|
|
45
|
+
expect(ruleset.resolvedApiVersion).toBe("2022-07-01");
|
|
46
|
+
expect(ruleset.props).toBe(props);
|
|
47
|
+
});
|
|
48
|
+
it("should create DNS Forwarding Ruleset with explicit version pinning", () => {
|
|
49
|
+
const props = {
|
|
50
|
+
name: "my-ruleset",
|
|
51
|
+
location: "eastus",
|
|
52
|
+
resourceGroupId: mockResourceGroupId,
|
|
53
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
54
|
+
apiVersion: "2022-07-01",
|
|
55
|
+
tags: { environment: "test" },
|
|
56
|
+
};
|
|
57
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", props);
|
|
58
|
+
expect(ruleset.resolvedApiVersion).toBe("2022-07-01");
|
|
59
|
+
expect(ruleset.tags).toEqual({ environment: "test" });
|
|
60
|
+
});
|
|
61
|
+
it("should use location from props", () => {
|
|
62
|
+
const props = {
|
|
63
|
+
name: "my-ruleset",
|
|
64
|
+
location: "westus",
|
|
65
|
+
resourceGroupId: mockResourceGroupId,
|
|
66
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
67
|
+
};
|
|
68
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", props);
|
|
69
|
+
expect(ruleset.location).toBe("westus");
|
|
70
|
+
});
|
|
71
|
+
it("should create DNS Forwarding Ruleset with multiple outbound endpoints", () => {
|
|
72
|
+
const props = {
|
|
73
|
+
name: "my-ruleset",
|
|
74
|
+
location: "eastus",
|
|
75
|
+
resourceGroupId: mockResourceGroupId,
|
|
76
|
+
dnsResolverOutboundEndpointIds: [
|
|
77
|
+
mockOutboundEndpointId,
|
|
78
|
+
`${mockOutboundEndpointId}-2`,
|
|
79
|
+
],
|
|
80
|
+
};
|
|
81
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", props);
|
|
82
|
+
expect(ruleset).toBeDefined();
|
|
83
|
+
expect(ruleset.props.dnsResolverOutboundEndpointIds).toHaveLength(2);
|
|
84
|
+
});
|
|
85
|
+
});
|
|
86
|
+
describe("Framework Integration", () => {
|
|
87
|
+
it("should resolve latest API version automatically", () => {
|
|
88
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
89
|
+
name: "my-ruleset",
|
|
90
|
+
location: "eastus",
|
|
91
|
+
resourceGroupId: mockResourceGroupId,
|
|
92
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
93
|
+
});
|
|
94
|
+
expect(ruleset.resolvedApiVersion).toBe("2022-07-01");
|
|
95
|
+
expect(ruleset.latestVersion()).toBe("2022-07-01");
|
|
96
|
+
});
|
|
97
|
+
it("should provide version configuration", () => {
|
|
98
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
99
|
+
name: "my-ruleset",
|
|
100
|
+
location: "eastus",
|
|
101
|
+
resourceGroupId: mockResourceGroupId,
|
|
102
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
103
|
+
});
|
|
104
|
+
expect(ruleset.versionConfig).toBeDefined();
|
|
105
|
+
expect(ruleset.versionConfig.version).toBe("2022-07-01");
|
|
106
|
+
expect(ruleset.versionConfig.supportLevel).toBe(version_interfaces_1.VersionSupportLevel.ACTIVE);
|
|
107
|
+
});
|
|
108
|
+
it("should provide supported versions", () => {
|
|
109
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
110
|
+
name: "my-ruleset",
|
|
111
|
+
location: "eastus",
|
|
112
|
+
resourceGroupId: mockResourceGroupId,
|
|
113
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
114
|
+
});
|
|
115
|
+
const versions = ruleset.supportedVersions();
|
|
116
|
+
expect(versions).toContain("2022-07-01");
|
|
117
|
+
expect(versions.length).toBeGreaterThan(0);
|
|
118
|
+
});
|
|
119
|
+
});
|
|
120
|
+
describe("Public Methods - DNS Forwarding Ruleset Properties", () => {
|
|
121
|
+
it("should provide provisioning state", () => {
|
|
122
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
123
|
+
name: "my-ruleset",
|
|
124
|
+
location: "eastus",
|
|
125
|
+
resourceGroupId: mockResourceGroupId,
|
|
126
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
127
|
+
});
|
|
128
|
+
expect(ruleset.provisioningState).toBeDefined();
|
|
129
|
+
expect(typeof ruleset.provisioningState).toBe("string");
|
|
130
|
+
});
|
|
131
|
+
it("should provide resource GUID", () => {
|
|
132
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
133
|
+
name: "my-ruleset",
|
|
134
|
+
location: "eastus",
|
|
135
|
+
resourceGroupId: mockResourceGroupId,
|
|
136
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
137
|
+
});
|
|
138
|
+
expect(ruleset.resourceGuid).toBeDefined();
|
|
139
|
+
expect(typeof ruleset.resourceGuid).toBe("string");
|
|
140
|
+
});
|
|
141
|
+
});
|
|
142
|
+
describe("Tag Management", () => {
|
|
143
|
+
it("should allow adding tags", () => {
|
|
144
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
145
|
+
name: "my-ruleset",
|
|
146
|
+
location: "eastus",
|
|
147
|
+
resourceGroupId: mockResourceGroupId,
|
|
148
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
149
|
+
tags: { initial: "tag" },
|
|
150
|
+
});
|
|
151
|
+
ruleset.addTag("newKey", "newValue");
|
|
152
|
+
expect(ruleset.props.tags).toHaveProperty("newKey", "newValue");
|
|
153
|
+
expect(ruleset.props.tags).toHaveProperty("initial", "tag");
|
|
154
|
+
});
|
|
155
|
+
it("should allow removing tags", () => {
|
|
156
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
157
|
+
name: "my-ruleset",
|
|
158
|
+
location: "eastus",
|
|
159
|
+
resourceGroupId: mockResourceGroupId,
|
|
160
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
161
|
+
tags: { key1: "value1", key2: "value2" },
|
|
162
|
+
});
|
|
163
|
+
ruleset.removeTag("key1");
|
|
164
|
+
expect(ruleset.props.tags).not.toHaveProperty("key1");
|
|
165
|
+
expect(ruleset.props.tags).toHaveProperty("key2", "value2");
|
|
166
|
+
});
|
|
167
|
+
it("should handle adding tags when no initial tags exist", () => {
|
|
168
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
169
|
+
name: "my-ruleset",
|
|
170
|
+
location: "eastus",
|
|
171
|
+
resourceGroupId: mockResourceGroupId,
|
|
172
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
173
|
+
});
|
|
174
|
+
ruleset.addTag("newKey", "newValue");
|
|
175
|
+
expect(ruleset.props.tags).toHaveProperty("newKey", "newValue");
|
|
176
|
+
});
|
|
177
|
+
});
|
|
178
|
+
describe("Outputs", () => {
|
|
179
|
+
it("should create all required outputs", () => {
|
|
180
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
181
|
+
name: "my-ruleset",
|
|
182
|
+
location: "eastus",
|
|
183
|
+
resourceGroupId: mockResourceGroupId,
|
|
184
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
185
|
+
});
|
|
186
|
+
expect(ruleset.idOutput).toBeDefined();
|
|
187
|
+
expect(ruleset.nameOutput).toBeDefined();
|
|
188
|
+
expect(ruleset.locationOutput).toBeDefined();
|
|
189
|
+
expect(ruleset.tagsOutput).toBeDefined();
|
|
190
|
+
expect(ruleset.provisioningStateOutput).toBeDefined();
|
|
191
|
+
expect(ruleset.resourceGuidOutput).toBeDefined();
|
|
192
|
+
});
|
|
193
|
+
it("should have correct logical IDs for outputs", () => {
|
|
194
|
+
new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
195
|
+
name: "my-ruleset",
|
|
196
|
+
location: "eastus",
|
|
197
|
+
resourceGroupId: mockResourceGroupId,
|
|
198
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
199
|
+
});
|
|
200
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
201
|
+
expect(synthesized).toContain('"id"');
|
|
202
|
+
expect(synthesized).toContain('"name"');
|
|
203
|
+
expect(synthesized).toContain('"location"');
|
|
204
|
+
expect(synthesized).toContain('"tags"');
|
|
205
|
+
expect(synthesized).toContain('"provisioning_state"');
|
|
206
|
+
expect(synthesized).toContain('"resource_guid"');
|
|
207
|
+
});
|
|
208
|
+
});
|
|
209
|
+
describe("Ignore Changes Configuration", () => {
|
|
210
|
+
it("should apply ignore changes lifecycle rules", () => {
|
|
211
|
+
new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
212
|
+
name: "my-ruleset",
|
|
213
|
+
location: "eastus",
|
|
214
|
+
resourceGroupId: mockResourceGroupId,
|
|
215
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
216
|
+
ignoreChanges: ["tags"],
|
|
217
|
+
});
|
|
218
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
219
|
+
expect(synthesized).toContain("ignore_changes");
|
|
220
|
+
});
|
|
221
|
+
it("should handle multiple ignore changes properties", () => {
|
|
222
|
+
new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
223
|
+
name: "my-ruleset",
|
|
224
|
+
location: "eastus",
|
|
225
|
+
resourceGroupId: mockResourceGroupId,
|
|
226
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
227
|
+
ignoreChanges: ["tags", "location"],
|
|
228
|
+
});
|
|
229
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
230
|
+
expect(synthesized).toBeDefined();
|
|
231
|
+
});
|
|
232
|
+
});
|
|
233
|
+
describe("CDK Terraform Integration", () => {
|
|
234
|
+
it("should synthesize to valid Terraform configuration", () => {
|
|
235
|
+
new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "SynthTest", {
|
|
236
|
+
name: "my-ruleset",
|
|
237
|
+
location: "eastus",
|
|
238
|
+
resourceGroupId: mockResourceGroupId,
|
|
239
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
240
|
+
tags: { test: "synthesis" },
|
|
241
|
+
});
|
|
242
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
243
|
+
expect(synthesized).toBeDefined();
|
|
244
|
+
const stackConfig = JSON.parse(synthesized);
|
|
245
|
+
expect(stackConfig.resource).toBeDefined();
|
|
246
|
+
});
|
|
247
|
+
it("should generate correct resource type in Terraform", () => {
|
|
248
|
+
new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "SynthTest", {
|
|
249
|
+
name: "my-ruleset",
|
|
250
|
+
location: "eastus",
|
|
251
|
+
resourceGroupId: mockResourceGroupId,
|
|
252
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
253
|
+
});
|
|
254
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
255
|
+
expect(synthesized).toContain("dnsForwardingRulesets");
|
|
256
|
+
expect(synthesized).toContain("2022-07-01");
|
|
257
|
+
});
|
|
258
|
+
it("should include all properties in Terraform body", () => {
|
|
259
|
+
new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "SynthTest", {
|
|
260
|
+
name: "my-ruleset",
|
|
261
|
+
location: "eastus",
|
|
262
|
+
resourceGroupId: mockResourceGroupId,
|
|
263
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
264
|
+
tags: { env: "test" },
|
|
265
|
+
});
|
|
266
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
267
|
+
expect(synthesized).toContain("eastus");
|
|
268
|
+
expect(synthesized).toContain("env");
|
|
269
|
+
expect(synthesized).toContain(mockOutboundEndpointId);
|
|
270
|
+
});
|
|
271
|
+
});
|
|
272
|
+
describe("Resource Identification", () => {
|
|
273
|
+
it("should provide resource ID", () => {
|
|
274
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
275
|
+
name: "my-ruleset",
|
|
276
|
+
location: "eastus",
|
|
277
|
+
resourceGroupId: mockResourceGroupId,
|
|
278
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
279
|
+
});
|
|
280
|
+
expect(ruleset.id).toBeDefined();
|
|
281
|
+
expect(typeof ruleset.id).toBe("string");
|
|
282
|
+
});
|
|
283
|
+
it("should provide resource name from props when specified", () => {
|
|
284
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
285
|
+
name: "my-ruleset",
|
|
286
|
+
location: "eastus",
|
|
287
|
+
resourceGroupId: mockResourceGroupId,
|
|
288
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
289
|
+
});
|
|
290
|
+
expect(ruleset.name).toBe("my-ruleset");
|
|
291
|
+
});
|
|
292
|
+
});
|
|
293
|
+
describe("JSII Compliance", () => {
|
|
294
|
+
it("should have proper return types for all public methods", () => {
|
|
295
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
296
|
+
name: "my-ruleset",
|
|
297
|
+
location: "eastus",
|
|
298
|
+
resourceGroupId: mockResourceGroupId,
|
|
299
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
300
|
+
});
|
|
301
|
+
// All getter methods should return strings for Terraform interpolations
|
|
302
|
+
expect(typeof ruleset.provisioningState).toBe("string");
|
|
303
|
+
expect(typeof ruleset.resourceGuid).toBe("string");
|
|
304
|
+
});
|
|
305
|
+
it("should not use function types in public interface", () => {
|
|
306
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
307
|
+
name: "my-ruleset",
|
|
308
|
+
location: "eastus",
|
|
309
|
+
resourceGroupId: mockResourceGroupId,
|
|
310
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
311
|
+
});
|
|
312
|
+
// Verify methods exist and are callable
|
|
313
|
+
expect(typeof ruleset.addTag).toBe("function");
|
|
314
|
+
expect(typeof ruleset.removeTag).toBe("function");
|
|
315
|
+
// Test that they work correctly
|
|
316
|
+
ruleset.addTag("test", "value");
|
|
317
|
+
expect(ruleset.props.tags).toHaveProperty("test", "value");
|
|
318
|
+
});
|
|
319
|
+
});
|
|
320
|
+
describe("Schema Registration", () => {
|
|
321
|
+
it("should register schemas successfully", () => {
|
|
322
|
+
const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
|
|
323
|
+
name: "my-ruleset",
|
|
324
|
+
location: "eastus",
|
|
325
|
+
resourceGroupId: mockResourceGroupId,
|
|
326
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
327
|
+
});
|
|
328
|
+
// If the ruleset was created successfully, schemas were registered
|
|
329
|
+
expect(ruleset).toBeDefined();
|
|
330
|
+
expect(ruleset.resolvedApiVersion).toBe("2022-07-01");
|
|
331
|
+
});
|
|
332
|
+
it("should handle multiple instantiations without errors", () => {
|
|
333
|
+
new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset1", {
|
|
334
|
+
name: "my-ruleset-1",
|
|
335
|
+
location: "eastus",
|
|
336
|
+
resourceGroupId: mockResourceGroupId,
|
|
337
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
338
|
+
});
|
|
339
|
+
// Second instantiation should not throw an error even if schemas are already registered
|
|
340
|
+
const ruleset2 = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset2", {
|
|
341
|
+
name: "my-ruleset-2",
|
|
342
|
+
location: "eastus",
|
|
343
|
+
resourceGroupId: mockResourceGroupId,
|
|
344
|
+
dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
|
|
345
|
+
});
|
|
346
|
+
expect(ruleset2).toBeDefined();
|
|
347
|
+
});
|
|
348
|
+
});
|
|
349
|
+
});
|
|
350
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG5zLWZvcndhcmRpbmctcnVsZXNldC5zcGVjLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2F6dXJlLWRuc2ZvcndhcmRpbmdydWxlc2V0L3Rlc3QvZG5zLWZvcndhcmRpbmctcnVsZXNldC5zcGVjLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7OztHQU9HOztBQUVILGlDQUFnQztBQUNoQywrQkFBK0I7QUFDL0Isa0dBQTZGO0FBQzdGLDJHQUF5RztBQUN6RywwRUFHdUM7QUFDdkMsMEZBRytDO0FBRS9DLFFBQVEsQ0FBQyx1Q0FBdUMsRUFBRSxHQUFHLEVBQUU7SUFDckQsSUFBSSxHQUFjLENBQUM7SUFDbkIsSUFBSSxLQUEyQixDQUFDO0lBQ2hDLElBQUksT0FBMEIsQ0FBQztJQUUvQixNQUFNLHNCQUFzQixHQUMxQixtS0FBbUssQ0FBQztJQUN0SyxNQUFNLG1CQUFtQixHQUN2Qiw0RUFBNEUsQ0FBQztJQUUvRSxVQUFVLENBQUMsR0FBRyxFQUFFO1FBQ2QsR0FBRyxHQUFHLGVBQU8sQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUNwQixLQUFLLEdBQUcsSUFBSSxLQUFLLENBQUMsY0FBYyxDQUFDLEdBQUcsRUFBRSxXQUFXLENBQUMsQ0FBQztRQUNuRCxPQUFPLEdBQUcsdUNBQWlCLENBQUMsUUFBUSxFQUFFLENBQUM7UUFFdkMsZ0NBQWdDO1FBQ2hDLElBQUksQ0FBQztZQUNILE9BQU8sQ0FBQyxvQkFBb0IsQ0FDMUIsNERBQTJCLEVBQzNCLG9FQUFtQyxDQUNwQyxDQUFDO1FBQ0osQ0FBQztRQUFDLE9BQU8sS0FBSyxFQUFFLENBQUM7WUFDZiwrQkFBK0I7UUFDakMsQ0FBQztJQUNILENBQUMsQ0FBQyxDQUFDO0lBRUgsUUFBUSxDQUFDLGtDQUFrQyxFQUFFLEdBQUcsRUFBRTtRQUNoRCxFQUFFLENBQUMsK0VBQStFLEVBQUUsR0FBRyxFQUFFO1lBQ3ZGLE1BQU0sS0FBSyxHQUE4QjtnQkFDdkMsSUFB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QUU7Z0JBQzlDLElBQUksRUFBRSxjQUFjO2dCQUNwQixRQUFRLEVBQUUsUUFBUTtnQkFDbEIsZUFBZSxFQUFFLG1CQUFtQjtnQkFDcEMsOEJBQThCLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQzthQUN6RCxDQUFDLENBQUM7WUFFSCx3RkFBd0Y7WUFDeEYsTUFBTSxRQUFRLEdBQUcsSUFBSSw2Q0FBb0IsQ0FBQyxLQUFLLEVBQUUsY0FBYyxFQUFFO2dCQUMvRCxJQUFJLEVBQUUsY0FBYztnQkFDcEIsUUFBUSxFQUFFLFFBQVE7Z0JBQ2xCLGVBQWUsRUFBRSxtQkFBbUI7Z0JBQ3BDLDhCQUE4QixFQUFFLENBQUMsc0JBQXNCLENBQUM7YUFDekQsQ0FBQyxDQUFDO1lBRUgsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQ2pDLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29tcHJlaGVuc2l2ZSB0ZXN0cyBmb3IgdGhlIERuc0ZvcndhcmRpbmdSdWxlc2V0IGltcGxlbWVudGF0aW9uXG4gKlxuICogVGhpcyB0ZXN0IHN1aXRlIHZhbGlkYXRlcyB0aGUgRG5zRm9yd2FyZGluZ1J1bGVzZXQgY2xhc3MgdXNpbmcgdGhlXG4gKiBBemFwaVJlc291cmNlIGZyYW1ld29yay4gVGVzdHMgY292ZXIgYXV0b21hdGljIHZlcnNpb24gcmVzb2x1dGlvbixcbiAqIGV4cGxpY2l0IHZlcnNpb24gcGlubmluZywgc2NoZW1hIHZhbGlkYXRpb24sIHByb3BlcnR5IHRyYW5zZm9ybWF0aW9uLFxuICogYW5kIGZ1bGwgYmFja3dhcmQgY29tcGF0aWJpbGl0eS5cbiAqL1xuXG5pbXBvcnQgeyBUZXN0aW5nIH0gZnJvbSBcImNka3RmXCI7XG5pbXBvcnQgKiBhcyBjZGt0ZiBmcm9tIFwiY2RrdGZcIjtcbmltcG9ydCB7IEFwaVZlcnNpb25NYW5hZ2VyIH0gZnJvbSBcIi4uLy4uL2NvcmUtYXp1cmUvbGliL3ZlcnNpb24tbWFuYWdlci9hcGktdmVyc2lvbi1tYW5hZ2VyXCI7XG5pbXBvcnQgeyBWZXJzaW9uU3VwcG9ydExldmVsIH0gZnJvbSBcIi4uLy4uL2NvcmUtYXp1cmUvbGliL3ZlcnNpb24tbWFuYWdlci9pbnRlcmZhY2VzL3ZlcnNpb24taW50ZXJmYWNlc1wiO1xuaW1wb3J0IHtcbiAgRG5zRm9yd2FyZGluZ1J1bGVzZXQsXG4gIERuc0ZvcndhcmRpbmdSdWxlc2V0UHJvcHMsXG59IGZyb20gXCIuLi9saWIvZG5zLWZvcndhcmRpbmctcnVsZXNldFwiO1xuaW1wb3J0IHtcbiAgQUxMX0ROU19GT1JXQVJESU5HX1JVTEVTRVRfVkVSU0lPTlMsXG4gIEROU19GT1JXQVJESU5HX1JVTEVTRVRfVFlQRSxcbn0gZnJvbSBcIi4uL2xpYi9kbnMtZm9yd2FyZGluZy1ydWxlc2V0LXNjaGVtYXNcIjtcblxuZGVzY3JpYmUoXCJEbnNGb3J3YXJkaW5nUnVsZXNldCAtIEltcGxlbWVudGF0aW9uXCIsICgpID0+IHtcbiAgbGV0IGFwcDogY2RrdGYuQXBwO1xuICBsZXQgc3RhY2s6IGNka3RmLlRlcnJhZm9ybVN0YWNrO1xuICBsZXQgbWFuYWdlcjogQXBpVmVyc2lvbk1hbmFnZXI7XG5cbiAgY29uc3QgbW9ja091dGJvdW5kRW5kcG9pbnRJZCA9XG4gICAgXCIvc3Vic2NyaXB0aW9ucy8xMjM0NTY3OC0xMjM0LTEyMzQtMTIzNC0xMjM0NTY3ODkwMTIvcmVzb3VyY2VHcm91cHMvdGVzdC1yZy9wcm92aWRlcnMvTWljcm9zb2Z0Lk5ldHdvcmsvZG5zUmVzb2x2ZXJzL3Rlc3QtcmVzb2x2ZXIvb3V0Ym91bmRFbmRwb2ludHMvdGVzdC1lbmRwb2ludFwiO1xuICBjb25zdCBtb2NrUmVzb3VyY2VHcm91cElkID1cbiAgICBcIi9zdWJzY3JpcHRpb25zLzEyMzQ1Njc4LTEyMzQtMTIzNC0xMjM0LTEyMzQ1Njc4OTAxMi9yZXNvdXJjZUdyb3Vwcy90ZXN0LXJnXCI7XG5cbiAgYmVmb3JlRWFjaCgoKSA9PiB7XG4gICAgYXBwID0gVGVzdGluZy5hcHAoKTtcbiAgICBzdGFjayA9IG5ldyBjZGt0Zi5UZXJyYWZvcm1TdGFjayhhcHAsIFwiVGVzdFN0YWNrXCIpO1xuICAgIG1hbmFnZXIgPSBBcGlWZXJzaW9uTWFuYWdlci5pbnN0YW5jZSgpO1xuXG4gICAgLy8gRW5zdXJlIHNjaGVtYXMgYXJlIHJlZ2lzdGVyZWRcbiAgICB0cnkge1xuICAgICAgbWFuYWdlci5yZWdpc3RlclJlc291cmNlVHlwZShcbiAgICAgICAgRE5TX0ZPUldBUkRJTkdfUlVMRVNFVF9UWVBFLFxuICAgICAgICBBTExfRE5TX0ZPUldBUkRJTkdfUlVMRVNFVF9WRVJTSU9OUyxcbiAgICAgICk7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIC8vIElnbm9yZSBpZiBhbHJlYWR5IHJlZ2lzdGVyZWRcbiAgICB9XG4gIH0pO1xuXG4gIGRlc2NyaWJlKFwiQ29uc3RydWN0b3IgYW5kIEJhc2ljIFByb3BlcnRpZXNcIiwgKCkgPT4ge1xuICAgIGl0KFwic2hvdWxkIGNyZWF0ZSBETlMgRm9yd2FyZGluZyBSdWxlc2V0IHdpdGggYXV0b21hdGljIGxhdGVzdCB2ZXJzaW9uIHJlc29sdXRpb25cIiwgKCkgPT4ge1xuICAgICAgY29uc3QgcHJvcHM6IERuc0ZvcndhcmRpbmdSdWxlc2V0UHJvcHMgPSB7XG4gICAgICAgIG5hbWU6IFwibXktcnVsZXNldFwiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiBtb2NrUmVzb3VyY2VHcm91cElkLFxuICAgICAgICBkbnNSZXNvbHZlck91dGJvdW5kRW5kcG9pbnRJZHM6IFttb2NrT3V0Ym91bmRFbmRwb2ludElkXSxcbiAgICAgIH07XG5cbiAgICAgIGNvbnN0IHJ1bGVzZXQgPSBuZXcgRG5zRm9yd2FyZGluZ1J1bGVzZXQoc3RhY2ssIFwiVGVzdFJ1bGVzZXRcIiwgcHJvcHMpO1xuXG4gICAgICBleHBlY3QocnVsZXNldCkudG9CZUluc3RhbmNlT2YoRG5zRm9yd2FyZGluZ1J1bGVzZXQpO1xuICAgICAgZXhwZWN0KHJ1bGVzZXQucmVzb2x2ZWRBcGlWZXJzaW9uKS50b0JlKFwiMjAyMi0wNy0wMVwiKTtcbiAgICAgIGV4cGVjdChydWxlc2V0LnByb3BzKS50b0JlKHByb3BzKTtcbiAgICB9KTtcblxuICAgIGl0KFwic2hvdWxkIGNyZWF0ZSBETlMgRm9yd2FyZGluZyBSdWxlc2V0IHdpdGggZXhwbGljaXQgdmVyc2lvbiBwaW5uaW5nXCIsICgpID0+IHtcbiAgICAgIGNvbnN0IHByb3BzOiBEbnNGb3J3YXJkaW5nUnVsZXNldFByb3BzID0ge1xuICAgICAgICBuYW1lOiBcIm15LXJ1bGVzZXRcIixcbiAgICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICAgIHJlc291cmNlR3JvdXBJZDogbW9ja1Jlc291cmNlR3JvdXBJZCxcbiAgICAgICAgZG5zUmVzb2x2ZXJPdXRib3VuZEVuZHBvaW50SWRzOiBbbW9ja091dGJvdW5kRW5kcG9pbnRJZF0sXG4gICAgICAgIGFwaVZlcnNpb246IFwiMjAyMi0wNy0wMVwiLFxuICAgICAgICB0YWdzOiB7IGVudmlyb25tZW50OiBcInRlc3RcIiB9LFxuICAgICAgfTtcblxuICAgICAgY29uc3QgcnVsZXNldCA9IG5ldyBEbnNGb3J3YXJkaW5nUnVsZXNldChzdGFjaywgXCJUZXN0UnVsZXNldFwiLCBwcm9wcyk7XG5cbiAgICAgIGV4cGVjdChydWxlc2V0LnJlc29sdmVkQXBpVmVyc2lvbikudG9CZShcIjIwMjItMDctMDFcIik7XG4gICAgICBleHBlY3QocnVsZXNldC50YWdzKS50b0VxdWFsKHsgZW52aXJvbm1lbnQ6IFwidGVzdFwiIH0pO1xuICAgIH0pO1xuXG4gICAgaXQoXCJzaG91bGQgdXNlIGxvY2F0aW9uIGZyb20gcHJvcHNcIiwgKCkgPT4ge1xuICAgICAgY29uc3QgcHJvcHM6IERuc0ZvcndhcmRpbmdSdWxlc2V0UHJvcHMgPSB7XG4gICAgICAgIG5hbWU6IFwibXktcnVsZXNldFwiLFxuICAgICAgICBsb2NhdGlvbjogXCJ3ZXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiBtb2NrUmVzb3VyY2VHcm91cElkLFxuICAgICAgICBkbnNSZXNvbHZlck91dGJvdW5kRW5kcG9pbnRJZHM6IFttb2NrT3V0Ym91bmRFbmRwb2ludElkXSxcbiAgICAgIH07XG5cbiAgICAgIGNvbnN0IHJ1bGVzZXQgPSBuZXcgRG5zRm9yd2FyZGluZ1J1bGVzZXQoc3RhY2ssIFwiVGVzdFJ1bGVzZXRcIiwgcHJvcHMpO1xuXG4gICAgICBleHBlY3QocnVsZXNldC5sb2NhdGlvbikudG9CZShcIndlc3R1c1wiKTtcbiAgICB9KTtcblxuICAgIGl0KFwic2hvdWxkIGNyZWF0ZSBETlMgRm9yd2FyZGluZyBSdWxlc2V0IHdpdGggbXVsdGlwbGUgb3V0Ym91bmQgZW5kcG9pbnRzXCIsICgpID0+IHtcbiAgICAgIGNvbnN0IHByb3BzOiBEbnNGb3J3YXJkaW5nUnVsZXNldFByb3BzID0ge1xuICAgICAgICBuYW1lOiBcIm15LXJ1bGVzZXRcIixcbiAgICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICAgIHJlc291cmNlR3JvdXBJZDogbW9ja1Jlc291cmNlR3JvdXBJZCxcbiAgICAgICAgZG5zUmVzb2x2ZXJPdXRib3VuZEVuZHBvaW50SWRzOiBbXG4gICAgICAgICAgbW9ja091dGJvdW5kRW5kcG9pbnRJZCxcbiAgICAgICAgICBgJHttb2NrT3V0Ym91bmRFbmRwb2ludElkfS0yYCxcbiAgICAgICAgXSxcbiAgICAgIH07XG5cbiAgICAgIGNvbnN0IHJ1bGVzZXQgPSBuZXcgRG5zRm9yd2FyZGluZ1J1bGVzZXQoc3RhY2ssIFwiVGVzdFJ1bGVzZXRcIiwgcHJvcHMpO1xuXG4gICAgICBleHBlY3QocnVsZXNldCkudG9CZURlZmluZWQoKTtcbiAgICAgIGV4cGVjdChydWxlc2V0LnByb3BzLmRuc1Jlc29sdmVyT3V0Ym91bmRFbmRwb2ludElkcykudG9IYXZlTGVuZ3RoKDIpO1xuICAgIH0pO1xuICB9KTtcblxuICBkZXNjcmliZShcIkZyYW1ld29yayBJbnRlZ3JhdGlvblwiLCAoKSA9PiB7XG4gICAgaXQoXCJzaG91bGQgcmVzb2x2ZSBsYXRlc3QgQVBJIHZlcnNpb24gYXV0b21hdGljYWxseVwiLCAoKSA9PiB7XG4gICAgICBjb25zdCBydWxlc2V0ID0gbmV3IERuc0ZvcndhcmRpbmdSdWxlc2V0KHN0YWNrLCBcIlRlc3RSdWxlc2V0XCIsIHtcbiAgICAgICAgbmFtZTogXCJteS1ydWxlc2V0XCIsXG4gICAgICAgIGxvY2F0aW9uOiBcImVhc3R1c1wiLFxuICAgICAgICByZXNvdXJjZUdyb3VwSWQ6IG1vY2tSZXNvdXJjZUdyb3VwSWQsXG4gICAgICAgIGRuc1Jlc29sdmVyT3V0Ym91bmRFbmRwb2ludElkczogW21vY2tPdXRib3VuZEVuZHBvaW50SWRdLFxuICAgICAgfSk7XG5cbiAgICAgIGV4cGVjdChydWxlc2V0LnJlc29sdmVkQXBpVmVyc2lvbikudG9CZShcIjIwMjItMDctMDFcIik7XG4gICAgICBleHBlY3QocnVsZXNldC5sYXRlc3RWZXJzaW9uKCkpLnRvQmUoXCIyMDIyLTA3LTAxXCIpO1xuICAgIH0pO1xuXG4gICAgaXQoXCJzaG91bGQgcHJvdmlkZSB2ZXJzaW9uIGNvbmZpZ3VyYXRpb25cIiwgKCkgPT4ge1xuICAgICAgY29uc3QgcnVsZXNldCA9IG5ldyBEbnNGb3J3YXJkaW5nUnVsZXNldChzdGFjaywgXCJUZXN0UnVsZXNldFwiLCB7XG4gICAgICAgIG5hbWU6IFwibXktcnVsZXNldFwiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiBtb2NrUmVzb3VyY2VHcm91cElkLFxuICAgICAgICBkbnNSZXNvbHZlck91dGJvdW5kRW5kcG9pbnRJZHM6IFttb2NrT3V0Ym91bmRFbmRwb2ludElkXSxcbiAgICAgIH0pO1xuXG4gICAgICBleHBlY3QocnVsZXNldC52ZXJzaW9uQ29uZmlnKS50b0JlRGVmaW5lZCgpO1xuICAgICAgZXhwZWN0KHJ1bGVzZXQudmVyc2lvbkNvbmZpZy52ZXJzaW9uKS50b0JlKFwiMjAyMi0wNy0wMVwiKTtcbiAgICAgIGV4cGVjdChydWxlc2V0LnZlcnNpb25Db25maWcuc3VwcG9ydExldmVsKS50b0JlKFxuICAgICAgICBWZXJzaW9uU3VwcG9ydExldmVsLkFDVElWRSxcbiAgICAgICk7XG4gICAgfSk7XG5cbiAgICBpdChcInNob3VsZCBwcm92aWRlIHN1cHBvcnRlZCB2ZXJzaW9uc1wiLCAoKSA9PiB7XG4gICAgICBjb25zdCBydWxlc2V0ID0gbmV3IERuc0ZvcndhcmRpbmdSdWxlc2V0KHN0YWNrLCBcIlRlc3RSdWxlc2V0XCIsIHtcbiAgICAgICAgbmFtZTogXCJteS1ydWxlc2V0XCIsXG4gICAgICAgIGxvY2F0aW9uOiBcImVhc3R1c1wiLFxuICAgICAgICByZXNvdXJjZUdyb3VwSWQ6IG1vY2tSZXNvdXJjZUdyb3VwSWQsXG4gICAgICAgIGRuc1Jlc29sdmVyT3V0Ym91bmRFbmRwb2ludElkczogW21vY2tPdXRib3VuZEVuZHBvaW50SWRdLFxuICAgICAgfSk7XG5cbiAgICAgIGNvbnN0IHZlcnNpb25zID0gcnVsZXNldC5zdXBwb3J0ZWRWZXJzaW9ucygpO1xuICAgICAgZXhwZWN0KHZlcnNpb25zKS50b0NvbnRhaW4oXCIyMDIyLTA3LTAxXCIpO1xuICAgICAgZXhwZWN0KHZlcnNpb25zLmxlbmd0aCkudG9CZUdyZWF0ZXJUaGFuKDApO1xuICAgIH0pO1xuICB9KTtcblxuICBkZXNjcmliZShcIlB1YmxpYyBNZXRob2RzIC0gRE5TIEZvcndhcmRpbmcgUnVsZXNldCBQcm9wZXJ0aWVzXCIsICgpID0+IHtcbiAgICBpdChcInNob3VsZCBwcm92aWRlIHByb3Zpc2lvbmluZyBzdGF0ZVwiLCAoKSA9PiB7XG4gICAgICBjb25zdCBydWxlc2V0ID0gbmV3IERuc0ZvcndhcmRpbmdSdWxlc2V0KHN0YWNrLCBcIlRlc3RSdWxlc2V0XCIsIHtcbiAgICAgICAgbmFtZTogXCJteS1ydWxlc2V0XCIsXG4gICAgICAgIGxvY2F0aW9uOiBcImVhc3R1c1wiLFxuICAgICAgICByZXNvdXJjZUdyb3VwSWQ6IG1vY2tSZXNvdXJjZUdyb3VwSWQsXG4gICAgICAgIGRuc1Jlc29sdmVyT3V0Ym91bmRFbmRwb2ludElkczogW21vY2tPdXRib3VuZEVuZHBvaW50SWRdLFxuICAgICAgfSk7XG5cbiAgICAgIGV4cGVjdChydWxlc2V0LnByb3Zpc2lvbmluZ1N0YXRlKS50b0JlRGVmaW5lZCgpO1xuICAgICAgZXhwZWN0KHR5cGVvZiBydWxlc2V0LnByb3Zpc2lvbmluZ1N0YXRlKS50b0JlKFwic3RyaW5nXCIpO1xuICAgIH0pO1xuXG4gICAgaXQoXCJzaG91bGQgcHJvdmlkZSByZXNvdXJjZSBHVUlEXCIsICgpID0+IHtcbiAgICAgIGNvbnN0IHJ1bGVzZXQgPSBuZXcgRG5zRm9yd2FyZGluZ1J1bGVzZXQoc3RhY2ssIFwiVGVzdFJ1bGVzZXRcIiwge1xuICAgICAgICBuYW1lOiBcIm15LXJ1bGVzZXRcIixcbiAgICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICAgIHJlc291cmNlR3JvdXBJZDogbW9ja1Jlc291cmNlR3JvdXBJZCxcbiAgICAgICAgZG5zUmVzb2x2ZXJPdXRib3VuZEVuZHBvaW50SWRzOiBbbW9ja091dGJvdW5kRW5kcG9pbnRJZF0sXG4gICAgICB9KTtcblxuICAgICAgZXhwZWN0KHJ1bGVzZXQucmVzb3VyY2VHdWlkKS50b0JlRGVmaW5lZCgpO1xuICAgICAgZXhwZWN0KHR5cGVvZiBydWxlc2V0LnJlc291cmNlR3VpZCkudG9CZShcInN0cmluZ1wiKTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoXCJUYWcgTWFuYWdlbWVudFwiLCAoKSA9PiB7XG4gICAgaXQoXCJzaG91bGQgYWxsb3cgYWRkaW5nIHRhZ3NcIiwgKCkgPT4ge1xuICAgICAgY29uc3QgcnVsZXNldCA9IG5ldyBEbnNGb3J3YXJkaW5nUnVsZXNldChzdGFjaywgXCJUZXN0UnVsZXNldFwiLCB7XG4gICAgICAgIG5hbWU6IFwibXktcnVsZXNldFwiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiBtb2NrUmVzb3VyY2VHcm91cElkLFxuICAgICAgICBkbnNSZXNvbHZlck91dGJvdW5kRW5kcG9pbnRJZHM6IFttb2NrT3V0Ym91bmRFbmRwb2ludElkXSxcbiAgICAgICAgdGFnczogeyBpbml0aWFsOiBcInRhZ1wiIH0sXG4gICAgICB9KTtcblxuICAgICAgcnVsZXNldC5hZGRUYWcoXCJuZXdLZXlcIiwgXCJuZXdWYWx1ZVwiKTtcbiAgICAgIGV4cGVjdChydWxlc2V0LnByb3BzLnRhZ3MpLnRvSGF2ZVByb3BlcnR5KFwibmV3S2V5XCIsIFwibmV3VmFsdWVcIik7XG4gICAgICBleHBlY3QocnVsZXNldC5wcm9wcy50YWdzKS50b0hhdmVQcm9wZXJ0eShcImluaXRpYWxcIiwgXCJ0YWdcIik7XG4gICAgfSk7XG5cbiAgICBpdChcInNob3VsZCBhbGxvdyByZW1vdmluZyB0YWdzXCIsICgpID0+IHtcbiAgICAgIGNvbnN0IHJ1bGVzZXQgPSBuZXcgRG5zRm9yd2FyZGluZ1J1bGVzZXQoc3RhY2ssIFwiVGVzdFJ1bGVzZXRcIiwge1xuICAgICAgICBuYW1lOiBcIm15LXJ1bGVzZXRcIixcbiAgICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICAgIHJlc291cmNlR3JvdXBJZDogbW9ja1Jlc291cmNlR3JvdXBJZCxcbiAgICAgICAgZG5zUmVzb2x2ZXJPdXRib3VuZEVuZHBvaW50SWRzOiBbbW9ja091dGJvdW5kRW5kcG9pbnRJZF0sXG4gICAgICAgIHRhZ3M6IHsga2V5MTogXCJ2YWx1ZTFcIiwga2V5MjogXCJ2YWx1ZTJcIiB9LFxuICAgICAgfSk7XG5cbiAgICAgIHJ1bGVzZXQucmVtb3ZlVGFnKFwia2V5MVwiKTtcbiAgICAgIGV4cGVjdChydWxlc2V0LnByb3BzLnRhZ3MpLm5vdC50b0hhdmVQcm9wZXJ0eShcImtleTFcIik7XG4gICAgICBleHBlY3QocnVsZXNldC5wcm9wcy50YWdzKS50b0hhdmVQcm9wZXJ0eShcImtleTJcIiwgXCJ2YWx1ZTJcIik7XG4gICAgfSk7XG5cbiAgICBpdChcInNob3VsZCBoYW5kbGUgYWRkaW5nIHRhZ3Mgd2hlbiBubyBpbml0aWFsIHRhZ3MgZXhpc3RcIiwgKCkgPT4ge1xuICAgICAgY29uc3QgcnVsZXNldCA9IG5ldyBEbnNGb3J3YXJkaW5nUnVsZXNldChzdGFjaywgXCJUZXN0UnVsZXNldFwiLCB7XG4gICAgICAgIG5hbWU6IFwibXktcnVsZXNldFwiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiBtb2NrUmVzb3VyY2VHcm91cElkLFxuICAgICAgICBkbnNSZXNvbHZlck91dGJvdW5kRW5kcG9pbnRJZHM6IFttb2NrT3V0Ym91bmRFbmRwb2ludElkXSxcbiAgICAgIH0pO1xuXG4gICAgICBydWxlc2V0LmFkZFRhZyhcIm5ld0tleVwiLCBcIm5ld1ZhbHVlXCIpO1xuICAgICAgZXhwZWN0KHJ1bGVzZXQucHJvcHMudGFncykudG9IYXZlUHJvcGVydHkoXCJuZXdLZXlcIiwgXCJuZXdWYWx1ZVwiKTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoXCJPdXRwdXRzXCIsICgpID0+IHtcbiAgICBpdChcInNob3VsZCBjcmVhdGUgYWxsIHJlcXVpcmVkIG91dHB1dHNcIiwgKCkgPT4ge1xuICAgICAgY29uc3QgcnVsZXNldCA9IG5ldyBEbnNGb3J3YXJkaW5nUnVsZXNldChzdGFjaywgXCJUZXN0UnVsZXNldFwiLCB7XG4gICAgICAgIG5hbWU6IFwibXktcnVsZXNldFwiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiBtb2NrUmVzb3VyY2VHcm91cElkLFxuICAgICAgICBkbnNSZXNvbHZlck91dGJvdW5kRW5kcG9pbnRJZHM6IFttb2NrT3V0Ym91bmRFbmRwb2ludElkXSxcbiAgICAgIH0pO1xuXG4gICAgICBleHBlY3QocnVsZXNldC5pZE91dHB1dCkudG9CZURlZmluZWQoKTtcbiAgICAgIGV4cGVjdChydWxlc2V0Lm5hbWVPdXRwdXQpLnRvQmVEZWZpbmVkKCk7XG4gICAgICBleHBlY3QocnVsZXNldC5sb2NhdGlvbk91dHB1dCkudG9CZURlZmluZWQoKTtcbiAgICAgIGV4cGVjdChydWxlc2V0LnRhZ3NPdXRwdXQpLnRvQmVEZWZpbmVkKCk7XG4gICAgICBleHBlY3QocnVsZXNldC5wcm92aXNpb25pbmdTdGF0ZU91dHB1dCkudG9CZURlZmluZWQoKTtcbiAgICAgIGV4cGVjdChydWxlc2V0LnJlc291cmNlR3VpZE91dHB1dCkudG9CZURlZmluZWQoKTtcbiAgICB9KTtcblxuICAgIGl0KFwic2hvdWxkIGhhdmUgY29ycmVjdCBsb2dpY2FsIElEcyBmb3Igb3V0cHV0c1wiLCAoKSA9PiB7XG4gICAgICBuZXcgRG5zRm9yd2FyZGluZ1J1bGVzZXQoc3RhY2ssIFwiVGVzdFJ1bGVzZXRcIiwge1xuICAgICAgICBuYW1lOiBcIm15LXJ1bGVzZXRcIixcbiAgICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICAgIHJlc291cmNlR3JvdXBJZDogbW9ja1Jlc291cmNlR3JvdXBJZCxcbiAgICAgICAgZG5zUmVzb2x2ZXJPdXRib3VuZEVuZHBvaW50SWRzOiBbbW9ja091dGJvdW5kRW5kcG9pbnRJZF0sXG4gICAgICB9KTtcblxuICAgICAgY29uc3Qgc3ludGhlc2l6ZWQgPSBUZXN0aW5nLnN5bnRoKHN0YWNrKTtcbiAgICAgIGV4cGVjdChzeW50aGVzaXplZCkudG9Db250YWluKCdcImlkXCInKTtcbiAgICAgIGV4cGVjdChzeW50aGVzaXplZCkudG9Db250YWluKCdcIm5hbWVcIicpO1xuICAgICAgZXhwZWN0KHN5bnRoZXNpemVkKS50b0NvbnRhaW4oJ1wibG9jYXRpb25cIicpO1xuICAgICAgZXhwZWN0KHN5bnRoZXNpemVkKS50b0NvbnRhaW4oJ1widGFnc1wiJyk7XG4gICAgICBleHBlY3Qoc3ludGhlc2l6ZWQpLnRvQ29udGFpbignXCJwcm92aXNpb25pbmdfc3RhdGVcIicpO1xuICAgICAgZXhwZWN0KHN5bnRoZXNpemVkKS50b0NvbnRhaW4oJ1wicmVzb3VyY2VfZ3VpZFwiJyk7XG4gICAgfSk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKFwiSWdub3JlIENoYW5nZXMgQ29uZmlndXJhdGlvblwiLCAoKSA9PiB7XG4gICAgaXQoXCJzaG91bGQgYXBwbHkgaWdub3JlIGNoYW5nZXMgbGlmZWN5Y2xlIHJ1bGVzXCIsICgpID0+IHtcbiAgICAgIG5ldyBEbnNGb3J3YXJkaW5nUnVsZXNldChzdGFjaywgXCJUZXN0UnVsZXNldFwiLCB7XG4gICAgICAgIG5hbWU6IFwibXktcnVsZXNldFwiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiBtb2NrUmVzb3VyY2VHcm91cElkLFxuICAgICAgICBkbnNSZXNvbHZlck91dGJvdW5kRW5kcG9pbnRJZHM6IFttb2NrT3V0Ym91bmRFbmRwb2ludElkXSxcbiAgICAgICAgaWdub3JlQ2hhbmdlczogW1widGFnc1wiXSxcbiAgICAgIH0pO1xuXG4gICAgICBjb25zdCBzeW50aGVzaXplZCA9IFRlc3Rpbmcuc3ludGgoc3RhY2spO1xuICAgICAgZXhwZWN0KHN5bnRoZXNpemVkKS50b0NvbnRhaW4oXCJpZ25vcmVfY2hhbmdlc1wiKTtcbiAgICB9KTtcblxuICAgIGl0KFwic2hvdWxkIGhhbmRsZSBtdWx0aXBsZSBpZ25vcmUgY2hhbmdlcyBwcm9wZXJ0aWVzXCIsICgpID0+IHtcbiAgICAgIG5ldyBEbnNGb3J3YXJkaW5nUnVsZXNldChzdGFjaywgXCJUZXN0UnVsZXNldFwiLCB7XG4gICAgICAgIG5hbWU6IFwibXktcnVsZXNldFwiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiBtb2NrUmVzb3VyY2VHcm91cElkLFxuICAgICAgICBkbnNSZXNvbHZlck91dGJvdW5kRW5kcG9pbnRJZHM6IFttb2NrT3V0Ym91bmRFbmRwb2ludElkXSxcbiAgICAgICAgaWdub3JlQ2hhbmdlczogW1widGFnc1wiLCBcImxvY2F0aW9uXCJdLFxuICAgICAgfSk7XG5cbiAgICAgIGNvbnN0IHN5bnRoZXNpemVkID0gVGVzdGluZy5zeW50aChzdGFjayk7XG4gICAgICBleHBlY3Qoc3ludGhlc2l6ZWQpLnRvQmVEZWZpbmVkKCk7XG4gICAgfSk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKFwiQ0RLIFRlcnJhZm9ybSBJbnRlZ3JhdGlvblwiLCAoKSA9PiB7XG4gICAgaXQoXCJzaG91bGQgc3ludGhlc2l6ZSB0byB2YWxpZCBUZXJyYWZvcm0gY29uZmlndXJhdGlvblwiLCAoKSA9PiB7XG4gICAgICBuZXcgRG5zRm9yd2FyZGluZ1J1bGVzZXQoc3RhY2ssIFwiU3ludGhUZXN0XCIsIHtcbiAgICAgICAgbmFtZTogXCJteS1ydWxlc2V0XCIsXG4gICAgICAgIGxvY2F0aW9uOiBcImVhc3R1c1wiLFxuICAgICAgICByZXNvdXJjZUdyb3VwSWQ6IG1vY2tSZXNvdXJjZUdyb3VwSWQsXG4gICAgICAgIGRuc1Jlc29sdmVyT3V0Ym91bmRFbmRwb2ludElkczogW21vY2tPdXRib3VuZEVuZHBvaW50SWRdLFxuICAgICAgICB0YWdzOiB7IHRlc3Q6IFwic3ludGhlc2lzXCIgfSxcbiAgICAgIH0pO1xuXG4gICAgICBjb25zdCBzeW50aGVzaXplZCA9IFRlc3Rpbmcuc3ludGgoc3RhY2spO1xuICAgICAgZXhwZWN0KHN5bnRoZXNpemVkKS50b0JlRGVmaW5lZCgpO1xuXG4gICAgICBjb25zdCBzdGFja0NvbmZpZyA9IEpTT04ucGFyc2Uoc3ludGhlc2l6ZWQpO1xuICAgICAgZXhwZWN0KHN0YWNrQ29uZmlnLnJlc291cmNlKS50b0JlRGVmaW5lZCgpO1xuICAgIH0pO1xuXG4gICAgaXQoXCJzaG91bGQgZ2VuZXJhdGUgY29ycmVjdCByZXNvdXJjZSB0eXBlIGluIFRlcnJhZm9ybVwiLCAoKSA9PiB7XG4gICAgICBuZXcgRG5zRm9yd2FyZGluZ1J1bGVzZXQoc3RhY2ssIFwiU3ludGhUZXN0XCIsIHtcbiAgICAgICAgbmFtZTogXCJteS1ydWxlc2V0XCIsXG4gICAgICAgIGxvY2F0aW9uOiBcImVhc3R1c1wiLFxuICAgICAgICByZXNvdXJjZUdyb3VwSWQ6IG1vY2tSZXNvdXJjZUdyb3VwSWQsXG4gICAgICAgIGRuc1Jlc29sdmVyT3V0Ym91bmRFbmRwb2ludElkczogW21vY2tPdXRib3VuZEVuZHBvaW50SWRdLFxuICAgICAgfSk7XG5cbiAgICAgIGNvbnN0IHN5bnRoZXNpemVkID0gVGVzdGluZy5zeW50aChzdGFjayk7XG4gICAgICBleHBlY3Qoc3ludGhlc2l6ZWQpLnRvQ29udGFpbihcImRuc0ZvcndhcmRpbmdSdWxlc2V0c1wiKTtcbiAgICAgIGV4cGVjdChzeW50aGVzaXplZCkudG9Db250YWluKFwiMjAyMi0wNy0wMVwiKTtcbiAgICB9KTtcblxuICAgIGl0KFwic2hvdWxkIGluY2x1ZGUgYWxsIHByb3BlcnRpZXMgaW4gVGVycmFmb3JtIGJvZHlcIiwgKCkgPT4ge1xuICAgICAgbmV3IERuc0ZvcndhcmRpbmdSdWxlc2V0KHN0YWNrLCBcIlN5bnRoVGVzdFwiLCB7XG4gICAgICAgIG5hbWU6IFwibXktcnVsZXNldFwiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiBtb2NrUmVzb3VyY2VHcm91cElkLFxuICAgICAgICBkbnNSZXNvbHZlck91dGJvdW5kRW5kcG9pbnRJZHM6IFttb2NrT3V0Ym91bmRFbmRwb2ludElkXSxcbiAgICAgICAgdGFnczogeyBlbnY6IFwidGVzdFwiIH0sXG4gICAgICB9KTtcblxuICAgICAgY29uc3Qgc3ludGhlc2l6ZWQgPSBUZXN0aW5nLnN5bnRoKHN0YWNrKTtcbiAgICAgIGV4cGVjdChzeW50aGVzaXplZCkudG9Db250YWluKFwiZWFzdHVzXCIpO1xuICAgICAgZXhwZWN0KHN5bnRoZXNpemVkKS50b0NvbnRhaW4oXCJlbnZcIik7XG4gICAgICBleHBlY3Qoc3ludGhlc2l6ZWQpLnRvQ29udGFpbihtb2NrT3V0Ym91bmRFbmRwb2ludElkKTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoXCJSZXNvdXJjZSBJZGVudGlmaWNhdGlvblwiLCAoKSA9PiB7XG4gICAgaXQoXCJzaG91bGQgcHJvdmlkZSByZXNvdXJjZSBJRFwiLCAoKSA9PiB7XG4gICAgICBjb25zdCBydWxlc2V0ID0gbmV3IERuc0ZvcndhcmRpbmdSdWxlc2V0KHN0YWNrLCBcIlRlc3RSdWxlc2V0XCIsIHtcbiAgICAgICAgbmFtZTogXCJteS1ydWxlc2V0XCIsXG4gICAgICAgIGxvY2F0aW9uOiBcImVhc3R1c1wiLFxuICAgICAgICByZXNvdXJjZUdyb3VwSWQ6IG1vY2tSZXNvdXJjZUdyb3VwSWQsXG4gICAgICAgIGRuc1Jlc29sdmVyT3V0Ym91bmRFbmRwb2ludElkczogW21vY2tPdXRib3VuZEVuZHBvaW50SWRdLFxuICAgICAgfSk7XG5cbiAgICAgIGV4cGVjdChydWxlc2V0LmlkKS50b0JlRGVmaW5lZCgpO1xuICAgICAgZXhwZWN0KHR5cGVvZiBydWxlc2V0LmlkKS50b0JlKFwic3RyaW5nXCIpO1xuICAgIH0pO1xuXG4gICAgaXQoXCJzaG91bGQgcHJvdmlkZSByZXNvdXJjZSBuYW1lIGZyb20gcHJvcHMgd2hlbiBzcGVjaWZpZWRcIiwgKCkgPT4ge1xuICAgICAgY29uc3QgcnVsZXNldCA9IG5ldyBEbnNGb3J3YXJkaW5nUnVsZXNldChzdGFjaywgXCJUZXN0UnVsZXNldFwiLCB7XG4gICAgICAgIG5hbWU6IFwibXktcnVsZXNldFwiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiBtb2NrUmVzb3VyY2VHcm91cElkLFxuICAgICAgICBkbnNSZXNvbHZlck91dGJvdW5kRW5kcG9pbnRJZHM6IFttb2NrT3V0Ym91bmRFbmRwb2ludElkXSxcbiAgICAgIH0pO1xuXG4gICAgICBleHBlY3QocnVsZXNldC5uYW1lKS50b0JlKFwibXktcnVsZXNldFwiKTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoXCJKU0lJIENvbXBsaWFuY2VcIiwgKCkgPT4ge1xuICAgIGl0KFwic2hvdWxkIGhhdmUgcHJvcGVyIHJldHVybiB0eXBlcyBmb3IgYWxsIHB1YmxpYyBtZXRob2RzXCIsICgpID0+IHtcbiAgICAgIGNvbnN0IHJ1bGVzZXQgPSBuZXcgRG5zRm9yd2FyZGluZ1J1bGVzZXQoc3RhY2ssIFwiVGVzdFJ1bGVzZXRcIiwge1xuICAgICAgICBuYW1lOiBcIm15LXJ1bGVzZXRcIixcbiAgICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICAgIHJlc291cmNlR3JvdXBJZDogbW9ja1Jlc291cmNlR3JvdXBJZCxcbiAgICAgICAgZG5zUmVzb2x2ZXJPdXRib3VuZEVuZHBvaW50SWRzOiBbbW9ja091dGJvdW5kRW5kcG9pbnRJZF0sXG4gICAgICB9KTtcblxuICAgICAgLy8gQWxsIGdldHRlciBtZXRob2RzIHNob3VsZCByZXR1cm4gc3RyaW5ncyBmb3IgVGVycmFmb3JtIGludGVycG9sYXRpb25zXG4gICAgICBleHBlY3QodHlwZW9mIHJ1bGVzZXQucHJvdmlzaW9uaW5nU3RhdGUpLnRvQmUoXCJzdHJpbmdcIik7XG4gICAgICBleHBlY3QodHlwZW9mIHJ1bGVzZXQucmVzb3VyY2VHdWlkKS50b0JlKFwic3RyaW5nXCIpO1xuICAgIH0pO1xuXG4gICAgaXQoXCJzaG91bGQgbm90IHVzZSBmdW5jdGlvbiB0eXBlcyBpbiBwdWJsaWMgaW50ZXJmYWNlXCIsICgpID0+IHtcbiAgICAgIGNvbnN0IHJ1bGVzZXQgPSBuZXcgRG5zRm9yd2FyZGluZ1J1bGVzZXQoc3RhY2ssIFwiVGVzdFJ1bGVzZXRcIiwge1xuICAgICAgICBuYW1lOiBcIm15LXJ1bGVzZXRcIixcbiAgICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICAgIHJlc291cmNlR3JvdXBJZDogbW9ja1Jlc291cmNlR3JvdXBJZCxcbiAgICAgICAgZG5zUmVzb2x2ZXJPdXRib3VuZEVuZHBvaW50SWRzOiBbbW9ja091dGJvdW5kRW5kcG9pbnRJZF0sXG4gICAgICB9KTtcblxuICAgICAgLy8gVmVyaWZ5IG1ldGhvZHMgZXhpc3QgYW5kIGFyZSBjYWxsYWJsZVxuICAgICAgZXhwZWN0KHR5cGVvZiBydWxlc2V0LmFkZFRhZykudG9CZShcImZ1bmN0aW9uXCIpO1xuICAgICAgZXhwZWN0KHR5cGVvZiBydWxlc2V0LnJlbW92ZVRhZykudG9CZShcImZ1bmN0aW9uXCIpO1xuXG4gICAgICAvLyBUZXN0IHRoYXQgdGhleSB3b3JrIGNvcnJlY3RseVxuICAgICAgcnVsZXNldC5hZGRUYWcoXCJ0ZXN0XCIsIFwidmFsdWVcIik7XG4gICAgICBleHBlY3QocnVsZXNldC5wcm9wcy50YWdzKS50b0hhdmVQcm9wZXJ0eShcInRlc3RcIiwgXCJ2YWx1ZVwiKTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoXCJTY2hlbWEgUmVnaXN0cmF0aW9uXCIsICgpID0+IHtcbiAgICBpdChcInNob3VsZCByZWdpc3RlciBzY2hlbWFzIHN1Y2Nlc3NmdWxseVwiLCAoKSA9PiB7XG4gICAgICBjb25zdCBydWxlc2V0ID0gbmV3IERuc0ZvcndhcmRpbmdSdWxlc2V0KHN0YWNrLCBcIlRlc3RSdWxlc2V0XCIsIHtcbiAgICAgICAgbmFtZTogXCJteS1ydWxlc2V0XCIsXG4gICAgICAgIGxvY2F0aW9uOiBcImVhc3R1c1wiLFxuICAgICAgICByZXNvdXJjZUdyb3VwSWQ6IG1vY2tSZXNvdXJjZUdyb3VwSWQsXG4gICAgICAgIGRuc1Jlc29sdmVyT3V0Ym91bmRFbmRwb2ludElkczogW21vY2tPdXRib3VuZEVuZHBvaW50SWRdLFxuICAgICAgfSk7XG5cbiAgICAgIC8vIElmIHRoZSBydWxlc2V0IHdhcyBjcmVhdGVkIHN1Y2Nlc3NmdWxseSwgc2NoZW1hcyB3ZXJlIHJlZ2lzdGVyZWRcbiAgICAgIGV4cGVjdChydWxlc2V0KS50b0JlRGVmaW5lZCgpO1xuICAgICAgZXhwZWN0KHJ1bGVzZXQucmVzb2x2ZWRBcGlWZXJzaW9uKS50b0JlKFwiMjAyMi0wNy0wMVwiKTtcbiAgICB9KTtcblxuICAgIGl0KFwic2hvdWxkIGhhbmRsZSBtdWx0aXBsZSBpbnN0YW50aWF0aW9ucyB3aXRob3V0IGVycm9yc1wiLCAoKSA9PiB7XG4gICAgICBuZXcgRG5zRm9yd2FyZGluZ1J1bGVzZXQoc3RhY2ssIFwiVGVzdFJ1bGVzZXQxXCIsIHtcbiAgICAgICAgbmFtZTogXCJteS1ydWxlc2V0LTFcIixcbiAgICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICAgIHJlc291cmNlR3JvdXBJZDogbW9ja1Jlc291cmNlR3JvdXBJZCxcbiAgICAgICAgZG5zUmVzb2x2ZXJPdXRib3VuZEVuZHBvaW50SWRzOiBbbW9ja091dGJvdW5kRW5kcG9pbnRJZF0sXG4gICAgICB9KTtcblxuICAgICAgLy8gU2Vjb25kIGluc3RhbnRpYXRpb24gc2hvdWxkIG5vdCB0aHJvdyBhbiBlcnJvciBldmVuIGlmIHNjaGVtYXMgYXJlIGFscmVhZHkgcmVnaXN0ZXJlZFxuICAgICAgY29uc3QgcnVsZXNldDIgPSBuZXcgRG5zRm9yd2FyZGluZ1J1bGVzZXQoc3RhY2ssIFwiVGVzdFJ1bGVzZXQyXCIsIHtcbiAgICAgICAgbmFtZTogXCJteS1ydWxlc2V0LTJcIixcbiAgICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICAgIHJlc291cmNlR3JvdXBJZDogbW9ja1Jlc291cmNlR3JvdXBJZCxcbiAgICAgICAgZG5zUmVzb2x2ZXJPdXRib3VuZEVuZHBvaW50SWRzOiBbbW9ja091dGJvdW5kRW5kcG9pbnRJZF0sXG4gICAgICB9KTtcblxuICAgICAgZXhwZWN0KHJ1bGVzZXQyKS50b0JlRGVmaW5lZCgpO1xuICAgIH0pO1xuICB9KTtcbn0pO1xuIl19
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Comprehensive tests for the ForwardingRule implementation
|
|
3
|
+
*
|
|
4
|
+
* This test suite validates the ForwardingRule class using the
|
|
5
|
+
* AzapiResource framework. Tests cover automatic version resolution,
|
|
6
|
+
* explicit version pinning, schema validation, property transformation,
|
|
7
|
+
* parent-child resource relationships, and full backward compatibility.
|
|
8
|
+
*/
|
|
9
|
+
export {};
|