@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,806 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Comprehensive tests for the unified PolicyDefinition implementation
|
|
4
|
+
*
|
|
5
|
+
* This test suite validates the unified PolicyDefinition class that uses
|
|
6
|
+
* the VersionedAzapiResource framework. Tests cover automatic version resolution,
|
|
7
|
+
* explicit version pinning, schema validation, property transformation, and
|
|
8
|
+
* policy-specific functionality.
|
|
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 policy_definition_1 = require("../lib/policy-definition");
|
|
16
|
+
const policy_definition_schemas_1 = require("../lib/policy-definition-schemas");
|
|
17
|
+
describe("PolicyDefinition - Unified Implementation", () => {
|
|
18
|
+
let app;
|
|
19
|
+
let stack;
|
|
20
|
+
let manager;
|
|
21
|
+
beforeEach(() => {
|
|
22
|
+
app = cdktf_1.Testing.app();
|
|
23
|
+
stack = new cdktf.TerraformStack(app, "TestStack");
|
|
24
|
+
manager = api_version_manager_1.ApiVersionManager.instance();
|
|
25
|
+
// Ensure Policy Definition schemas are registered
|
|
26
|
+
try {
|
|
27
|
+
manager.registerResourceType(policy_definition_schemas_1.POLICY_DEFINITION_TYPE, policy_definition_schemas_1.ALL_POLICY_DEFINITION_VERSIONS);
|
|
28
|
+
}
|
|
29
|
+
catch (error) {
|
|
30
|
+
// Ignore if already registered
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
describe("Constructor and Basic Properties", () => {
|
|
34
|
+
it("should create policy definition with automatic latest version resolution", () => {
|
|
35
|
+
const props = {
|
|
36
|
+
name: "test-policy",
|
|
37
|
+
policyRule: {
|
|
38
|
+
if: {
|
|
39
|
+
field: "tags['Environment']",
|
|
40
|
+
exists: "false",
|
|
41
|
+
},
|
|
42
|
+
then: {
|
|
43
|
+
effect: "deny",
|
|
44
|
+
},
|
|
45
|
+
},
|
|
46
|
+
};
|
|
47
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", props);
|
|
48
|
+
expect(policyDefinition).toBeInstanceOf(policy_definition_1.PolicyDefinition);
|
|
49
|
+
expect(policyDefinition.resolvedApiVersion).toBe("2021-06-01"); // Latest version
|
|
50
|
+
expect(policyDefinition.props).toBe(props);
|
|
51
|
+
expect(policyDefinition.name).toBe("test-policy");
|
|
52
|
+
});
|
|
53
|
+
it("should create policy definition with explicit version pinning", () => {
|
|
54
|
+
const props = {
|
|
55
|
+
name: "test-policy-pinned",
|
|
56
|
+
apiVersion: "2021-06-01",
|
|
57
|
+
policyRule: {
|
|
58
|
+
if: {
|
|
59
|
+
field: "type",
|
|
60
|
+
equals: "Microsoft.Compute/virtualMachines",
|
|
61
|
+
},
|
|
62
|
+
then: {
|
|
63
|
+
effect: "audit",
|
|
64
|
+
},
|
|
65
|
+
},
|
|
66
|
+
};
|
|
67
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", props);
|
|
68
|
+
expect(policyDefinition.resolvedApiVersion).toBe("2021-06-01");
|
|
69
|
+
});
|
|
70
|
+
it("should create policy definition with all optional properties", () => {
|
|
71
|
+
const props = {
|
|
72
|
+
name: "test-policy-full",
|
|
73
|
+
displayName: "Test Policy Definition",
|
|
74
|
+
description: "A test policy definition for unit testing",
|
|
75
|
+
policyType: "Custom",
|
|
76
|
+
mode: "All",
|
|
77
|
+
policyRule: {
|
|
78
|
+
if: {
|
|
79
|
+
field: "location",
|
|
80
|
+
notIn: ["eastus", "westus"],
|
|
81
|
+
},
|
|
82
|
+
then: {
|
|
83
|
+
effect: "deny",
|
|
84
|
+
},
|
|
85
|
+
},
|
|
86
|
+
parameters: {
|
|
87
|
+
allowedLocations: {
|
|
88
|
+
type: "Array",
|
|
89
|
+
metadata: {
|
|
90
|
+
displayName: "Allowed locations",
|
|
91
|
+
description: "The list of allowed locations for resources",
|
|
92
|
+
},
|
|
93
|
+
},
|
|
94
|
+
},
|
|
95
|
+
metadata: {
|
|
96
|
+
category: "General",
|
|
97
|
+
version: "1.0.0",
|
|
98
|
+
},
|
|
99
|
+
ignoreChanges: ["metadata"],
|
|
100
|
+
enableValidation: true,
|
|
101
|
+
enableMigrationAnalysis: true,
|
|
102
|
+
enableTransformation: true,
|
|
103
|
+
};
|
|
104
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", props);
|
|
105
|
+
expect(policyDefinition.props.displayName).toBe("Test Policy Definition");
|
|
106
|
+
expect(policyDefinition.props.description).toBe("A test policy definition for unit testing");
|
|
107
|
+
expect(policyDefinition.props.policyType).toBe("Custom");
|
|
108
|
+
expect(policyDefinition.props.mode).toBe("All");
|
|
109
|
+
expect(policyDefinition.props.parameters).toBeDefined();
|
|
110
|
+
expect(policyDefinition.props.metadata).toBeDefined();
|
|
111
|
+
});
|
|
112
|
+
it("should use default name when name is not provided", () => {
|
|
113
|
+
const props = {
|
|
114
|
+
policyRule: {
|
|
115
|
+
if: {
|
|
116
|
+
field: "type",
|
|
117
|
+
equals: "Microsoft.Storage/storageAccounts",
|
|
118
|
+
},
|
|
119
|
+
then: {
|
|
120
|
+
effect: "audit",
|
|
121
|
+
},
|
|
122
|
+
},
|
|
123
|
+
};
|
|
124
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", props);
|
|
125
|
+
expect(policyDefinition.name).toBe("TestPolicyDefinition");
|
|
126
|
+
});
|
|
127
|
+
it("should require policyRule to be provided", () => {
|
|
128
|
+
const props = {
|
|
129
|
+
name: "test-policy",
|
|
130
|
+
};
|
|
131
|
+
expect(() => {
|
|
132
|
+
new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", props);
|
|
133
|
+
}).toThrow("Required property 'policyRule' is missing");
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
describe("Framework Integration", () => {
|
|
137
|
+
it("should resolve latest API version automatically", () => {
|
|
138
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", {
|
|
139
|
+
name: "test-policy",
|
|
140
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
141
|
+
});
|
|
142
|
+
expect(policyDefinition.resolvedApiVersion).toBe("2021-06-01");
|
|
143
|
+
expect(policyDefinition.latestVersion()).toBe("2021-06-01");
|
|
144
|
+
});
|
|
145
|
+
it("should support all registered API versions", () => {
|
|
146
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", {
|
|
147
|
+
name: "test-policy",
|
|
148
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
149
|
+
});
|
|
150
|
+
const supportedVersions = policyDefinition.supportedVersions();
|
|
151
|
+
expect(supportedVersions).toContain("2021-06-01");
|
|
152
|
+
});
|
|
153
|
+
it("should validate version support", () => {
|
|
154
|
+
// Valid version
|
|
155
|
+
expect(() => {
|
|
156
|
+
new policy_definition_1.PolicyDefinition(stack, "ValidVersion", {
|
|
157
|
+
name: "test-policy",
|
|
158
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
159
|
+
apiVersion: "2021-06-01",
|
|
160
|
+
});
|
|
161
|
+
}).not.toThrow();
|
|
162
|
+
// Invalid version
|
|
163
|
+
expect(() => {
|
|
164
|
+
new policy_definition_1.PolicyDefinition(stack, "InvalidVersion", {
|
|
165
|
+
name: "test-policy",
|
|
166
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
167
|
+
apiVersion: "2022-01-01",
|
|
168
|
+
});
|
|
169
|
+
}).toThrow("Unsupported API version '2022-01-01'");
|
|
170
|
+
});
|
|
171
|
+
it("should load correct schema for resolved version", () => {
|
|
172
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", {
|
|
173
|
+
name: "test-policy",
|
|
174
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
175
|
+
apiVersion: "2021-06-01",
|
|
176
|
+
});
|
|
177
|
+
expect(policyDefinition.schema).toBeDefined();
|
|
178
|
+
expect(policyDefinition.schema.resourceType).toBe(policy_definition_schemas_1.POLICY_DEFINITION_TYPE);
|
|
179
|
+
expect(policyDefinition.schema.version).toBe("2021-06-01");
|
|
180
|
+
expect(policyDefinition.schema.properties).toBeDefined();
|
|
181
|
+
});
|
|
182
|
+
it("should load version configuration correctly", () => {
|
|
183
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", {
|
|
184
|
+
name: "test-policy",
|
|
185
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
186
|
+
});
|
|
187
|
+
expect(policyDefinition.versionConfig).toBeDefined();
|
|
188
|
+
expect(policyDefinition.versionConfig.version).toBe("2021-06-01");
|
|
189
|
+
expect(policyDefinition.versionConfig.supportLevel).toBe(version_interfaces_1.VersionSupportLevel.ACTIVE);
|
|
190
|
+
});
|
|
191
|
+
});
|
|
192
|
+
describe("Property Validation", () => {
|
|
193
|
+
it("should validate properties when validation is enabled", () => {
|
|
194
|
+
const props = {
|
|
195
|
+
name: "test-policy",
|
|
196
|
+
policyRule: {
|
|
197
|
+
if: {
|
|
198
|
+
field: "type",
|
|
199
|
+
equals: "Microsoft.Compute/virtualMachines",
|
|
200
|
+
},
|
|
201
|
+
then: {
|
|
202
|
+
effect: "audit",
|
|
203
|
+
},
|
|
204
|
+
},
|
|
205
|
+
enableValidation: true,
|
|
206
|
+
};
|
|
207
|
+
expect(() => {
|
|
208
|
+
new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", props);
|
|
209
|
+
}).not.toThrow();
|
|
210
|
+
});
|
|
211
|
+
it("should have validation results for valid properties", () => {
|
|
212
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", {
|
|
213
|
+
name: "valid-policy",
|
|
214
|
+
displayName: "Valid Policy",
|
|
215
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
216
|
+
enableValidation: true,
|
|
217
|
+
});
|
|
218
|
+
expect(policyDefinition.validationResult).toBeDefined();
|
|
219
|
+
expect(policyDefinition.validationResult.valid).toBe(true);
|
|
220
|
+
expect(policyDefinition.validationResult.errors).toHaveLength(0);
|
|
221
|
+
});
|
|
222
|
+
it("should skip validation when disabled", () => {
|
|
223
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", {
|
|
224
|
+
name: "test-policy",
|
|
225
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
226
|
+
enableValidation: false,
|
|
227
|
+
});
|
|
228
|
+
expect(policyDefinition).toBeDefined();
|
|
229
|
+
});
|
|
230
|
+
});
|
|
231
|
+
describe("Migration Analysis", () => {
|
|
232
|
+
it("should skip migration analysis for single version", () => {
|
|
233
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", {
|
|
234
|
+
name: "test-policy",
|
|
235
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
236
|
+
apiVersion: "2021-06-01",
|
|
237
|
+
});
|
|
238
|
+
// Since there's only one version, migration analysis should be skipped
|
|
239
|
+
expect(policyDefinition).toBeDefined();
|
|
240
|
+
});
|
|
241
|
+
it("should skip migration analysis when disabled", () => {
|
|
242
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", {
|
|
243
|
+
name: "test-policy",
|
|
244
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
245
|
+
enableMigrationAnalysis: false,
|
|
246
|
+
});
|
|
247
|
+
expect(policyDefinition.migrationAnalysis).toBeUndefined();
|
|
248
|
+
});
|
|
249
|
+
});
|
|
250
|
+
describe("Resource Creation and Body", () => {
|
|
251
|
+
it("should create correct resource body with minimal properties", () => {
|
|
252
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", {
|
|
253
|
+
name: "test-policy",
|
|
254
|
+
policyRule: {
|
|
255
|
+
if: {
|
|
256
|
+
field: "tags['Environment']",
|
|
257
|
+
exists: "false",
|
|
258
|
+
},
|
|
259
|
+
then: {
|
|
260
|
+
effect: "deny",
|
|
261
|
+
},
|
|
262
|
+
},
|
|
263
|
+
});
|
|
264
|
+
expect(policyDefinition).toBeDefined();
|
|
265
|
+
expect(policyDefinition.props.policyRule).toBeDefined();
|
|
266
|
+
});
|
|
267
|
+
it("should create correct resource body with all properties", () => {
|
|
268
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", {
|
|
269
|
+
name: "test-policy",
|
|
270
|
+
displayName: "Test Policy",
|
|
271
|
+
description: "A test policy",
|
|
272
|
+
policyType: "Custom",
|
|
273
|
+
mode: "Indexed",
|
|
274
|
+
policyRule: {
|
|
275
|
+
if: {
|
|
276
|
+
field: "location",
|
|
277
|
+
notIn: ["eastus", "westus"],
|
|
278
|
+
},
|
|
279
|
+
then: {
|
|
280
|
+
effect: "deny",
|
|
281
|
+
},
|
|
282
|
+
},
|
|
283
|
+
parameters: {
|
|
284
|
+
allowedLocations: {
|
|
285
|
+
type: "Array",
|
|
286
|
+
},
|
|
287
|
+
},
|
|
288
|
+
metadata: {
|
|
289
|
+
category: "Compliance",
|
|
290
|
+
},
|
|
291
|
+
});
|
|
292
|
+
expect(policyDefinition).toBeDefined();
|
|
293
|
+
expect(policyDefinition.props.displayName).toBe("Test Policy");
|
|
294
|
+
expect(policyDefinition.props.policyType).toBe("Custom");
|
|
295
|
+
expect(policyDefinition.props.mode).toBe("Indexed");
|
|
296
|
+
});
|
|
297
|
+
it("should create Terraform outputs", () => {
|
|
298
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", {
|
|
299
|
+
name: "test-policy-outputs",
|
|
300
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
301
|
+
});
|
|
302
|
+
expect(policyDefinition.idOutput).toBeInstanceOf(cdktf.TerraformOutput);
|
|
303
|
+
expect(policyDefinition.nameOutput).toBeInstanceOf(cdktf.TerraformOutput);
|
|
304
|
+
});
|
|
305
|
+
});
|
|
306
|
+
describe("Public Methods and Properties", () => {
|
|
307
|
+
let policyDefinition;
|
|
308
|
+
beforeEach(() => {
|
|
309
|
+
policyDefinition = new policy_definition_1.PolicyDefinition(stack, "TestPolicyDefinition", {
|
|
310
|
+
name: "test-policy",
|
|
311
|
+
displayName: "Test Policy",
|
|
312
|
+
policyType: "Custom",
|
|
313
|
+
mode: "All",
|
|
314
|
+
policyRule: {
|
|
315
|
+
if: {
|
|
316
|
+
field: "type",
|
|
317
|
+
equals: "Microsoft.Compute/virtualMachines",
|
|
318
|
+
},
|
|
319
|
+
then: {
|
|
320
|
+
effect: "audit",
|
|
321
|
+
},
|
|
322
|
+
},
|
|
323
|
+
});
|
|
324
|
+
});
|
|
325
|
+
it("should have correct id format", () => {
|
|
326
|
+
expect(policyDefinition.id).toMatch(/^\$\{.*\.id\}$/);
|
|
327
|
+
});
|
|
328
|
+
it("should have resourceId property matching id", () => {
|
|
329
|
+
expect(policyDefinition.resourceId).toBe(policyDefinition.id);
|
|
330
|
+
});
|
|
331
|
+
it("should return correct policyType", () => {
|
|
332
|
+
expect(policyDefinition.policyType).toBe("Custom");
|
|
333
|
+
});
|
|
334
|
+
it("should return correct policyMode", () => {
|
|
335
|
+
expect(policyDefinition.policyMode).toBe("All");
|
|
336
|
+
});
|
|
337
|
+
it("should use default policyType when not provided", () => {
|
|
338
|
+
const defaultPolicy = new policy_definition_1.PolicyDefinition(stack, "DefaultTypePolicy", {
|
|
339
|
+
name: "default-policy",
|
|
340
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
341
|
+
});
|
|
342
|
+
expect(defaultPolicy.policyType).toBe("Custom");
|
|
343
|
+
});
|
|
344
|
+
it("should use default mode when not provided", () => {
|
|
345
|
+
const defaultPolicy = new policy_definition_1.PolicyDefinition(stack, "DefaultModePolicy", {
|
|
346
|
+
name: "default-policy",
|
|
347
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
348
|
+
});
|
|
349
|
+
expect(defaultPolicy.policyMode).toBe("All");
|
|
350
|
+
});
|
|
351
|
+
});
|
|
352
|
+
describe("Ignore Changes Configuration", () => {
|
|
353
|
+
it("should apply ignore changes lifecycle rules", () => {
|
|
354
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "IgnoreChangesPolicy", {
|
|
355
|
+
name: "test-policy",
|
|
356
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
357
|
+
ignoreChanges: ["metadata", "description"],
|
|
358
|
+
});
|
|
359
|
+
expect(policyDefinition).toBeInstanceOf(policy_definition_1.PolicyDefinition);
|
|
360
|
+
});
|
|
361
|
+
it("should handle empty ignore changes array", () => {
|
|
362
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "EmptyIgnorePolicy", {
|
|
363
|
+
name: "test-policy",
|
|
364
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
365
|
+
ignoreChanges: [],
|
|
366
|
+
});
|
|
367
|
+
expect(policyDefinition).toBeInstanceOf(policy_definition_1.PolicyDefinition);
|
|
368
|
+
});
|
|
369
|
+
});
|
|
370
|
+
describe("Policy Rule Validation", () => {
|
|
371
|
+
it("should accept complex policy rules", () => {
|
|
372
|
+
const complexRule = {
|
|
373
|
+
if: {
|
|
374
|
+
allOf: [
|
|
375
|
+
{
|
|
376
|
+
field: "type",
|
|
377
|
+
equals: "Microsoft.Storage/storageAccounts",
|
|
378
|
+
},
|
|
379
|
+
{
|
|
380
|
+
field: "Microsoft.Storage/storageAccounts/enableHttpsTrafficOnly",
|
|
381
|
+
notEquals: "true",
|
|
382
|
+
},
|
|
383
|
+
],
|
|
384
|
+
},
|
|
385
|
+
then: {
|
|
386
|
+
effect: "deny",
|
|
387
|
+
},
|
|
388
|
+
};
|
|
389
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "ComplexRulePolicy", {
|
|
390
|
+
name: "complex-policy",
|
|
391
|
+
policyRule: complexRule,
|
|
392
|
+
});
|
|
393
|
+
expect(policyDefinition).toBeDefined();
|
|
394
|
+
expect(policyDefinition.props.policyRule).toEqual(complexRule);
|
|
395
|
+
});
|
|
396
|
+
it("should accept policy rules with parameters", () => {
|
|
397
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "ParameterizedPolicy", {
|
|
398
|
+
name: "parameterized-policy",
|
|
399
|
+
policyRule: {
|
|
400
|
+
if: {
|
|
401
|
+
field: "[concat('tags[', parameters('tagName'), ']')]",
|
|
402
|
+
exists: "false",
|
|
403
|
+
},
|
|
404
|
+
then: {
|
|
405
|
+
effect: "[parameters('effect')]",
|
|
406
|
+
},
|
|
407
|
+
},
|
|
408
|
+
parameters: {
|
|
409
|
+
tagName: {
|
|
410
|
+
type: "String",
|
|
411
|
+
metadata: {
|
|
412
|
+
displayName: "Tag Name",
|
|
413
|
+
description: "Name of the tag to check",
|
|
414
|
+
},
|
|
415
|
+
},
|
|
416
|
+
effect: {
|
|
417
|
+
type: "String",
|
|
418
|
+
allowedValues: ["audit", "deny"],
|
|
419
|
+
defaultValue: "audit",
|
|
420
|
+
},
|
|
421
|
+
},
|
|
422
|
+
});
|
|
423
|
+
expect(policyDefinition).toBeDefined();
|
|
424
|
+
expect(policyDefinition.props.parameters).toBeDefined();
|
|
425
|
+
});
|
|
426
|
+
it("should preserve complex allOf conditions with multiple field comparisons", () => {
|
|
427
|
+
const complexRule = {
|
|
428
|
+
if: {
|
|
429
|
+
allOf: [
|
|
430
|
+
{
|
|
431
|
+
field: "type",
|
|
432
|
+
equals: "Microsoft.Storage/storageAccounts",
|
|
433
|
+
},
|
|
434
|
+
{
|
|
435
|
+
field: "Microsoft.Storage/storageAccounts/networkAcls.defaultAction",
|
|
436
|
+
notEquals: "Deny",
|
|
437
|
+
},
|
|
438
|
+
],
|
|
439
|
+
},
|
|
440
|
+
then: {
|
|
441
|
+
effect: "audit",
|
|
442
|
+
},
|
|
443
|
+
};
|
|
444
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "ComplexAllOf", {
|
|
445
|
+
name: "complex-allof-policy",
|
|
446
|
+
displayName: "Complex AllOf Policy",
|
|
447
|
+
policyRule: complexRule,
|
|
448
|
+
});
|
|
449
|
+
expect(policyDefinition).toBeDefined();
|
|
450
|
+
expect(policyDefinition.props.policyRule).toEqual(complexRule);
|
|
451
|
+
// Synthesize and verify the structure is preserved
|
|
452
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
453
|
+
const stackConfig = JSON.parse(synthesized);
|
|
454
|
+
const azapiResource = Object.values(stackConfig.resource.azapi_resource)[0];
|
|
455
|
+
// The body is jsonencode() wrapped, so we need to parse the actual policy rule from props
|
|
456
|
+
expect(policyDefinition.props.policyRule.if.allOf).toHaveLength(2);
|
|
457
|
+
expect(policyDefinition.props.policyRule.if.allOf[0].field).toBe("type");
|
|
458
|
+
expect(policyDefinition.props.policyRule.if.allOf[0].equals).toBe("Microsoft.Storage/storageAccounts");
|
|
459
|
+
expect(policyDefinition.props.policyRule.if.allOf[1].field).toBe("Microsoft.Storage/storageAccounts/networkAcls.defaultAction");
|
|
460
|
+
expect(policyDefinition.props.policyRule.if.allOf[1].notEquals).toBe("Deny");
|
|
461
|
+
expect(policyDefinition.props.policyRule.then.effect).toBe("audit");
|
|
462
|
+
// Verify the synthesized config has the body property set
|
|
463
|
+
expect(azapiResource.body).toBeDefined();
|
|
464
|
+
});
|
|
465
|
+
it("should preserve Azure Policy expressions without converting them", () => {
|
|
466
|
+
const rule = {
|
|
467
|
+
if: {
|
|
468
|
+
field: "location",
|
|
469
|
+
notIn: "[parameters('allowedLocations')]",
|
|
470
|
+
},
|
|
471
|
+
then: {
|
|
472
|
+
effect: "[parameters('effect')]",
|
|
473
|
+
},
|
|
474
|
+
};
|
|
475
|
+
new policy_definition_1.PolicyDefinition(stack, "AzurePolicyExpressions", {
|
|
476
|
+
name: "azure-expressions-policy",
|
|
477
|
+
policyRule: rule,
|
|
478
|
+
parameters: {
|
|
479
|
+
allowedLocations: { type: "Array" },
|
|
480
|
+
effect: { type: "String" },
|
|
481
|
+
},
|
|
482
|
+
});
|
|
483
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
484
|
+
const stackConfig = JSON.parse(synthesized);
|
|
485
|
+
const azapiResource = Object.values(stackConfig.resource.azapi_resource)[0];
|
|
486
|
+
// Verify Azure Policy expressions are preserved in the construct's props
|
|
487
|
+
expect(rule.if.notIn).toBe("[parameters('allowedLocations')]");
|
|
488
|
+
expect(rule.then.effect).toBe("[parameters('effect')]");
|
|
489
|
+
// Verify the synthesized config has the body property set
|
|
490
|
+
expect(azapiResource.body).toBeDefined();
|
|
491
|
+
});
|
|
492
|
+
it("should preserve DeployIfNotExists policy with ARM template", () => {
|
|
493
|
+
const complexRule = {
|
|
494
|
+
if: {
|
|
495
|
+
field: "type",
|
|
496
|
+
equals: "Microsoft.Network/virtualNetworks",
|
|
497
|
+
},
|
|
498
|
+
then: {
|
|
499
|
+
effect: "DeployIfNotExists",
|
|
500
|
+
details: {
|
|
501
|
+
type: "Microsoft.Network/networkManagers/networkGroups/staticMembers",
|
|
502
|
+
deploymentScope: "subscription",
|
|
503
|
+
existenceScope: "subscription",
|
|
504
|
+
roleDefinitionIds: [
|
|
505
|
+
"/providers/Microsoft.Authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c",
|
|
506
|
+
],
|
|
507
|
+
deployment: {
|
|
508
|
+
location: "[field('location')]",
|
|
509
|
+
properties: {
|
|
510
|
+
mode: "incremental",
|
|
511
|
+
resourceGroup: "[variables('avnmResourceGroup')]",
|
|
512
|
+
subscriptionId: "[parameters('avnmSubscriptionId')]",
|
|
513
|
+
template: {
|
|
514
|
+
$schema: "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
|
|
515
|
+
contentVersion: "1.0.0.0",
|
|
516
|
+
parameters: {
|
|
517
|
+
vnetId: {
|
|
518
|
+
type: "string",
|
|
519
|
+
},
|
|
520
|
+
},
|
|
521
|
+
variables: {
|
|
522
|
+
staticMemberName: "[guid(parameters('vnetId'))]",
|
|
523
|
+
},
|
|
524
|
+
resources: [
|
|
525
|
+
{
|
|
526
|
+
type: "Microsoft.Network/networkManagers/networkGroups/staticMembers",
|
|
527
|
+
apiVersion: "2023-04-01",
|
|
528
|
+
name: "[concat(parameters('avnmId'), '/', variables('staticMemberName'))]",
|
|
529
|
+
properties: {
|
|
530
|
+
resourceId: "[parameters('vnetId')]",
|
|
531
|
+
},
|
|
532
|
+
},
|
|
533
|
+
],
|
|
534
|
+
outputs: {
|
|
535
|
+
memberId: {
|
|
536
|
+
type: "string",
|
|
537
|
+
value: "[resourceId('Microsoft.Network/networkManagers/networkGroups/staticMembers', variables('staticMemberName'))]",
|
|
538
|
+
},
|
|
539
|
+
},
|
|
540
|
+
},
|
|
541
|
+
parameters: {
|
|
542
|
+
vnetId: {
|
|
543
|
+
value: "[field('id')]",
|
|
544
|
+
},
|
|
545
|
+
},
|
|
546
|
+
},
|
|
547
|
+
},
|
|
548
|
+
},
|
|
549
|
+
},
|
|
550
|
+
};
|
|
551
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "DeployIfNotExistsPolicy", {
|
|
552
|
+
name: "deploy-if-not-exists-policy",
|
|
553
|
+
displayName: "Deploy If Not Exists with ARM Template",
|
|
554
|
+
policyRule: complexRule,
|
|
555
|
+
parameters: {
|
|
556
|
+
avnmSubscriptionId: { type: "String" },
|
|
557
|
+
},
|
|
558
|
+
});
|
|
559
|
+
expect(policyDefinition).toBeDefined();
|
|
560
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
561
|
+
const stackConfig = JSON.parse(synthesized);
|
|
562
|
+
const azapiResource = Object.values(stackConfig.resource.azapi_resource)[0];
|
|
563
|
+
const details = policyDefinition.props.policyRule.then.details;
|
|
564
|
+
// Verify deployment structure is preserved (not converted to null)
|
|
565
|
+
expect(details.deployment).toBeDefined();
|
|
566
|
+
expect(details.deployment.location).toBe("[field('location')]");
|
|
567
|
+
expect(details.deployment.properties).toBeDefined();
|
|
568
|
+
expect(details.deployment.properties.mode).toBe("incremental");
|
|
569
|
+
expect(details.deployment.properties.resourceGroup).toBe("[variables('avnmResourceGroup')]");
|
|
570
|
+
expect(details.deployment.properties.subscriptionId).toBe("[parameters('avnmSubscriptionId')]");
|
|
571
|
+
// Verify ARM template is fully preserved (not converted to null)
|
|
572
|
+
const template = details.deployment.properties.template;
|
|
573
|
+
expect(template).toBeDefined();
|
|
574
|
+
expect(template.$schema).toBe("https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#");
|
|
575
|
+
expect(template.contentVersion).toBe("1.0.0.0");
|
|
576
|
+
expect(template.parameters).toBeDefined();
|
|
577
|
+
expect(template.parameters.vnetId).toBeDefined();
|
|
578
|
+
expect(template.variables).toBeDefined();
|
|
579
|
+
expect(template.variables.staticMemberName).toBe("[guid(parameters('vnetId'))]");
|
|
580
|
+
expect(template.resources).toHaveLength(1);
|
|
581
|
+
expect(template.resources[0].name).toBe("[concat(parameters('avnmId'), '/', variables('staticMemberName'))]");
|
|
582
|
+
expect(template.outputs).toBeDefined();
|
|
583
|
+
expect(template.outputs.memberId.value).toBe("[resourceId('Microsoft.Network/networkManagers/networkGroups/staticMembers', variables('staticMemberName'))]");
|
|
584
|
+
// Verify ARM template parameters are preserved
|
|
585
|
+
const deploymentParams = details.deployment.properties.parameters;
|
|
586
|
+
expect(deploymentParams).toBeDefined();
|
|
587
|
+
expect(deploymentParams.vnetId.value).toBe("[field('id')]");
|
|
588
|
+
// Verify schema validation is disabled to allow complex nested structures
|
|
589
|
+
expect(azapiResource.schema_validation_enabled).toBe(false);
|
|
590
|
+
expect(azapiResource.ignore_missing_property).toBe(true);
|
|
591
|
+
// Verify the synthesized config has the body property set
|
|
592
|
+
expect(azapiResource.body).toBeDefined();
|
|
593
|
+
});
|
|
594
|
+
it("should preserve deeply nested logical operators", () => {
|
|
595
|
+
const complexRule = {
|
|
596
|
+
if: {
|
|
597
|
+
allOf: [
|
|
598
|
+
{
|
|
599
|
+
field: "type",
|
|
600
|
+
equals: "Microsoft.Network/virtualNetworks",
|
|
601
|
+
},
|
|
602
|
+
{
|
|
603
|
+
anyOf: [
|
|
604
|
+
{
|
|
605
|
+
field: "Microsoft.Network/virtualNetworks/enableDdosProtection",
|
|
606
|
+
equals: "false",
|
|
607
|
+
},
|
|
608
|
+
{
|
|
609
|
+
not: {
|
|
610
|
+
field: "Microsoft.Network/virtualNetworks/subnets[*].serviceEndpoints[*].service",
|
|
611
|
+
contains: "Microsoft.Storage",
|
|
612
|
+
},
|
|
613
|
+
},
|
|
614
|
+
],
|
|
615
|
+
},
|
|
616
|
+
],
|
|
617
|
+
},
|
|
618
|
+
then: {
|
|
619
|
+
effect: "audit",
|
|
620
|
+
},
|
|
621
|
+
};
|
|
622
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "DeeplyNested", {
|
|
623
|
+
name: "deeply-nested-policy",
|
|
624
|
+
policyRule: complexRule,
|
|
625
|
+
});
|
|
626
|
+
expect(policyDefinition.props.policyRule).toEqual(complexRule);
|
|
627
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
628
|
+
const stackConfig = JSON.parse(synthesized);
|
|
629
|
+
const azapiResource = Object.values(stackConfig.resource.azapi_resource)[0];
|
|
630
|
+
// Verify the deeply nested structure is preserved in the construct's props
|
|
631
|
+
expect(policyDefinition.props.policyRule.if.allOf[1].anyOf[1].not).toBeDefined();
|
|
632
|
+
expect(policyDefinition.props.policyRule.if.allOf[1].anyOf[1].not.field).toBe("Microsoft.Network/virtualNetworks/subnets[*].serviceEndpoints[*].service");
|
|
633
|
+
// Verify the synthesized config has the body property set
|
|
634
|
+
expect(azapiResource.body).toBeDefined();
|
|
635
|
+
});
|
|
636
|
+
});
|
|
637
|
+
describe("Error Handling", () => {
|
|
638
|
+
it("should handle invalid API versions gracefully", () => {
|
|
639
|
+
expect(() => {
|
|
640
|
+
new policy_definition_1.PolicyDefinition(stack, "InvalidAPI", {
|
|
641
|
+
name: "test-policy",
|
|
642
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
643
|
+
apiVersion: "invalid-version",
|
|
644
|
+
});
|
|
645
|
+
}).toThrow("Unsupported API version 'invalid-version'");
|
|
646
|
+
});
|
|
647
|
+
it("should handle validation errors when validation is enabled", () => {
|
|
648
|
+
expect(() => {
|
|
649
|
+
new policy_definition_1.PolicyDefinition(stack, "ValidationError", {
|
|
650
|
+
name: "test-policy",
|
|
651
|
+
policyRule: undefined, // Missing required policyRule
|
|
652
|
+
enableValidation: true,
|
|
653
|
+
});
|
|
654
|
+
}).toThrow("Required property 'policyRule' is missing");
|
|
655
|
+
});
|
|
656
|
+
it("should handle schema registration errors gracefully", () => {
|
|
657
|
+
expect(() => {
|
|
658
|
+
new policy_definition_1.PolicyDefinition(stack, "SchemaTest", {
|
|
659
|
+
name: "test-policy",
|
|
660
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
661
|
+
});
|
|
662
|
+
}).not.toThrow();
|
|
663
|
+
});
|
|
664
|
+
});
|
|
665
|
+
describe("JSII Compliance", () => {
|
|
666
|
+
it("should have JSII-compliant constructor", () => {
|
|
667
|
+
expect(() => {
|
|
668
|
+
new policy_definition_1.PolicyDefinition(stack, "JsiiTest", {
|
|
669
|
+
name: "jsii-test",
|
|
670
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
671
|
+
});
|
|
672
|
+
}).not.toThrow();
|
|
673
|
+
});
|
|
674
|
+
it("should have JSII-compliant properties", () => {
|
|
675
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "JsiiProps", {
|
|
676
|
+
name: "jsii-props",
|
|
677
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
678
|
+
});
|
|
679
|
+
expect(typeof policyDefinition.id).toBe("string");
|
|
680
|
+
expect(typeof policyDefinition.name).toBe("string");
|
|
681
|
+
expect(typeof policyDefinition.resolvedApiVersion).toBe("string");
|
|
682
|
+
expect(typeof policyDefinition.policyType).toBe("string");
|
|
683
|
+
expect(typeof policyDefinition.policyMode).toBe("string");
|
|
684
|
+
});
|
|
685
|
+
it("should have JSII-compliant methods", () => {
|
|
686
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "JsiiMethods", {
|
|
687
|
+
name: "jsii-methods",
|
|
688
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
689
|
+
});
|
|
690
|
+
expect(typeof policyDefinition.latestVersion).toBe("function");
|
|
691
|
+
expect(typeof policyDefinition.supportedVersions).toBe("function");
|
|
692
|
+
});
|
|
693
|
+
it("should serialize complex objects correctly", () => {
|
|
694
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "JsiiSerialization", {
|
|
695
|
+
name: "jsii-serialization",
|
|
696
|
+
policyRule: {
|
|
697
|
+
if: { field: "location", equals: "eastus" },
|
|
698
|
+
then: { effect: "deny" },
|
|
699
|
+
},
|
|
700
|
+
parameters: {
|
|
701
|
+
testParam: {
|
|
702
|
+
type: "String",
|
|
703
|
+
},
|
|
704
|
+
},
|
|
705
|
+
});
|
|
706
|
+
expect(() => JSON.stringify(policyDefinition.validationResult)).not.toThrow();
|
|
707
|
+
expect(() => JSON.stringify(policyDefinition.schema)).not.toThrow();
|
|
708
|
+
expect(() => JSON.stringify(policyDefinition.versionConfig)).not.toThrow();
|
|
709
|
+
});
|
|
710
|
+
});
|
|
711
|
+
describe("CDK Terraform Integration", () => {
|
|
712
|
+
it("should synthesize to valid Terraform configuration", () => {
|
|
713
|
+
new policy_definition_1.PolicyDefinition(stack, "SynthTest", {
|
|
714
|
+
name: "synth-test",
|
|
715
|
+
policyRule: {
|
|
716
|
+
if: {
|
|
717
|
+
field: "type",
|
|
718
|
+
equals: "Microsoft.Compute/virtualMachines",
|
|
719
|
+
},
|
|
720
|
+
then: {
|
|
721
|
+
effect: "audit",
|
|
722
|
+
},
|
|
723
|
+
},
|
|
724
|
+
});
|
|
725
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
726
|
+
expect(synthesized).toBeDefined();
|
|
727
|
+
const stackConfig = JSON.parse(synthesized);
|
|
728
|
+
expect(stackConfig.resource).toBeDefined();
|
|
729
|
+
});
|
|
730
|
+
it("should work in complex CDK constructs", () => {
|
|
731
|
+
class ComplexConstruct extends cdktf.TerraformStack {
|
|
732
|
+
constructor(scope, id) {
|
|
733
|
+
super(scope, id);
|
|
734
|
+
const policy1 = new policy_definition_1.PolicyDefinition(this, "Policy1", {
|
|
735
|
+
name: "policy-1",
|
|
736
|
+
displayName: "First Policy",
|
|
737
|
+
policyRule: { if: {}, then: { effect: "audit" } },
|
|
738
|
+
});
|
|
739
|
+
const policy2 = new policy_definition_1.PolicyDefinition(this, "Policy2", {
|
|
740
|
+
name: "policy-2",
|
|
741
|
+
displayName: "Second Policy",
|
|
742
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
743
|
+
apiVersion: "2021-06-01",
|
|
744
|
+
});
|
|
745
|
+
new cdktf.TerraformOutput(this, "Policy1Id", {
|
|
746
|
+
value: policy1.id,
|
|
747
|
+
});
|
|
748
|
+
new cdktf.TerraformOutput(this, "Policy2Id", {
|
|
749
|
+
value: policy2.id,
|
|
750
|
+
});
|
|
751
|
+
}
|
|
752
|
+
}
|
|
753
|
+
expect(() => {
|
|
754
|
+
new ComplexConstruct(app, "ComplexStack");
|
|
755
|
+
}).not.toThrow();
|
|
756
|
+
});
|
|
757
|
+
it("should handle multiple policy definitions in the same stack", () => {
|
|
758
|
+
const policy1 = new policy_definition_1.PolicyDefinition(stack, "PolicyDefinition1", {
|
|
759
|
+
name: "policy-1",
|
|
760
|
+
policyRule: { if: {}, then: { effect: "audit" } },
|
|
761
|
+
});
|
|
762
|
+
const policy2 = new policy_definition_1.PolicyDefinition(stack, "PolicyDefinition2", {
|
|
763
|
+
name: "policy-2",
|
|
764
|
+
policyRule: { if: {}, then: { effect: "deny" } },
|
|
765
|
+
apiVersion: "2021-06-01",
|
|
766
|
+
});
|
|
767
|
+
expect(policy1.resolvedApiVersion).toBe("2021-06-01");
|
|
768
|
+
expect(policy2.resolvedApiVersion).toBe("2021-06-01");
|
|
769
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
770
|
+
expect(synthesized).toBeDefined();
|
|
771
|
+
});
|
|
772
|
+
});
|
|
773
|
+
describe("Policy Definition Types", () => {
|
|
774
|
+
it("should support BuiltIn policy type", () => {
|
|
775
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "BuiltInPolicy", {
|
|
776
|
+
name: "builtin-policy",
|
|
777
|
+
policyType: "BuiltIn",
|
|
778
|
+
policyRule: { if: {}, then: { effect: "audit" } },
|
|
779
|
+
});
|
|
780
|
+
expect(policyDefinition.policyType).toBe("BuiltIn");
|
|
781
|
+
});
|
|
782
|
+
it("should support Static policy type", () => {
|
|
783
|
+
const policyDefinition = new policy_definition_1.PolicyDefinition(stack, "StaticPolicy", {
|
|
784
|
+
name: "static-policy",
|
|
785
|
+
policyType: "Static",
|
|
786
|
+
policyRule: { if: {}, then: { effect: "audit" } },
|
|
787
|
+
});
|
|
788
|
+
expect(policyDefinition.policyType).toBe("Static");
|
|
789
|
+
});
|
|
790
|
+
it("should support different policy modes", () => {
|
|
791
|
+
const indexedPolicy = new policy_definition_1.PolicyDefinition(stack, "IndexedPolicy", {
|
|
792
|
+
name: "indexed-policy",
|
|
793
|
+
mode: "Indexed",
|
|
794
|
+
policyRule: { if: {}, then: { effect: "audit" } },
|
|
795
|
+
});
|
|
796
|
+
expect(indexedPolicy.policyMode).toBe("Indexed");
|
|
797
|
+
const resourceProviderPolicy = new policy_definition_1.PolicyDefinition(stack, "ResourceProviderPolicy", {
|
|
798
|
+
name: "resource-provider-policy",
|
|
799
|
+
mode: "Microsoft.KeyVault.Data",
|
|
800
|
+
policyRule: { if: {}, then: { effect: "audit" } },
|
|
801
|
+
});
|
|
802
|
+
expect(resourceProviderPolicy.policyMode).toBe("Microsoft.KeyVault.Data");
|
|
803
|
+
});
|
|
804
|
+
});
|
|
805
|
+
});
|
|
806
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy-definition.spec.js","sourceRoot":"","sources":["../../../src/azure-policydefinition/test/policy-definition.spec.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Comprehensive tests for the unified PolicyDefinition implementation\n *\n * This test suite validates the unified PolicyDefinition class that uses\n * the VersionedAzapiResource framework. Tests cover automatic version resolution,\n * explicit version pinning, schema validation, property transformation, and\n * policy-specific functionality.\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  PolicyDefinition,\n  PolicyDefinitionProps,\n} from \"../lib/policy-definition\";\nimport {\n  ALL_POLICY_DEFINITION_VERSIONS,\n  POLICY_DEFINITION_TYPE,\n} from \"../lib/policy-definition-schemas\";\n\ndescribe(\"PolicyDefinition - Unified Implementation\", () => {\n  let app: cdktf.App;\n  let stack: cdktf.TerraformStack;\n  let manager: ApiVersionManager;\n\n  beforeEach(() => {\n    app = Testing.app();\n    stack = new cdktf.TerraformStack(app, \"TestStack\");\n    manager = ApiVersionManager.instance();\n\n    // Ensure Policy Definition schemas are registered\n    try {\n      manager.registerResourceType(\n        POLICY_DEFINITION_TYPE,\n        ALL_POLICY_DEFINITION_VERSIONS,\n      );\n    } catch (error) {\n      // Ignore if already registered\n    }\n  });\n\n  describe(\"Constructor and Basic Properties\", () => {\n    it(\"should create policy definition with automatic latest version resolution\", () => {\n      const props: PolicyDefinitionProps = {\n        name: \"test-policy\",\n        policyRule: {\n          if: {\n            field: \"tags['Environment']\",\n            exists: \"false\",\n          },\n          then: {\n            effect: \"deny\",\n          },\n        },\n      };\n\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"TestPolicyDefinition\",\n        props,\n      );\n\n      expect(policyDefinition).toBeInstanceOf(PolicyDefinition);\n      expect(policyDefinition.resolvedApiVersion).toBe(\"2021-06-01\"); // Latest version\n      expect(policyDefinition.props).toBe(props);\n      expect(policyDefinition.name).toBe(\"test-policy\");\n    });\n\n    it(\"should create policy definition with explicit version pinning\", () => {\n      const props: PolicyDefinitionProps = {\n        name: \"test-policy-pinned\",\n        apiVersion: \"2021-06-01\",\n        policyRule: {\n          if: {\n            field: \"type\",\n            equals: \"Microsoft.Compute/virtualMachines\",\n          },\n          then: {\n            effect: \"audit\",\n          },\n        },\n      };\n\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"TestPolicyDefinition\",\n        props,\n      );\n\n      expect(policyDefinition.resolvedApiVersion).toBe(\"2021-06-01\");\n    });\n\n    it(\"should create policy definition with all optional properties\", () => {\n      const props: PolicyDefinitionProps = {\n        name: \"test-policy-full\",\n        displayName: \"Test Policy Definition\",\n        description: \"A test policy definition for unit testing\",\n        policyType: \"Custom\",\n        mode: \"All\",\n        policyRule: {\n          if: {\n            field: \"location\",\n            notIn: [\"eastus\", \"westus\"],\n          },\n          then: {\n            effect: \"deny\",\n          },\n        },\n        parameters: {\n          allowedLocations: {\n            type: \"Array\",\n            metadata: {\n              displayName: \"Allowed locations\",\n              description: \"The list of allowed locations for resources\",\n            },\n          },\n        },\n        metadata: {\n          category: \"General\",\n          version: \"1.0.0\",\n        },\n        ignoreChanges: [\"metadata\"],\n        enableValidation: true,\n        enableMigrationAnalysis: true,\n        enableTransformation: true,\n      };\n\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"TestPolicyDefinition\",\n        props,\n      );\n\n      expect(policyDefinition.props.displayName).toBe(\"Test Policy Definition\");\n      expect(policyDefinition.props.description).toBe(\n        \"A test policy definition for unit testing\",\n      );\n      expect(policyDefinition.props.policyType).toBe(\"Custom\");\n      expect(policyDefinition.props.mode).toBe(\"All\");\n      expect(policyDefinition.props.parameters).toBeDefined();\n      expect(policyDefinition.props.metadata).toBeDefined();\n    });\n\n    it(\"should use default name when name is not provided\", () => {\n      const props: PolicyDefinitionProps = {\n        policyRule: {\n          if: {\n            field: \"type\",\n            equals: \"Microsoft.Storage/storageAccounts\",\n          },\n          then: {\n            effect: \"audit\",\n          },\n        },\n      };\n\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"TestPolicyDefinition\",\n        props,\n      );\n\n      expect(policyDefinition.name).toBe(\"TestPolicyDefinition\");\n    });\n\n    it(\"should require policyRule to be provided\", () => {\n      const props: any = {\n        name: \"test-policy\",\n      };\n\n      expect(() => {\n        new PolicyDefinition(stack, \"TestPolicyDefinition\", props);\n      }).toThrow(\"Required property 'policyRule' is missing\");\n    });\n  });\n\n  describe(\"Framework Integration\", () => {\n    it(\"should resolve latest API version automatically\", () => {\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"TestPolicyDefinition\",\n        {\n          name: \"test-policy\",\n          policyRule: { if: {}, then: { effect: \"deny\" } },\n        },\n      );\n\n      expect(policyDefinition.resolvedApiVersion).toBe(\"2021-06-01\");\n      expect(policyDefinition.latestVersion()).toBe(\"2021-06-01\");\n    });\n\n    it(\"should support all registered API versions\", () => {\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"TestPolicyDefinition\",\n        {\n          name: \"test-policy\",\n          policyRule: { if: {}, then: { effect: \"deny\" } },\n        },\n      );\n\n      const supportedVersions = policyDefinition.supportedVersions();\n      expect(supportedVersions).toContain(\"2021-06-01\");\n    });\n\n    it(\"should validate version support\", () => {\n      // Valid version\n      expect(() => {\n        new PolicyDefinition(stack, \"ValidVersion\", {\n          name: \"test-policy\",\n          policyRule: { if: {}, then: { effect: \"deny\" } },\n          apiVersion: \"2021-06-01\",\n        });\n      }).not.toThrow();\n\n      // Invalid version\n      expect(() => {\n        new PolicyDefinition(stack, \"InvalidVersion\", {\n          name: \"test-policy\",\n          policyRule: { if: {}, then: { effect: \"deny\" } },\n          apiVersion: \"2022-01-01\",\n        });\n      }).toThrow(\"Unsupported API version '2022-01-01'\");\n    });\n\n    it(\"should load correct schema for resolved version\", () => {\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"TestPolicyDefinition\",\n        {\n          name: \"test-policy\",\n          policyRule: { if: {}, then: { effect: \"deny\" } },\n          apiVersion: \"2021-06-01\",\n        },\n      );\n\n      expect(policyDefinition.schema).toBeDefined();\n      expect(policyDefinition.schema.resourceType).toBe(POLICY_DEFINITION_TYPE);\n      expect(policyDefinition.schema.version).toBe(\"2021-06-01\");\n      expect(policyDefinition.schema.properties).toBeDefined();\n    });\n\n    it(\"should load version configuration correctly\", () => {\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"TestPolicyDefinition\",\n        {\n          name: \"test-policy\",\n          policyRule: { if: {}, then: { effect: \"deny\" } },\n        },\n      );\n\n      expect(policyDefinition.versionConfig).toBeDefined();\n      expect(policyDefinition.versionConfig.version).toBe(\"2021-06-01\");\n      expect(policyDefinition.versionConfig.supportLevel).toBe(\n        VersionSupportLevel.ACTIVE,\n      );\n    });\n  });\n\n  describe(\"Property Validation\", () => {\n    it(\"should validate properties when validation is enabled\", () => {\n      const props: PolicyDefinitionProps = {\n        name: \"test-policy\",\n        policyRule: {\n          if: {\n            field: \"type\",\n            equals: \"Microsoft.Compute/virtualMachines\",\n          },\n          then: {\n            effect: \"audit\",\n          },\n        },\n        enableValidation: true,\n      };\n\n      expect(() => {\n        new PolicyDefinition(stack, \"TestPolicyDefinition\", props);\n      }).not.toThrow();\n    });\n\n    it(\"should have validation results for valid properties\", () => {\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"TestPolicyDefinition\",\n        {\n          name: \"valid-policy\",\n          displayName: \"Valid Policy\",\n          policyRule: { if: {}, then: { effect: \"deny\" } },\n          enableValidation: true,\n        },\n      );\n\n      expect(policyDefinition.validationResult).toBeDefined();\n      expect(policyDefinition.validationResult!.valid).toBe(true);\n      expect(policyDefinition.validationResult!.errors).toHaveLength(0);\n    });\n\n    it(\"should skip validation when disabled\", () => {\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"TestPolicyDefinition\",\n        {\n          name: \"test-policy\",\n          policyRule: { if: {}, then: { effect: \"deny\" } },\n          enableValidation: false,\n        },\n      );\n\n      expect(policyDefinition).toBeDefined();\n    });\n  });\n\n  describe(\"Migration Analysis\", () => {\n    it(\"should skip migration analysis for single version\", () => {\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"TestPolicyDefinition\",\n        {\n          name: \"test-policy\",\n          policyRule: { if: {}, then: { effect: \"deny\" } },\n          apiVersion: \"2021-06-01\",\n        },\n      );\n\n      // Since there's only one version, migration analysis should be skipped\n      expect(policyDefinition).toBeDefined();\n    });\n\n    it(\"should skip migration analysis when disabled\", () => {\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"TestPolicyDefinition\",\n        {\n          name: \"test-policy\",\n          policyRule: { if: {}, then: { effect: \"deny\" } },\n          enableMigrationAnalysis: false,\n        },\n      );\n\n      expect(policyDefinition.migrationAnalysis).toBeUndefined();\n    });\n  });\n\n  describe(\"Resource Creation and Body\", () => {\n    it(\"should create correct resource body with minimal properties\", () => {\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"TestPolicyDefinition\",\n        {\n          name: \"test-policy\",\n          policyRule: {\n            if: {\n              field: \"tags['Environment']\",\n              exists: \"false\",\n            },\n            then: {\n              effect: \"deny\",\n            },\n          },\n        },\n      );\n\n      expect(policyDefinition).toBeDefined();\n      expect(policyDefinition.props.policyRule).toBeDefined();\n    });\n\n    it(\"should create correct resource body with all properties\", () => {\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"TestPolicyDefinition\",\n        {\n          name: \"test-policy\",\n          displayName: \"Test Policy\",\n          description: \"A test policy\",\n          policyType: \"Custom\",\n          mode: \"Indexed\",\n          policyRule: {\n            if: {\n              field: \"location\",\n              notIn: [\"eastus\", \"westus\"],\n            },\n            then: {\n              effect: \"deny\",\n            },\n          },\n          parameters: {\n            allowedLocations: {\n              type: \"Array\",\n            },\n          },\n          metadata: {\n            category: \"Compliance\",\n          },\n        },\n      );\n\n      expect(policyDefinition).toBeDefined();\n      expect(policyDefinition.props.displayName).toBe(\"Test Policy\");\n      expect(policyDefinition.props.policyType).toBe(\"Custom\");\n      expect(policyDefinition.props.mode).toBe(\"Indexed\");\n    });\n\n    it(\"should create Terraform outputs\", () => {\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"TestPolicyDefinition\",\n        {\n          name: \"test-policy-outputs\",\n          policyRule: { if: {}, then: { effect: \"deny\" } },\n        },\n      );\n\n      expect(policyDefinition.idOutput).toBeInstanceOf(cdktf.TerraformOutput);\n      expect(policyDefinition.nameOutput).toBeInstanceOf(cdktf.TerraformOutput);\n    });\n  });\n\n  describe(\"Public Methods and Properties\", () => {\n    let policyDefinition: PolicyDefinition;\n\n    beforeEach(() => {\n      policyDefinition = new PolicyDefinition(stack, \"TestPolicyDefinition\", {\n        name: \"test-policy\",\n        displayName: \"Test Policy\",\n        policyType: \"Custom\",\n        mode: \"All\",\n        policyRule: {\n          if: {\n            field: \"type\",\n            equals: \"Microsoft.Compute/virtualMachines\",\n          },\n          then: {\n            effect: \"audit\",\n          },\n        },\n      });\n    });\n\n    it(\"should have correct id format\", () => {\n      expect(policyDefinition.id).toMatch(/^\\$\\{.*\\.id\\}$/);\n    });\n\n    it(\"should have resourceId property matching id\", () => {\n      expect(policyDefinition.resourceId).toBe(policyDefinition.id);\n    });\n\n    it(\"should return correct policyType\", () => {\n      expect(policyDefinition.policyType).toBe(\"Custom\");\n    });\n\n    it(\"should return correct policyMode\", () => {\n      expect(policyDefinition.policyMode).toBe(\"All\");\n    });\n\n    it(\"should use default policyType when not provided\", () => {\n      const defaultPolicy = new PolicyDefinition(stack, \"DefaultTypePolicy\", {\n        name: \"default-policy\",\n        policyRule: { if: {}, then: { effect: \"deny\" } },\n      });\n\n      expect(defaultPolicy.policyType).toBe(\"Custom\");\n    });\n\n    it(\"should use default mode when not provided\", () => {\n      const defaultPolicy = new PolicyDefinition(stack, \"DefaultModePolicy\", {\n        name: \"default-policy\",\n        policyRule: { if: {}, then: { effect: \"deny\" } },\n      });\n\n      expect(defaultPolicy.policyMode).toBe(\"All\");\n    });\n  });\n\n  describe(\"Ignore Changes Configuration\", () => {\n    it(\"should apply ignore changes lifecycle rules\", () => {\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"IgnoreChangesPolicy\",\n        {\n          name: \"test-policy\",\n          policyRule: { if: {}, then: { effect: \"deny\" } },\n          ignoreChanges: [\"metadata\", \"description\"],\n        },\n      );\n\n      expect(policyDefinition).toBeInstanceOf(PolicyDefinition);\n    });\n\n    it(\"should handle empty ignore changes array\", () => {\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"EmptyIgnorePolicy\",\n        {\n          name: \"test-policy\",\n          policyRule: { if: {}, then: { effect: \"deny\" } },\n          ignoreChanges: [],\n        },\n      );\n\n      expect(policyDefinition).toBeInstanceOf(PolicyDefinition);\n    });\n  });\n\n  describe(\"Policy Rule Validation\", () => {\n    it(\"should accept complex policy rules\", () => {\n      const complexRule = {\n        if: {\n          allOf: [\n            {\n              field: \"type\",\n              equals: \"Microsoft.Storage/storageAccounts\",\n            },\n            {\n              field: \"Microsoft.Storage/storageAccounts/enableHttpsTrafficOnly\",\n              notEquals: \"true\",\n            },\n          ],\n        },\n        then: {\n          effect: \"deny\",\n        },\n      };\n\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"ComplexRulePolicy\",\n        {\n          name: \"complex-policy\",\n          policyRule: complexRule,\n        },\n      );\n\n      expect(policyDefinition).toBeDefined();\n      expect(policyDefinition.props.policyRule).toEqual(complexRule);\n    });\n\n    it(\"should accept policy rules with parameters\", () => {\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"ParameterizedPolicy\",\n        {\n          name: \"parameterized-policy\",\n          policyRule: {\n            if: {\n              field: \"[concat('tags[', parameters('tagName'), ']')]\",\n              exists: \"false\",\n            },\n            then: {\n              effect: \"[parameters('effect')]\",\n            },\n          },\n          parameters: {\n            tagName: {\n              type: \"String\",\n              metadata: {\n                displayName: \"Tag Name\",\n                description: \"Name of the tag to check\",\n              },\n            },\n            effect: {\n              type: \"String\",\n              allowedValues: [\"audit\", \"deny\"],\n              defaultValue: \"audit\",\n            },\n          },\n        },\n      );\n\n      expect(policyDefinition).toBeDefined();\n      expect(policyDefinition.props.parameters).toBeDefined();\n    });\n\n    it(\"should preserve complex allOf conditions with multiple field comparisons\", () => {\n      const complexRule = {\n        if: {\n          allOf: [\n            {\n              field: \"type\",\n              equals: \"Microsoft.Storage/storageAccounts\",\n            },\n            {\n              field:\n                \"Microsoft.Storage/storageAccounts/networkAcls.defaultAction\",\n              notEquals: \"Deny\",\n            },\n          ],\n        },\n        then: {\n          effect: \"audit\",\n        },\n      };\n\n      const policyDefinition = new PolicyDefinition(stack, \"ComplexAllOf\", {\n        name: \"complex-allof-policy\",\n        displayName: \"Complex AllOf Policy\",\n        policyRule: complexRule,\n      });\n\n      expect(policyDefinition).toBeDefined();\n      expect(policyDefinition.props.policyRule).toEqual(complexRule);\n\n      // Synthesize and verify the structure is preserved\n      const synthesized = Testing.synth(stack);\n      const stackConfig = JSON.parse(synthesized);\n      const azapiResource = Object.values(\n        stackConfig.resource.azapi_resource,\n      )[0] as any;\n\n      // The body is jsonencode() wrapped, so we need to parse the actual policy rule from props\n      expect(policyDefinition.props.policyRule.if.allOf).toHaveLength(2);\n      expect(policyDefinition.props.policyRule.if.allOf[0].field).toBe(\"type\");\n      expect(policyDefinition.props.policyRule.if.allOf[0].equals).toBe(\n        \"Microsoft.Storage/storageAccounts\",\n      );\n      expect(policyDefinition.props.policyRule.if.allOf[1].field).toBe(\n        \"Microsoft.Storage/storageAccounts/networkAcls.defaultAction\",\n      );\n      expect(policyDefinition.props.policyRule.if.allOf[1].notEquals).toBe(\n        \"Deny\",\n      );\n      expect(policyDefinition.props.policyRule.then.effect).toBe(\"audit\");\n\n      // Verify the synthesized config has the body property set\n      expect(azapiResource.body).toBeDefined();\n    });\n\n    it(\"should preserve Azure Policy expressions without converting them\", () => {\n      const rule = {\n        if: {\n          field: \"location\",\n          notIn: \"[parameters('allowedLocations')]\",\n        },\n        then: {\n          effect: \"[parameters('effect')]\",\n        },\n      };\n\n      new PolicyDefinition(stack, \"AzurePolicyExpressions\", {\n        name: \"azure-expressions-policy\",\n        policyRule: rule,\n        parameters: {\n          allowedLocations: { type: \"Array\" },\n          effect: { type: \"String\" },\n        },\n      });\n\n      const synthesized = Testing.synth(stack);\n      const stackConfig = JSON.parse(synthesized);\n      const azapiResource = Object.values(\n        stackConfig.resource.azapi_resource,\n      )[0] as any;\n\n      // Verify Azure Policy expressions are preserved in the construct's props\n      expect(rule.if.notIn).toBe(\"[parameters('allowedLocations')]\");\n      expect(rule.then.effect).toBe(\"[parameters('effect')]\");\n\n      // Verify the synthesized config has the body property set\n      expect(azapiResource.body).toBeDefined();\n    });\n\n    it(\"should preserve DeployIfNotExists policy with ARM template\", () => {\n      const complexRule = {\n        if: {\n          field: \"type\",\n          equals: \"Microsoft.Network/virtualNetworks\",\n        },\n        then: {\n          effect: \"DeployIfNotExists\",\n          details: {\n            type: \"Microsoft.Network/networkManagers/networkGroups/staticMembers\",\n            deploymentScope: \"subscription\",\n            existenceScope: \"subscription\",\n            roleDefinitionIds: [\n              \"/providers/Microsoft.Authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\",\n            ],\n            deployment: {\n              location: \"[field('location')]\",\n              properties: {\n                mode: \"incremental\",\n                resourceGroup: \"[variables('avnmResourceGroup')]\",\n                subscriptionId: \"[parameters('avnmSubscriptionId')]\",\n                template: {\n                  $schema:\n                    \"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#\",\n                  contentVersion: \"1.0.0.0\",\n                  parameters: {\n                    vnetId: {\n                      type: \"string\",\n                    },\n                  },\n                  variables: {\n                    staticMemberName: \"[guid(parameters('vnetId'))]\",\n                  },\n                  resources: [\n                    {\n                      type: \"Microsoft.Network/networkManagers/networkGroups/staticMembers\",\n                      apiVersion: \"2023-04-01\",\n                      name: \"[concat(parameters('avnmId'), '/', variables('staticMemberName'))]\",\n                      properties: {\n                        resourceId: \"[parameters('vnetId')]\",\n                      },\n                    },\n                  ],\n                  outputs: {\n                    memberId: {\n                      type: \"string\",\n                      value:\n                        \"[resourceId('Microsoft.Network/networkManagers/networkGroups/staticMembers', variables('staticMemberName'))]\",\n                    },\n                  },\n                },\n                parameters: {\n                  vnetId: {\n                    value: \"[field('id')]\",\n                  },\n                },\n              },\n            },\n          },\n        },\n      };\n\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"DeployIfNotExistsPolicy\",\n        {\n          name: \"deploy-if-not-exists-policy\",\n          displayName: \"Deploy If Not Exists with ARM Template\",\n          policyRule: complexRule,\n          parameters: {\n            avnmSubscriptionId: { type: \"String\" },\n          },\n        },\n      );\n\n      expect(policyDefinition).toBeDefined();\n\n      const synthesized = Testing.synth(stack);\n      const stackConfig = JSON.parse(synthesized);\n      const azapiResource = Object.values(\n        stackConfig.resource.azapi_resource,\n      )[0] as any;\n\n      const details = policyDefinition.props.policyRule.then.details;\n\n      // Verify deployment structure is preserved (not converted to null)\n      expect(details.deployment).toBeDefined();\n      expect(details.deployment.location).toBe(\"[field('location')]\");\n      expect(details.deployment.properties).toBeDefined();\n      expect(details.deployment.properties.mode).toBe(\"incremental\");\n      expect(details.deployment.properties.resourceGroup).toBe(\n        \"[variables('avnmResourceGroup')]\",\n      );\n      expect(details.deployment.properties.subscriptionId).toBe(\n        \"[parameters('avnmSubscriptionId')]\",\n      );\n\n      // Verify ARM template is fully preserved (not converted to null)\n      const template = details.deployment.properties.template;\n      expect(template).toBeDefined();\n      expect(template.$schema).toBe(\n        \"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#\",\n      );\n      expect(template.contentVersion).toBe(\"1.0.0.0\");\n      expect(template.parameters).toBeDefined();\n      expect(template.parameters.vnetId).toBeDefined();\n      expect(template.variables).toBeDefined();\n      expect(template.variables.staticMemberName).toBe(\n        \"[guid(parameters('vnetId'))]\",\n      );\n      expect(template.resources).toHaveLength(1);\n      expect(template.resources[0].name).toBe(\n        \"[concat(parameters('avnmId'), '/', variables('staticMemberName'))]\",\n      );\n      expect(template.outputs).toBeDefined();\n      expect(template.outputs.memberId.value).toBe(\n        \"[resourceId('Microsoft.Network/networkManagers/networkGroups/staticMembers', variables('staticMemberName'))]\",\n      );\n\n      // Verify ARM template parameters are preserved\n      const deploymentParams = details.deployment.properties.parameters;\n      expect(deploymentParams).toBeDefined();\n      expect(deploymentParams.vnetId.value).toBe(\"[field('id')]\");\n\n      // Verify schema validation is disabled to allow complex nested structures\n      expect(azapiResource.schema_validation_enabled).toBe(false);\n      expect(azapiResource.ignore_missing_property).toBe(true);\n\n      // Verify the synthesized config has the body property set\n      expect(azapiResource.body).toBeDefined();\n    });\n\n    it(\"should preserve deeply nested logical operators\", () => {\n      const complexRule = {\n        if: {\n          allOf: [\n            {\n              field: \"type\",\n              equals: \"Microsoft.Network/virtualNetworks\",\n            },\n            {\n              anyOf: [\n                {\n                  field:\n                    \"Microsoft.Network/virtualNetworks/enableDdosProtection\",\n                  equals: \"false\",\n                },\n                {\n                  not: {\n                    field:\n                      \"Microsoft.Network/virtualNetworks/subnets[*].serviceEndpoints[*].service\",\n                    contains: \"Microsoft.Storage\",\n                  },\n                },\n              ],\n            },\n          ],\n        },\n        then: {\n          effect: \"audit\",\n        },\n      };\n\n      const policyDefinition = new PolicyDefinition(stack, \"DeeplyNested\", {\n        name: \"deeply-nested-policy\",\n        policyRule: complexRule,\n      });\n\n      expect(policyDefinition.props.policyRule).toEqual(complexRule);\n\n      const synthesized = Testing.synth(stack);\n      const stackConfig = JSON.parse(synthesized);\n      const azapiResource = Object.values(\n        stackConfig.resource.azapi_resource,\n      )[0] as any;\n\n      // Verify the deeply nested structure is preserved in the construct's props\n      expect(\n        policyDefinition.props.policyRule.if.allOf[1].anyOf[1].not,\n      ).toBeDefined();\n      expect(\n        policyDefinition.props.policyRule.if.allOf[1].anyOf[1].not.field,\n      ).toBe(\n        \"Microsoft.Network/virtualNetworks/subnets[*].serviceEndpoints[*].service\",\n      );\n\n      // Verify the synthesized config has the body property set\n      expect(azapiResource.body).toBeDefined();\n    });\n  });\n\n  describe(\"Error Handling\", () => {\n    it(\"should handle invalid API versions gracefully\", () => {\n      expect(() => {\n        new PolicyDefinition(stack, \"InvalidAPI\", {\n          name: \"test-policy\",\n          policyRule: { if: {}, then: { effect: \"deny\" } },\n          apiVersion: \"invalid-version\",\n        });\n      }).toThrow(\"Unsupported API version 'invalid-version'\");\n    });\n\n    it(\"should handle validation errors when validation is enabled\", () => {\n      expect(() => {\n        new PolicyDefinition(stack, \"ValidationError\", {\n          name: \"test-policy\",\n          policyRule: undefined as any, // Missing required policyRule\n          enableValidation: true,\n        });\n      }).toThrow(\"Required property 'policyRule' is missing\");\n    });\n\n    it(\"should handle schema registration errors gracefully\", () => {\n      expect(() => {\n        new PolicyDefinition(stack, \"SchemaTest\", {\n          name: \"test-policy\",\n          policyRule: { if: {}, then: { effect: \"deny\" } },\n        });\n      }).not.toThrow();\n    });\n  });\n\n  describe(\"JSII Compliance\", () => {\n    it(\"should have JSII-compliant constructor\", () => {\n      expect(() => {\n        new PolicyDefinition(stack, \"JsiiTest\", {\n          name: \"jsii-test\",\n          policyRule: { if: {}, then: { effect: \"deny\" } },\n        });\n      }).not.toThrow();\n    });\n\n    it(\"should have JSII-compliant properties\", () => {\n      const policyDefinition = new PolicyDefinition(stack, \"JsiiProps\", {\n        name: \"jsii-props\",\n        policyRule: { if: {}, then: { effect: \"deny\" } },\n      });\n\n      expect(typeof policyDefinition.id).toBe(\"string\");\n      expect(typeof policyDefinition.name).toBe(\"string\");\n      expect(typeof policyDefinition.resolvedApiVersion).toBe(\"string\");\n      expect(typeof policyDefinition.policyType).toBe(\"string\");\n      expect(typeof policyDefinition.policyMode).toBe(\"string\");\n    });\n\n    it(\"should have JSII-compliant methods\", () => {\n      const policyDefinition = new PolicyDefinition(stack, \"JsiiMethods\", {\n        name: \"jsii-methods\",\n        policyRule: { if: {}, then: { effect: \"deny\" } },\n      });\n\n      expect(typeof policyDefinition.latestVersion).toBe(\"function\");\n      expect(typeof policyDefinition.supportedVersions).toBe(\"function\");\n    });\n\n    it(\"should serialize complex objects correctly\", () => {\n      const policyDefinition = new PolicyDefinition(\n        stack,\n        \"JsiiSerialization\",\n        {\n          name: \"jsii-serialization\",\n          policyRule: {\n            if: { field: \"location\", equals: \"eastus\" },\n            then: { effect: \"deny\" },\n          },\n          parameters: {\n            testParam: {\n              type: \"String\",\n            },\n          },\n        },\n      );\n\n      expect(() =>\n        JSON.stringify(policyDefinition.validationResult),\n      ).not.toThrow();\n      expect(() => JSON.stringify(policyDefinition.schema)).not.toThrow();\n      expect(() =>\n        JSON.stringify(policyDefinition.versionConfig),\n      ).not.toThrow();\n    });\n  });\n\n  describe(\"CDK Terraform Integration\", () => {\n    it(\"should synthesize to valid Terraform configuration\", () => {\n      new PolicyDefinition(stack, \"SynthTest\", {\n        name: \"synth-test\",\n        policyRule: {\n          if: {\n            field: \"type\",\n            equals: \"Microsoft.Compute/virtualMachines\",\n          },\n          then: {\n            effect: \"audit\",\n          },\n        },\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 work in complex CDK constructs\", () => {\n      class ComplexConstruct extends cdktf.TerraformStack {\n        constructor(scope: cdktf.App, id: string) {\n          super(scope, id);\n\n          const policy1 = new PolicyDefinition(this, \"Policy1\", {\n            name: \"policy-1\",\n            displayName: \"First Policy\",\n            policyRule: { if: {}, then: { effect: \"audit\" } },\n          });\n\n          const policy2 = new PolicyDefinition(this, \"Policy2\", {\n            name: \"policy-2\",\n            displayName: \"Second Policy\",\n            policyRule: { if: {}, then: { effect: \"deny\" } },\n            apiVersion: \"2021-06-01\",\n          });\n\n          new cdktf.TerraformOutput(this, \"Policy1Id\", {\n            value: policy1.id,\n          });\n\n          new cdktf.TerraformOutput(this, \"Policy2Id\", {\n            value: policy2.id,\n          });\n        }\n      }\n\n      expect(() => {\n        new ComplexConstruct(app, \"ComplexStack\");\n      }).not.toThrow();\n    });\n\n    it(\"should handle multiple policy definitions in the same stack\", () => {\n      const policy1 = new PolicyDefinition(stack, \"PolicyDefinition1\", {\n        name: \"policy-1\",\n        policyRule: { if: {}, then: { effect: \"audit\" } },\n      });\n\n      const policy2 = new PolicyDefinition(stack, \"PolicyDefinition2\", {\n        name: \"policy-2\",\n        policyRule: { if: {}, then: { effect: \"deny\" } },\n        apiVersion: \"2021-06-01\",\n      });\n\n      expect(policy1.resolvedApiVersion).toBe(\"2021-06-01\");\n      expect(policy2.resolvedApiVersion).toBe(\"2021-06-01\");\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toBeDefined();\n    });\n  });\n\n  describe(\"Policy Definition Types\", () => {\n    it(\"should support BuiltIn policy type\", () => {\n      const policyDefinition = new PolicyDefinition(stack, \"BuiltInPolicy\", {\n        name: \"builtin-policy\",\n        policyType: \"BuiltIn\",\n        policyRule: { if: {}, then: { effect: \"audit\" } },\n      });\n\n      expect(policyDefinition.policyType).toBe(\"BuiltIn\");\n    });\n\n    it(\"should support Static policy type\", () => {\n      const policyDefinition = new PolicyDefinition(stack, \"StaticPolicy\", {\n        name: \"static-policy\",\n        policyType: \"Static\",\n        policyRule: { if: {}, then: { effect: \"audit\" } },\n      });\n\n      expect(policyDefinition.policyType).toBe(\"Static\");\n    });\n\n    it(\"should support different policy modes\", () => {\n      const indexedPolicy = new PolicyDefinition(stack, \"IndexedPolicy\", {\n        name: \"indexed-policy\",\n        mode: \"Indexed\",\n        policyRule: { if: {}, then: { effect: \"audit\" } },\n      });\n\n      expect(indexedPolicy.policyMode).toBe(\"Indexed\");\n\n      const resourceProviderPolicy = new PolicyDefinition(\n        stack,\n        \"ResourceProviderPolicy\",\n        {\n          name: \"resource-provider-policy\",\n          mode: \"Microsoft.KeyVault.Data\",\n          policyRule: { if: {}, then: { effect: \"audit\" } },\n        },\n      );\n\n      expect(resourceProviderPolicy.policyMode).toBe(\"Microsoft.KeyVault.Data\");\n    });\n  });\n});\n"]}
|