@microsoft/terraform-cdk-constructs 0.0.3-pre.10 → 0.0.3-pre.12
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 +858 -681
- package/API.md +499 -405
- package/README.md +4 -5
- package/docs/testing.md +39 -137
- package/lib/azure-actiongroup/lib/actiongroup.d.ts +1 -1
- package/lib/azure-actiongroup/lib/actiongroup.js +4 -4
- package/lib/azure-actiongroup/model/action-group-props.d.ts +3 -2
- package/lib/azure-actiongroup/model/action-group-props.js +1 -1
- package/lib/azure-actiongroup/test/AzureActionGroup.integ.js +66 -0
- package/lib/azure-actiongroup/test/AzureActionGroup.spec.js +5 -33
- package/lib/azure-applicationgateway/lib/gateway.d.ts +5 -3
- package/lib/azure-applicationgateway/lib/gateway.js +14 -7
- package/lib/azure-applicationgateway/test/AzureApplicationGateway.integ.d.ts +1 -0
- package/lib/azure-applicationgateway/test/AzureApplicationGateway.integ.js +272 -0
- package/lib/azure-applicationgateway/test/AzureApplicationGateway.spec.js +3 -35
- package/lib/azure-applicationinsights/lib/appinsights.d.ts +4 -3
- package/lib/azure-applicationinsights/lib/appinsights.js +6 -6
- package/lib/azure-applicationinsights/test/AzureAppInsights.integ.d.ts +1 -0
- package/lib/azure-applicationinsights/test/AzureAppInsights.integ.js +101 -0
- package/lib/azure-applicationinsights/test/AzureAppInsights.spec.js +4 -27
- package/lib/azure-containerregistry/lib/registry.d.ts +4 -3
- package/lib/azure-containerregistry/lib/registry.js +5 -5
- package/lib/azure-containerregistry/test/AzureContainerRegistry.integ.d.ts +1 -0
- package/lib/azure-containerregistry/test/AzureContainerRegistry.integ.js +68 -0
- package/lib/azure-containerregistry/test/AzureContainerRegistry.spec.js +4 -23
- package/lib/azure-datalake/lib/datalake.d.ts +1 -0
- package/lib/azure-datalake/lib/datalake.js +2 -1
- package/lib/azure-datalake/test/AzureDatalake.spec.d.ts +1 -0
- package/lib/azure-datalake/test/AzureDatalake.spec.js +32 -0
- package/lib/azure-datalake/test/AzureStorageAccount.integ.d.ts +1 -0
- package/lib/azure-datalake/test/AzureStorageAccount.integ.js +60 -0
- package/lib/azure-eventhub/lib/authorization.js +1 -1
- package/lib/azure-eventhub/lib/consumer.js +1 -1
- package/lib/azure-eventhub/lib/{cluster.d.ts → eventhubcluster.d.ts} +11 -7
- package/lib/azure-eventhub/lib/eventhubcluster.js +64 -0
- package/lib/azure-eventhub/lib/index.d.ts +1 -1
- package/lib/azure-eventhub/lib/index.js +2 -2
- package/lib/azure-eventhub/lib/instance.d.ts +1 -0
- package/lib/azure-eventhub/lib/instance.js +5 -4
- package/lib/azure-eventhub/lib/kusto-connection.js +1 -1
- package/lib/azure-eventhub/lib/namespace.d.ts +7 -6
- package/lib/azure-eventhub/lib/namespace.js +24 -26
- package/lib/azure-eventhub/test/AzureEventhub.integ.d.ts +1 -0
- package/lib/azure-eventhub/test/AzureEventhub.integ.js +72 -0
- package/lib/azure-eventhub/test/AzureEventhub.spec.js +4 -27
- package/lib/azure-functionapp/lib/functionapplinux.js +1 -1
- package/lib/azure-functionapp/test/AzureLinuxFunctionApp.integ.d.ts +1 -0
- package/lib/azure-functionapp/test/AzureLinuxFunctionApp.integ.js +117 -0
- package/lib/azure-functionapp/test/AzureLinuxFunctionApp.spec.js +4 -21
- package/lib/azure-keyvault/lib/certificate.js +2 -2
- package/lib/azure-keyvault/lib/key.js +1 -1
- package/lib/azure-keyvault/lib/policy.js +1 -1
- package/lib/azure-keyvault/lib/secret.js +1 -1
- package/lib/azure-keyvault/lib/vault.d.ts +3 -2
- package/lib/azure-keyvault/lib/vault.js +4 -4
- package/lib/azure-keyvault/test/AzureKeyVault.integ.d.ts +1 -0
- package/lib/azure-keyvault/test/AzureKeyVault.integ.js +119 -0
- package/lib/azure-keyvault/test/AzureKeyVault.spec.js +4 -35
- package/lib/azure-kubernetes/lib/cluster.js +1 -1
- package/lib/azure-kubernetes/test/AzureKubernetesCluster.integ.d.ts +1 -0
- package/lib/azure-kubernetes/test/AzureKubernetesCluster.integ.js +75 -0
- package/lib/azure-kubernetes/test/AzureKubernetesCluster.spec.js +4 -21
- package/lib/azure-kusto/lib/cluster.d.ts +9 -5
- package/lib/azure-kusto/lib/cluster.js +66 -42
- package/lib/azure-kusto/lib/compute-specification.js +1 -1
- package/lib/azure-kusto/lib/database.d.ts +7 -8
- package/lib/azure-kusto/lib/database.js +23 -25
- package/lib/azure-kusto/test/AzureKusto.integ.d.ts +1 -0
- package/lib/azure-kusto/test/AzureKusto.integ.js +74 -0
- package/lib/azure-kusto/test/AzureKusto.spec.js +3 -22
- package/lib/azure-loganalytics/lib/workspace.d.ts +6 -3
- package/lib/azure-loganalytics/lib/workspace.js +7 -6
- package/lib/azure-loganalytics/test/AzureLogAnalytics.integ.d.ts +1 -0
- package/lib/azure-loganalytics/test/AzureLogAnalytics.integ.js +117 -0
- package/lib/azure-loganalytics/test/AzureLogAnalytics.spec.js +4 -23
- package/lib/azure-metricalert/lib/metric-alert.js +1 -1
- package/lib/azure-metricalert/test/AzureMetricAlert.integ.d.ts +1 -0
- package/lib/azure-metricalert/test/AzureMetricAlert.integ.js +85 -0
- package/lib/azure-metricalert/test/AzureMetricAlert.spec.js +4 -21
- package/lib/azure-networksecuritygroup/lib/preconfigured-rules.js +1 -1
- package/lib/azure-networksecuritygroup/lib/securitygroup.d.ts +4 -3
- package/lib/azure-networksecuritygroup/lib/securitygroup.js +7 -7
- package/lib/azure-networksecuritygroup/test/AzureNetworkSecurityGroup.integ.d.ts +1 -0
- package/lib/azure-networksecuritygroup/test/AzureNetworkSecurityGroup.integ.js +85 -0
- package/lib/azure-networksecuritygroup/test/AzureNetworkSecurityGroup.spec.js +4 -23
- package/lib/azure-queryrulealert/lib/query-rule-alert.js +1 -1
- package/lib/azure-queryrulealert/test/AzureQueryRuleAlert.integ.d.ts +1 -0
- package/lib/azure-queryrulealert/test/AzureQueryRuleAlert.integ.js +63 -0
- package/lib/azure-queryrulealert/test/AzureQueryRuleAlert.spec.js +4 -21
- package/lib/azure-resourcegroup/lib/resource-group.js +1 -1
- package/lib/azure-resourcegroup/test/AzureResourceGroup.integ.d.ts +1 -0
- package/lib/azure-resourcegroup/test/AzureResourceGroup.integ.js +41 -0
- package/lib/azure-resourcegroup/test/AzureResourceGroup.spec.js +4 -17
- package/lib/azure-storageaccount/lib/account.d.ts +5 -0
- package/lib/azure-storageaccount/lib/account.js +3 -2
- package/lib/azure-storageaccount/lib/container.js +2 -2
- package/lib/azure-storageaccount/lib/fileshare.js +2 -2
- package/lib/azure-storageaccount/lib/queue.js +1 -1
- package/lib/azure-storageaccount/lib/table.js +1 -1
- package/lib/azure-storageaccount/test/AzureStorageAccount.integ.d.ts +1 -0
- package/lib/azure-storageaccount/test/AzureStorageAccount.integ.js +84 -0
- package/lib/azure-storageaccount/test/AzureStorageAccount.spec.js +4 -17
- package/lib/azure-virtualmachine/lib/image-references.js +2 -2
- package/lib/azure-virtualmachine/lib/vm.d.ts +29 -6
- package/lib/azure-virtualmachine/lib/vm.js +17 -15
- package/lib/azure-virtualmachine/test/AzureLinuxVirtualMachine.integ.d.ts +1 -0
- package/lib/azure-virtualmachine/test/AzureLinuxVirtualMachine.integ.js +109 -0
- package/lib/azure-virtualmachine/test/AzureLinuxVirtualMachine.spec.js +5 -25
- package/lib/azure-virtualmachine/test/AzureWindowsVirtualMachine.integ.d.ts +1 -0
- package/lib/azure-virtualmachine/test/AzureWindowsVirtualMachine.integ.js +105 -0
- package/lib/azure-virtualmachine/test/AzureWindowsVirtualMachine.spec.js +4 -23
- package/lib/azure-virtualmachinescaleset/lib/cluster.d.ts +28 -6
- package/lib/azure-virtualmachinescaleset/lib/cluster.js +13 -11
- package/lib/azure-virtualmachinescaleset/test/AzureLinuxVirtualMachineScaleSet.integ.d.ts +1 -0
- package/lib/azure-virtualmachinescaleset/test/AzureLinuxVirtualMachineScaleSet.integ.js +113 -0
- package/lib/azure-virtualmachinescaleset/test/AzureLinuxVirtualMachineScaleSet.spec.js +5 -25
- package/lib/azure-virtualmachinescaleset/test/AzureWindowsVirtualMachineScaleSet.integ.d.ts +1 -0
- package/lib/azure-virtualmachinescaleset/test/AzureWindowsVirtualMachineScaleSet.integ.js +109 -0
- package/lib/azure-virtualmachinescaleset/test/AzureWindowsVirtualMachineScaleSet.spec.js +4 -23
- package/lib/azure-virtualnetwork/lib/network.d.ts +4 -3
- package/lib/azure-virtualnetwork/lib/network.js +7 -6
- package/lib/azure-virtualnetwork/lib/peering.js +1 -1
- package/lib/azure-virtualnetwork/test/AzureVirtualNetwork.integ.d.ts +1 -0
- package/lib/azure-virtualnetwork/test/AzureVirtualNetwork.integ.js +92 -0
- package/lib/azure-virtualnetwork/test/AzureVirtualNetwork.spec.js +5 -25
- package/lib/core-azure/lib/diagsettings.d.ts +3 -2
- package/lib/core-azure/lib/diagsettings.js +15 -21
- package/lib/core-azure/lib/rbac.js +1 -1
- package/lib/core-azure/lib/resource.js +6 -4
- package/lib/core-azure/test/AzureResource.integ.d.ts +1 -0
- package/lib/core-azure/test/AzureResource.integ.js +75 -0
- package/lib/testing/index.d.ts +34 -0
- package/lib/testing/index.js +235 -2
- package/package.json +32 -11
- package/cdktf.out/manifest.json +0 -13
- package/cdktf.out/stacks/testAzureActionGroup/cdk.tf.json +0 -111
- package/cdktf.out/stacks/testAzureApplicationGateway/cdk.tf.json +0 -588
- package/cdktf.out/stacks/testAzureApplicationInsights/cdk.tf.json +0 -245
- package/cdktf.out/stacks/testAzureContainerRegistry/cdk.tf.json +0 -179
- package/cdktf.out/stacks/testAzureEventhub/cdk.tf.json +0 -236
- package/cdktf.out/stacks/testAzureKeyVault/cdk.tf.json +0 -436
- package/cdktf.out/stacks/testAzureKubernetesCluster/cdk.tf.json +0 -152
- package/cdktf.out/stacks/testAzureKusto/cdk.tf.json +0 -209
- package/cdktf.out/stacks/testAzureLinuxFunctionApp/cdk.tf.json +0 -439
- package/cdktf.out/stacks/testAzureLinuxVirtualMachineExample/cdk.tf.json +0 -283
- package/cdktf.out/stacks/testAzureLinuxVirtualMachineScaleSetExample/cdk.tf.json +0 -261
- package/cdktf.out/stacks/testAzureLogAnalytics/cdk.tf.json +0 -309
- package/cdktf.out/stacks/testAzureMetricAlert/cdk.tf.json +0 -161
- package/cdktf.out/stacks/testAzureNetworkSecurityGroup/cdk.tf.json +0 -271
- package/cdktf.out/stacks/testAzureQueryRuleAlert/cdk.tf.json +0 -122
- package/cdktf.out/stacks/testAzureResourceGroup/cdk.tf.json +0 -88
- package/cdktf.out/stacks/testAzureStorageAccount/cdk.tf.json +0 -339
- package/cdktf.out/stacks/testAzureVirtualNetwork/cdk.tf.json +0 -264
- package/cdktf.out/stacks/testAzureWindowVirtualMachineScaleSetExample/cdk.tf.json +0 -261
- package/cdktf.out/stacks/testAzureWindowsVirtualMachineExample/cdk.tf.json +0 -280
- package/cdktf.out/stacks/testExampleAzureResource/cdk.tf.json +0 -167
- package/lib/azure-actiongroup/test/ExampleAzureActionGroup.d.ts +0 -5
- package/lib/azure-actiongroup/test/ExampleAzureActionGroup.js +0 -66
- package/lib/azure-applicationgateway/test/ExampleAzureApplicationGateway.d.ts +0 -5
- package/lib/azure-applicationgateway/test/ExampleAzureApplicationGateway.js +0 -267
- package/lib/azure-applicationinsights/test/ExampleAzureApplicationInsights.d.ts +0 -5
- package/lib/azure-applicationinsights/test/ExampleAzureApplicationInsights.js +0 -87
- package/lib/azure-containerregistry/test/ExampleAzureContainerRegistry.d.ts +0 -5
- package/lib/azure-containerregistry/test/ExampleAzureContainerRegistry.js +0 -57
- package/lib/azure-eventhub/lib/cluster.js +0 -64
- package/lib/azure-eventhub/test/ExampleAzureEventhub.d.ts +0 -5
- package/lib/azure-eventhub/test/ExampleAzureEventhub.js +0 -72
- package/lib/azure-functionapp/test/ExampleAzureLinuxFunctionApp.d.ts +0 -5
- package/lib/azure-functionapp/test/ExampleAzureLinuxFunctionApp.js +0 -123
- package/lib/azure-keyvault/test/ExampleAzureKeyVault.d.ts +0 -5
- package/lib/azure-keyvault/test/ExampleAzureKeyVault.js +0 -112
- package/lib/azure-kubernetes/test/ExampleAzureKubernetesCluster.d.ts +0 -5
- package/lib/azure-kubernetes/test/ExampleAzureKubernetesCluster.js +0 -65
- package/lib/azure-kusto/test/ExampleAzureKusto.d.ts +0 -5
- package/lib/azure-kusto/test/ExampleAzureKusto.js +0 -71
- package/lib/azure-loganalytics/test/ExampleAzureLogAnalytics.d.ts +0 -5
- package/lib/azure-loganalytics/test/ExampleAzureLogAnalytics.js +0 -115
- package/lib/azure-metricalert/test/ExampleAzureMetricAlert.d.ts +0 -5
- package/lib/azure-metricalert/test/ExampleAzureMetricAlert.js +0 -81
- package/lib/azure-networksecuritygroup/test/ExampleAzureNetworkSecurityGroup.d.ts +0 -5
- package/lib/azure-networksecuritygroup/test/ExampleAzureNetworkSecurityGroup.js +0 -97
- package/lib/azure-queryrulealert/test/ExampleAzureQueryRuleAlert.d.ts +0 -5
- package/lib/azure-queryrulealert/test/ExampleAzureQueryRuleAlert.js +0 -67
- package/lib/azure-resourcegroup/test/ExampleAzureResourceGroup.d.ts +0 -5
- package/lib/azure-resourcegroup/test/ExampleAzureResourceGroup.js +0 -29
- package/lib/azure-storageaccount/test/ExampleAzureStorageAccount.d.ts +0 -5
- package/lib/azure-storageaccount/test/ExampleAzureStorageAccount.js +0 -102
- package/lib/azure-virtualmachine/test/ExampleAzureLinuxVirtualMachine.d.ts +0 -5
- package/lib/azure-virtualmachine/test/ExampleAzureLinuxVirtualMachine.js +0 -106
- package/lib/azure-virtualmachine/test/ExampleAzureWindowsVirtualMachine.d.ts +0 -5
- package/lib/azure-virtualmachine/test/ExampleAzureWindowsVirtualMachine.js +0 -102
- package/lib/azure-virtualmachinescaleset/test/ExampleAzureLinuxVirtualMachineScaleSet.d.ts +0 -5
- package/lib/azure-virtualmachinescaleset/test/ExampleAzureLinuxVirtualMachineScaleSet.js +0 -107
- package/lib/azure-virtualmachinescaleset/test/ExampleAzureWindowsVirtualMachineScaleSet.d.ts +0 -5
- package/lib/azure-virtualmachinescaleset/test/ExampleAzureWindowsVirtualMachineScaleSet.js +0 -103
- package/lib/azure-virtualnetwork/test/ExampleAzureVirtualNetwork.d.ts +0 -5
- package/lib/azure-virtualnetwork/test/ExampleAzureVirtualNetwork.js +0 -88
- package/lib/core-azure/test/AzureResource.spec.js +0 -19
- package/lib/core-azure/test/ExampleAzureResource.d.ts +0 -5
- package/lib/core-azure/test/ExampleAzureResource.js +0 -67
- package/tfsec.json +0 -4
- /package/lib/{core-azure/test/AzureResource.spec.d.ts → azure-actiongroup/test/AzureActionGroup.integ.d.ts} +0 -0
|
@@ -75,6 +75,8 @@ class AzureResource extends constructs_1.Construct {
|
|
|
75
75
|
storageAccountId: props.storageAccountId,
|
|
76
76
|
targetResourceId: this.id,
|
|
77
77
|
logAnalyticsDestinationType: undefined,
|
|
78
|
+
log: props?.log,
|
|
79
|
+
metric: props?.metric,
|
|
78
80
|
});
|
|
79
81
|
}
|
|
80
82
|
setupResourceGroup(props) {
|
|
@@ -82,7 +84,7 @@ class AzureResource extends constructs_1.Construct {
|
|
|
82
84
|
// Create a new resource group
|
|
83
85
|
const newResourceGroup = new resource_group_1.ResourceGroup(this, "rg", {
|
|
84
86
|
name: `rg-${props.name}`,
|
|
85
|
-
location: props.location,
|
|
87
|
+
location: props.location || "eastus",
|
|
86
88
|
tags: props.tags,
|
|
87
89
|
});
|
|
88
90
|
// Use the name of the new resource group
|
|
@@ -96,7 +98,7 @@ class AzureResource extends constructs_1.Construct {
|
|
|
96
98
|
}
|
|
97
99
|
exports.AzureResource = AzureResource;
|
|
98
100
|
_a = JSII_RTTI_SYMBOL_1;
|
|
99
|
-
AzureResource[_a] = { fqn: "@microsoft/terraform-cdk-constructs.core_azure.AzureResource", version: "0.0.3-pre.
|
|
101
|
+
AzureResource[_a] = { fqn: "@microsoft/terraform-cdk-constructs.core_azure.AzureResource", version: "0.0.3-pre.12" };
|
|
100
102
|
class AzureResourceWithAlert extends AzureResource {
|
|
101
103
|
addQueryRuleAlert(props) {
|
|
102
104
|
new queryalert.QueryRuleAlert(this, "queryrulealert", {
|
|
@@ -114,5 +116,5 @@ class AzureResourceWithAlert extends AzureResource {
|
|
|
114
116
|
}
|
|
115
117
|
exports.AzureResourceWithAlert = AzureResourceWithAlert;
|
|
116
118
|
_b = JSII_RTTI_SYMBOL_1;
|
|
117
|
-
AzureResourceWithAlert[_b] = { fqn: "@microsoft/terraform-cdk-constructs.core_azure.AzureResourceWithAlert", version: "0.0.3-pre.
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
119
|
+
AzureResourceWithAlert[_b] = { fqn: "@microsoft/terraform-cdk-constructs.core_azure.AzureResourceWithAlert", version: "0.0.3-pre.12" };
|
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource.js","sourceRoot":"","sources":["../../../src/core-azure/lib/resource.ts"],"names":[],"mappings":";;;;;AAAA,+EAA2E;AAC3E,2CAAuC;AACvC,iDAGwB;AACxB,iCAA8B;AAC9B,uDAAuD;AACvD,yDAAyD;AAEzD,MAAsB,aAAc,SAAQ,sBAAS;IAInD,YAAY,KAAgB,EAAE,EAAU;QACtC,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACjB,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;IACf,CAAC;IAED;;;;;;;;;;;;;;;OAeG;IACI,SAAS,CAAC,QAAgB,EAAE,cAAsB;QACvD,IAAI,WAAI,CAAC,IAAI,EAAE,QAAQ,GAAG,cAAc,EAAE;YACxC,QAAQ,EAAE,QAAQ;YAClB,kBAAkB,EAAE,cAAc;YAClC,KAAK,EAAE,IAAI,CAAC,EAAE;SACf,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA4BG;IACI,eAAe,CACpB,KAAkC;QAElC,OAAO,IAAI,iCAAkB,CAAC,IAAI,EAAE,cAAc,EAAE;YAClD,IAAI,EAAE,KAAK,CAAC,IAAI,IAAI,eAAe;YACnC,uBAAuB,EAAE,KAAK,CAAC,uBAAuB;YACtD,2BAA2B,EAAE,KAAK,CAAC,2BAA2B;YAC9D,YAAY,EAAE,KAAK,CAAC,YAAY;YAChC,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;YACxC,gBAAgB,EAAE,IAAI,CAAC,EAAE;YACzB,2BAA2B,EAAE,SAAS;YACtC,GAAG,EAAE,KAAK,EAAE,GAAG;YACf,MAAM,EAAE,KAAK,EAAE,MAAM;SACtB,CAAC,CAAC;IACL,CAAC;IAES,kBAAkB,CAAC,KAAU;QACrC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE;YACxB,8BAA8B;YAC9B,MAAM,gBAAgB,GAAG,IAAI,8BAAa,CAAC,IAAI,EAAE,IAAI,EAAE;gBACrD,IAAI,EAAE,MAAM,KAAK,CAAC,IAAI,EAAE;gBACxB,QAAQ,EAAE,KAAK,CAAC,QAAQ,IAAI,QAAQ;gBACpC,IAAI,EAAE,KAAK,CAAC,IAAI;aACjB,CAAC,CAAC;YACH,yCAAyC;YACzC,OAAO,gBAAgB,CAAC;SACzB;aAAM;YACL,uCAAuC;YACvC,OAAO,KAAK,CAAC,aAAa,CAAC;SAC5B;IACH,CAAC;;AA5FH,sCA6FC;;;AAED,MAAsB,sBAAuB,SAAQ,aAAa;IACzD,iBAAiB,CAAC,KAA8C;QACrE,IAAI,UAAU,CAAC,cAAc,CAAC,IAAI,EAAE,gBAAgB,EAAE;YACpD,GAAG,KAAK;YACR,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;SAClB,CAAC,CAAC;IACL,CAAC;IAEM,cAAc,CAAC,KAAwC;QAC5D,IAAI,WAAW,CAAC,WAAW,CAAC,IAAI,EAAE,aAAa,EAAE;YAC/C,GAAG,KAAK;YACR,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;SAClB,CAAC,CAAC;IACL,CAAC;;AAdH,wDAeC","sourcesContent":["import { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport { Construct } from \"constructs\";\nimport {\n  DiagnosticSettings,\n  BaseDiagnosticSettingsProps,\n} from \"./diagsettings\";\nimport { Rbac } from \"./rbac\";\nimport * as metricalert from \"../../azure-metricalert\";\nimport * as queryalert from \"../../azure-queryrulealert\";\n\nexport abstract class AzureResource extends Construct {\n  public id: string;\n  public abstract resourceGroup: ResourceGroup;\n\n  constructor(scope: Construct, id: string) {\n    super(scope, id);\n    this.id = id;\n  }\n\n  /**\n   * Adds an access role assignment for a specified Azure AD object (e.g., user, group, service principal) within this RBAC construct's scope.\n   *\n   * This method creates a new role assignment which grants the specified Azure AD object access to resources\n   * at the scope defined by this construct. This is useful for programmatically managing access controls,\n   * ensuring only authorized users or systems can perform specific actions on Azure resources.\n   *\n   * @param objectId - The unique identifier of the Azure AD object (user, group, or service principal) that will receive the role assignment.\n   * @param customRoleName - The human-readable name of the Azure RBAC role to be assigned. This role defines the permissions that the object will have.\n   *\n   * Example usage:\n   * ```typescript\n   * // Example: Assign a \"Reader\" role to a user for the current RBAC scope\n   * rbacInstance.addAccess('user-object-id', 'Reader');\n   * ```\n   */\n  public addAccess(objectId: string, customRoleName: string) {\n    new Rbac(this, objectId + customRoleName, {\n      objectId: objectId,\n      roleDefinitionName: customRoleName,\n      scope: this.id,\n    });\n  }\n\n  /**\n   * Adds diagnostic settings to a specified resource within this construct.\n   *\n   * This method creates and configures a new DiagnosticSettings instance which captures and routes\n   * diagnostic data (logs and metrics) to the specified destinations such as Azure Monitor,\n   * an Event Hubs instance, a Log Analytics workspace, or an Azure Storage account.\n   *\n   * @param props - The properties required to configure the diagnostic settings. These include:\n   *                - `name`: Optional. The name of the diagnostic settings resource. Defaults to 'diag-settings'.\n   *                - `logAnalyticsWorkspaceId`: Optional. The identifier of the Log Analytics workspace to send logs.\n   *                - `eventhubAuthorizationRuleId`: Optional. The authorization rule ID for an Event Hub where logs will be forwarded.\n   *                - `eventhubName`: Optional. The name of the Event Hub to which logs will be sent.\n   *                - `storageAccountId`: Optional. The identifier of the Azure Storage account where logs will be stored.\n   *                - `logAnalyticsDestinationType`: Optional. Determines if logs are sent to dedicated or legacy tables in Log Analytics. Defaults to undefined which uses the default settings.\n   *                The `targetResourceId` is automatically set to the ID of this construct instance.\n   *\n   * @returns An instance of the DiagnosticSettings class, configured with the provided properties.\n   *\n   * Example usage:\n   * ```typescript\n   * const diagSettings = resource.addDiagSettings({\n   *   name: 'custom-diag-settings',\n   *   logAnalyticsWorkspaceId: 'workspace-id',\n   *   eventhubAuthorizationRuleId: 'auth-rule-id',\n   *   eventhubName: 'eventhub-name',\n   *   storageAccountId: 'storage-account-id'\n   * });\n   * ```\n   */\n  public addDiagSettings(\n    props: BaseDiagnosticSettingsProps,\n  ): DiagnosticSettings {\n    return new DiagnosticSettings(this, \"diagsettings\", {\n      name: props.name || \"diag-settings\",\n      logAnalyticsWorkspaceId: props.logAnalyticsWorkspaceId,\n      eventhubAuthorizationRuleId: props.eventhubAuthorizationRuleId,\n      eventhubName: props.eventhubName,\n      storageAccountId: props.storageAccountId,\n      targetResourceId: this.id,\n      logAnalyticsDestinationType: undefined,\n      log: props?.log,\n      metric: props?.metric,\n    });\n  }\n\n  protected setupResourceGroup(props: any): ResourceGroup {\n    if (!props.resourceGroup) {\n      // Create a new resource group\n      const newResourceGroup = new ResourceGroup(this, \"rg\", {\n        name: `rg-${props.name}`,\n        location: props.location || \"eastus\",\n        tags: props.tags,\n      });\n      // Use the name of the new resource group\n      return newResourceGroup;\n    } else {\n      // Use the provided resource group name\n      return props.resourceGroup;\n    }\n  }\n}\n\nexport abstract class AzureResourceWithAlert extends AzureResource {\n  public addQueryRuleAlert(props: queryalert.BaseAzureQueryRuleAlertProps) {\n    new queryalert.QueryRuleAlert(this, \"queryrulealert\", {\n      ...props,\n      scopes: [this.id],\n    });\n  }\n\n  public addMetricAlert(props: metricalert.IBaseMetricAlertProps) {\n    new metricalert.MetricAlert(this, \"metricalert\", {\n      ...props,\n      resourceGroup: this.resourceGroup,\n      scopes: [this.id],\n    });\n  }\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import "cdktf/lib/testing/adapters/jest";
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const container_registry_1 = require("@cdktf/provider-azurerm/lib/container-registry");
|
|
4
|
+
const data_azurerm_client_config_1 = require("@cdktf/provider-azurerm/lib/data-azurerm-client-config");
|
|
5
|
+
const log_analytics_workspace_1 = require("@cdktf/provider-azurerm/lib/log-analytics-workspace");
|
|
6
|
+
const provider_1 = require("@cdktf/provider-azurerm/lib/provider");
|
|
7
|
+
const resource_group_1 = require("@cdktf/provider-azurerm/lib/resource-group");
|
|
8
|
+
const cdktf_1 = require("cdktf");
|
|
9
|
+
const testing_1 = require("../../testing");
|
|
10
|
+
const randomName_1 = require("../../util/randomName");
|
|
11
|
+
const lib_1 = require("../lib");
|
|
12
|
+
require("cdktf/lib/testing/adapters/jest");
|
|
13
|
+
describe("Example of deploying an Azure Resource", () => {
|
|
14
|
+
let stack;
|
|
15
|
+
let fullSynthResult;
|
|
16
|
+
const streamOutput = process.env.STREAM_OUTPUT !== "false";
|
|
17
|
+
beforeEach(() => {
|
|
18
|
+
const app = cdktf_1.Testing.app();
|
|
19
|
+
stack = new cdktf_1.TerraformStack(app, "test");
|
|
20
|
+
const randomName = (0, randomName_1.generateRandomName)(12);
|
|
21
|
+
class TestACR extends lib_1.AzureResource {
|
|
22
|
+
constructor(scope, name, resourceGroup, location) {
|
|
23
|
+
super(scope, name);
|
|
24
|
+
const containerRegistry = new container_registry_1.ContainerRegistry(this, "containerRegistry", {
|
|
25
|
+
name: `acr${name}8898`,
|
|
26
|
+
resourceGroupName: resourceGroup.name,
|
|
27
|
+
location: location,
|
|
28
|
+
sku: "Basic",
|
|
29
|
+
adminEnabled: true,
|
|
30
|
+
});
|
|
31
|
+
this.id = containerRegistry.id;
|
|
32
|
+
this.resourceGroup = resourceGroup;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
const clientConfig = new data_azurerm_client_config_1.DataAzurermClientConfig(stack, "CurrentClientConfig", {});
|
|
36
|
+
new provider_1.AzurermProvider(stack, "azureFeature", { features: {} });
|
|
37
|
+
// Create a resource group
|
|
38
|
+
const resourceGroup = new resource_group_1.ResourceGroup(stack, "rg", {
|
|
39
|
+
name: `rg-${randomName}`,
|
|
40
|
+
location: "eastus",
|
|
41
|
+
});
|
|
42
|
+
const acr = new TestACR(stack, `${randomName}`, resourceGroup, resourceGroup.location);
|
|
43
|
+
// Test RBAC Methods
|
|
44
|
+
acr.addAccess(clientConfig.objectId, "Contributor");
|
|
45
|
+
acr.addAccess(clientConfig.objectId, "Monitoring Reader");
|
|
46
|
+
const logAnalyticsWorkspace = new log_analytics_workspace_1.LogAnalyticsWorkspace(stack, "log_analytics", {
|
|
47
|
+
location: "eastus",
|
|
48
|
+
name: `la-${randomName}`,
|
|
49
|
+
resourceGroupName: resourceGroup.name,
|
|
50
|
+
});
|
|
51
|
+
// Test Diag Settings
|
|
52
|
+
acr.addDiagSettings({
|
|
53
|
+
name: "diagsettings",
|
|
54
|
+
logAnalyticsWorkspaceId: logAnalyticsWorkspace.id,
|
|
55
|
+
metric: [
|
|
56
|
+
{
|
|
57
|
+
category: "AllMetrics",
|
|
58
|
+
},
|
|
59
|
+
],
|
|
60
|
+
});
|
|
61
|
+
fullSynthResult = cdktf_1.Testing.fullSynth(stack); // Save the result for reuse
|
|
62
|
+
});
|
|
63
|
+
afterEach(() => {
|
|
64
|
+
try {
|
|
65
|
+
(0, testing_1.TerraformDestroy)(fullSynthResult, streamOutput);
|
|
66
|
+
}
|
|
67
|
+
catch (error) {
|
|
68
|
+
console.error("Error during Terraform destroy:", error);
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
it("check if this can be deployed", () => {
|
|
72
|
+
(0, testing_1.TerraformApplyAndCheckIdempotency)(fullSynthResult, streamOutput); // Set to true to stream output
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXp1cmVSZXNvdXJjZS5pbnRlZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb3JlLWF6dXJlL3Rlc3QvQXp1cmVSZXNvdXJjZS5pbnRlZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHVGQUFtRjtBQUNuRix1R0FBaUc7QUFDakcsaUdBQTRGO0FBQzVGLG1FQUF1RTtBQUN2RSwrRUFBMkU7QUFFM0UsaUNBQWdEO0FBRWhELDJDQUd1QjtBQUN2QixzREFBMkQ7QUFDM0QsZ0NBQXVDO0FBQ3ZDLDJDQUF5QztBQUV6QyxRQUFRLENBQUMsd0NBQXdDLEVBQUUsR0FBRyxFQUFFO0lBQ3RELElBQUksS0FBcUIsQ0FBQztJQUMxQixJQUFJLGVBQW9CLENBQUM7SUFDekIsTUFBTSxZQUFZLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxhQUFhLEtBQUssT0FBTyxDQUFDO0lBRTNELFVBQVUsQ0FBQyxHQUFHLEVBQUU7UUFDZCxNQUFNLEdBQUcsR0FBRyxlQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDMUIsS0FBSyxHQUFHLElBQUksc0JBQWMsQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDeEMsTUFBTSxVQUFVLEdBQUcsSUFBQSwrQkFBa0IsRUFBQyxFQUFFLENBQUMsQ0FBQztRQUUxQyxNQUFNLE9BQVEsU0FBUSxtQkFBYTtZQUlqQyxZQUNFLEtBQWdCLEVBQ2hCLElBQVksRUFDWixhQUE0QixFQUM1QixRQUFnQjtnQkFFaEIsS0FBSyxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztnQkFFbkIsTUFBTSxpQkFBaUIsR0FBRyxJQUFJLHNDQUFpQixDQUM3QyxJQUFJLEVBQ0osbUJBQW1CLEVBQ25CO29CQUNFLElBQUksRUFBRSxNQUFNLElBQUksTUFBTTtvQkFDdEIsaUJBQWlCLEVBQUUsYUFBYSxDQUFDLElBQUk7b0JBQ3JDLFFBQVEsRUFBRSxRQUFRO29CQUNsQixHQUFHLEVBQUUsT0FBTztvQkFDWixZQUFZLEVBQUUsSUFBSTtpQkFDbkIsQ0FDRixDQUFDO2dCQUNGLElBQUksQ0FBQyxFQUFFLEdBQUcsaUJBQWlCLENBQUMsRUFBRSxDQUFDO2dCQUMvQixJQUFJLENBQUMsYUFBYSxHQUFHLGFBQWEsQ0FBQztZQUNyQyxDQUFDO1NBQ0Y7UUFFRCxNQUFNLFlBQVksR0FBRyxJQUFJLG9EQUF1QixDQUM5QyxLQUFLLEVBQ0wscUJBQXFCLEVBQ3JCLEVBQUUsQ0FDSCxDQUFDO1FBRUYsSUFBSSwwQkFBZSxDQUFDLEtBQUssRUFBRSxjQUFjLEVBQUUsRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUU3RCwwQkFBMEI7UUFDMUIsTUFBTSxhQUFhLEdBQUcsSUFBSSw4QkFBYSxDQUFDLEtBQUssRUFBRSxJQUFJLEVBQUU7WUFDbkQsSUFBSSxFQUFFLE1BQU0sVUFBVSxFQUFFO1lBQ3hCLFFBQVEsRUFBRSxRQUFRO1NBQ25CLENBQUMsQ0FBQztRQUVILE1BQU0sR0FBRyxHQUFHLElBQUksT0FBTyxDQUNyQixLQUFLLEVBQ0wsR0FBRyxVQUFVLEVBQUUsRUFDZixhQUFhLEVBQ2IsYUFBYSxDQUFDLFFBQVEsQ0FDdkIsQ0FBQztRQUVGLG9CQUFvQjtRQUNwQixHQUFHLENBQUMsU0FBUyxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsYUFBYSxDQUFDLENBQUM7UUFDcEQsR0FBRyxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsUUFBUSxFQUFFLG1CQUFtQixDQUFDLENBQUM7UUFFMUQsTUFBTSxxQkFBcUIsR0FBRyxJQUFJLCtDQUFxQixDQUNyRCxLQUFLLEVBQ0wsZUFBZSxFQUNmO1lBQ0UsUUFBUSxFQUFFLFFBQVE7WUFDbEIsSUFBSSxFQUFFLE1BQU0sVUFBVSxFQUFFO1lBQ3hCLGlCQUFpQixFQUFFLGFBQWEsQ0FBQyxJQUFJO1NBQ3RDLENBQ0YsQ0FBQztRQUVGLHFCQUFxQjtRQUNyQixHQUFHLENBQUMsZUFBZSxDQUFDO1lBQ2xCLElBQUksRUFBRSxjQUFjO1lBQ3BCLHVCQUF1QixFQUFFLHFCQUFxQixDQUFDLEVBQUU7WUFDakQsTUFBTSxFQUFFO2dCQUNOO29CQUNFLFFBQVEsRUFBRSxZQUFZO2lCQUN2QjthQUNGO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsZUFBZSxHQUFHLGVBQU8sQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyw0QkFBNEI7SUFDMUUsQ0FBQyxDQUFDLENBQUM7SUFFSCxTQUFTLENBQUMsR0FBRyxFQUFFO1FBQ2IsSUFBSTtZQUNGLElBQUEsMEJBQWdCLEVBQUMsZUFBZSxFQUFFLFlBQVksQ0FBQyxDQUFDO1NBQ2pEO1FBQUMsT0FBTyxLQUFLLEVBQUU7WUFDZCxPQUFPLENBQUMsS0FBSyxDQUFDLGlDQUFpQyxFQUFFLEtBQUssQ0FBQyxDQUFDO1NBQ3pEO0lBQ0gsQ0FBQyxDQUFDLENBQUM7SUFFSCxFQUFFLENBQUMsK0JBQStCLEVBQUUsR0FBRyxFQUFFO1FBQ3ZDLElBQUEsMkNBQWlDLEVBQUMsZUFBZSxFQUFFLFlBQVksQ0FBQyxDQUFDLENBQUMsK0JBQStCO0lBQ25HLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb250YWluZXJSZWdpc3RyeSB9IGZyb20gXCJAY2RrdGYvcHJvdmlkZXItYXp1cmVybS9saWIvY29udGFpbmVyLXJlZ2lzdHJ5XCI7XG5pbXBvcnQgeyBEYXRhQXp1cmVybUNsaWVudENvbmZpZyB9IGZyb20gXCJAY2RrdGYvcHJvdmlkZXItYXp1cmVybS9saWIvZGF0YS1henVyZXJtLWNsaWVudC1jb25maWdcIjtcbmltcG9ydCB7IExvZ0FuYWx5dGljc1dvcmtzcGFjZSB9IGZyb20gXCJAY2RrdGYvcHJvdmlkZXItYXp1cmVybS9saWIvbG9nLWFuYWx5dGljcy13b3Jrc3BhY2VcIjtcbmltcG9ydCB7IEF6dXJlcm1Qcm92aWRlciB9IGZyb20gXCJAY2RrdGYvcHJvdmlkZXItYXp1cmVybS9saWIvcHJvdmlkZXJcIjtcbmltcG9ydCB7IFJlc291cmNlR3JvdXAgfSBmcm9tIFwiQGNka3RmL3Byb3ZpZGVyLWF6dXJlcm0vbGliL3Jlc291cmNlLWdyb3VwXCI7XG5cbmltcG9ydCB7IFRlc3RpbmcsIFRlcnJhZm9ybVN0YWNrIH0gZnJvbSBcImNka3RmXCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tIFwiY29uc3RydWN0c1wiO1xuaW1wb3J0IHtcbiAgVGVycmFmb3JtQXBwbHlBbmRDaGVja0lkZW1wb3RlbmN5LFxuICBUZXJyYWZvcm1EZXN0cm95LFxufSBmcm9tIFwiLi4vLi4vdGVzdGluZ1wiO1xuaW1wb3J0IHsgZ2VuZXJhdGVSYW5kb21OYW1lIH0gZnJvbSBcIi4uLy4uL3V0aWwvcmFuZG9tTmFtZVwiO1xuaW1wb3J0IHsgQXp1cmVSZXNvdXJjZSB9IGZyb20gXCIuLi9saWJcIjtcbmltcG9ydCBcImNka3RmL2xpYi90ZXN0aW5nL2FkYXB0ZXJzL2plc3RcIjtcblxuZGVzY3JpYmUoXCJFeGFtcGxlIG9mIGRlcGxveWluZyBhbiBBenVyZSBSZXNvdXJjZVwiLCAoKSA9PiB7XG4gIGxldCBzdGFjazogVGVycmFmb3JtU3RhY2s7XG4gIGxldCBmdWxsU3ludGhSZXN1bHQ6IGFueTtcbiAgY29uc3Qgc3RyZWFtT3V0cHV0ID0gcHJvY2Vzcy5lbnYuU1RSRUFNX09VVFBVVCAhPT0gXCJmYWxzZVwiO1xuXG4gIGJlZm9yZUVhY2goKCkgPT4ge1xuICAgIGNvbnN0IGFwcCA9IFRlc3RpbmcuYXBwKCk7XG4gICAgc3RhY2sgPSBuZXcgVGVycmFmb3JtU3RhY2soYXBwLCBcInRlc3RcIik7XG4gICAgY29uc3QgcmFuZG9tTmFtZSA9IGdlbmVyYXRlUmFuZG9tTmFtZSgxMik7XG5cbiAgICBjbGFzcyBUZXN0QUNSIGV4dGVuZHMgQXp1cmVSZXNvdXJjZSB7XG4gICAgICBwdWJsaWMgcmVhZG9ubHkgaWQ6IHN0cmluZztcbiAgICAgIHB1YmxpYyByZWFkb25seSByZXNvdXJjZUdyb3VwOiBSZXNvdXJjZUdyb3VwO1xuXG4gICAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgc2NvcGU6IENvbnN0cnVjdCxcbiAgICAgICAgbmFtZTogc3RyaW5nLFxuICAgICAgICByZXNvdXJjZUdyb3VwOiBSZXNvdXJjZUdyb3VwLFxuICAgICAgICBsb2NhdGlvbjogc3RyaW5nLFxuICAgICAgKSB7XG4gICAgICAgIHN1cGVyKHNjb3BlLCBuYW1lKTtcblxuICAgICAgICBjb25zdCBjb250YWluZXJSZWdpc3RyeSA9IG5ldyBDb250YWluZXJSZWdpc3RyeShcbiAgICAgICAgICB0aGlzLFxuICAgICAgICAgIFwiY29udGFpbmVyUmVnaXN0cnlcIixcbiAgICAgICAgICB7XG4gICAgICAgICAgICBuYW1lOiBgYWNyJHtuYW1lfTg4OThgLFxuICAgICAgICAgICAgcmVzb3VyY2VHcm91cE5hbWU6IHJlc291cmNlR3JvdXAubmFtZSxcbiAgICAgICAgICAgIGxvY2F0aW9uOiBsb2NhdGlvbixcbiAgICAgICAgICAgIHNrdTogXCJCYXNpY1wiLFxuICAgICAgICAgICAgYWRtaW5FbmFibGVkOiB0cnVlLFxuICAgICAgICAgIH0sXG4gICAgICAgICk7XG4gICAgICAgIHRoaXMuaWQgPSBjb250YWluZXJSZWdpc3RyeS5pZDtcbiAgICAgICAgdGhpcy5yZXNvdXJjZUdyb3VwID0gcmVzb3VyY2VHcm91cDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBjb25zdCBjbGllbnRDb25maWcgPSBuZXcgRGF0YUF6dXJlcm1DbGllbnRDb25maWcoXG4gICAgICBzdGFjayxcbiAgICAgIFwiQ3VycmVudENsaWVudENvbmZpZ1wiLFxuICAgICAge30sXG4gICAgKTtcblxuICAgIG5ldyBBenVyZXJtUHJvdmlkZXIoc3RhY2ssIFwiYXp1cmVGZWF0dXJlXCIsIHsgZmVhdHVyZXM6IHt9IH0pO1xuXG4gICAgLy8gQ3JlYXRlIGEgcmVzb3VyY2UgZ3JvdXBcbiAgICBjb25zdCByZXNvdXJjZUdyb3VwID0gbmV3IFJlc291cmNlR3JvdXAoc3RhY2ssIFwicmdcIiwge1xuICAgICAgbmFtZTogYHJnLSR7cmFuZG9tTmFtZX1gLFxuICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgfSk7XG5cbiAgICBjb25zdCBhY3IgPSBuZXcgVGVzdEFDUihcbiAgICAgIHN0YWNrLFxuICAgICAgYCR7cmFuZG9tTmFtZX1gLFxuICAgICAgcmVzb3VyY2VHcm91cCxcbiAgICAgIHJlc291cmNlR3JvdXAubG9jYXRpb24sXG4gICAgKTtcblxuICAgIC8vIFRlc3QgUkJBQyBNZXRob2RzXG4gICAgYWNyLmFkZEFjY2VzcyhjbGllbnRDb25maWcub2JqZWN0SWQsIFwiQ29udHJpYnV0b3JcIik7XG4gICAgYWNyLmFkZEFjY2VzcyhjbGllbnRDb25maWcub2JqZWN0SWQsIFwiTW9uaXRvcmluZyBSZWFkZXJcIik7XG5cbiAgICBjb25zdCBsb2dBbmFseXRpY3NXb3Jrc3BhY2UgPSBuZXcgTG9nQW5hbHl0aWNzV29ya3NwYWNlKFxuICAgICAgc3RhY2ssXG4gICAgICBcImxvZ19hbmFseXRpY3NcIixcbiAgICAgIHtcbiAgICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICAgIG5hbWU6IGBsYS0ke3JhbmRvbU5hbWV9YCxcbiAgICAgICAgcmVzb3VyY2VHcm91cE5hbWU6IHJlc291cmNlR3JvdXAubmFtZSxcbiAgICAgIH0sXG4gICAgKTtcblxuICAgIC8vIFRlc3QgRGlhZyBTZXR0aW5nc1xuICAgIGFjci5hZGREaWFnU2V0dGluZ3Moe1xuICAgICAgbmFtZTogXCJkaWFnc2V0dGluZ3NcIixcbiAgICAgIGxvZ0FuYWx5dGljc1dvcmtzcGFjZUlkOiBsb2dBbmFseXRpY3NXb3Jrc3BhY2UuaWQsXG4gICAgICBtZXRyaWM6IFtcbiAgICAgICAge1xuICAgICAgICAgIGNhdGVnb3J5OiBcIkFsbE1ldHJpY3NcIixcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgfSk7XG5cbiAgICBmdWxsU3ludGhSZXN1bHQgPSBUZXN0aW5nLmZ1bGxTeW50aChzdGFjayk7IC8vIFNhdmUgdGhlIHJlc3VsdCBmb3IgcmV1c2VcbiAgfSk7XG5cbiAgYWZ0ZXJFYWNoKCgpID0+IHtcbiAgICB0cnkge1xuICAgICAgVGVycmFmb3JtRGVzdHJveShmdWxsU3ludGhSZXN1bHQsIHN0cmVhbU91dHB1dCk7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIGNvbnNvbGUuZXJyb3IoXCJFcnJvciBkdXJpbmcgVGVycmFmb3JtIGRlc3Ryb3k6XCIsIGVycm9yKTtcbiAgICB9XG4gIH0pO1xuXG4gIGl0KFwiY2hlY2sgaWYgdGhpcyBjYW4gYmUgZGVwbG95ZWRcIiwgKCkgPT4ge1xuICAgIFRlcnJhZm9ybUFwcGx5QW5kQ2hlY2tJZGVtcG90ZW5jeShmdWxsU3ludGhSZXN1bHQsIHN0cmVhbU91dHB1dCk7IC8vIFNldCB0byB0cnVlIHRvIHN0cmVhbSBvdXRwdXRcbiAgfSk7XG59KTtcbiJdfQ==
|
package/lib/testing/index.d.ts
CHANGED
|
@@ -1,6 +1,40 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { ExecSyncOptionsWithStringEncoding } from "child_process";
|
|
1
3
|
import { TerraformStack } from "cdktf";
|
|
2
4
|
import { Construct } from "constructs";
|
|
3
5
|
export declare class BaseTestStack extends TerraformStack {
|
|
4
6
|
readonly name: string;
|
|
5
7
|
constructor(scope: Construct, id: string);
|
|
6
8
|
}
|
|
9
|
+
export declare function execTerraformCommand(command: string, opts: ExecSyncOptionsWithStringEncoding, streamOutput: boolean): {
|
|
10
|
+
stdout: string;
|
|
11
|
+
stderr: string;
|
|
12
|
+
exitCode: number;
|
|
13
|
+
};
|
|
14
|
+
export declare function TerraformApply(stack: any, streamOutput?: boolean): {
|
|
15
|
+
stdout: string;
|
|
16
|
+
stderr: string;
|
|
17
|
+
error: any;
|
|
18
|
+
};
|
|
19
|
+
export declare function TerraformPlanExitCode(stack: any, streamOutput?: boolean): {
|
|
20
|
+
stdout: string;
|
|
21
|
+
stderr: string;
|
|
22
|
+
exitCode: number;
|
|
23
|
+
error: any;
|
|
24
|
+
};
|
|
25
|
+
export declare function TerraformIdempotentCheck(stack: any): AssertionReturn;
|
|
26
|
+
export declare function TerraformDestroy(stack: any, streamOutput?: boolean): AssertionReturn;
|
|
27
|
+
export declare function TerraformApplyAndCheckIdempotency(stack: any, streamOutput?: boolean): AssertionReturn;
|
|
28
|
+
export declare function TerraformApplyCheckAndDestroy(stack: any): void;
|
|
29
|
+
export declare function TerraformPlan(stack: any): AssertionReturn;
|
|
30
|
+
export declare class AssertionReturn {
|
|
31
|
+
readonly message: string;
|
|
32
|
+
readonly pass: boolean;
|
|
33
|
+
/**
|
|
34
|
+
* Create an AssertionReturn
|
|
35
|
+
* @param message - String message containing information about the result of the assertion
|
|
36
|
+
* @param pass - Boolean pass denoting the success of the assertion
|
|
37
|
+
*/
|
|
38
|
+
constructor(message: string, pass: boolean);
|
|
39
|
+
}
|
|
40
|
+
export declare function cleanupCdkTfOutDirs(): void;
|
package/lib/testing/index.js
CHANGED
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.BaseTestStack = void 0;
|
|
3
|
+
exports.cleanupCdkTfOutDirs = exports.AssertionReturn = exports.TerraformPlan = exports.TerraformApplyCheckAndDestroy = exports.TerraformApplyAndCheckIdempotency = exports.TerraformDestroy = exports.TerraformIdempotentCheck = exports.TerraformPlanExitCode = exports.TerraformApply = exports.execTerraformCommand = exports.BaseTestStack = void 0;
|
|
4
|
+
const child_process_1 = require("child_process");
|
|
5
|
+
const fs = require("fs");
|
|
6
|
+
const path = require("path");
|
|
4
7
|
const cdktf = require("cdktf");
|
|
5
8
|
const cdktf_1 = require("cdktf");
|
|
6
9
|
class BaseTestStack extends cdktf_1.TerraformStack {
|
|
@@ -15,4 +18,234 @@ class BaseTestStack extends cdktf_1.TerraformStack {
|
|
|
15
18
|
}
|
|
16
19
|
}
|
|
17
20
|
exports.BaseTestStack = BaseTestStack;
|
|
18
|
-
|
|
21
|
+
function execTerraformCommand(command, opts, streamOutput) {
|
|
22
|
+
try {
|
|
23
|
+
if (streamOutput) {
|
|
24
|
+
(0, child_process_1.execSync)(command, { ...opts, stdio: "inherit" });
|
|
25
|
+
return { stdout: "", stderr: "", exitCode: 0 };
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
const stdout = (0, child_process_1.execSync)(command, { ...opts, stdio: "pipe" }).toString();
|
|
29
|
+
return { stdout, stderr: "", exitCode: 0 };
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
catch (error) {
|
|
33
|
+
const stdout = error.stdout ? error.stdout.toString() : "";
|
|
34
|
+
const stderr = error.stderr ? error.stderr.toString() : "";
|
|
35
|
+
return { stdout, stderr, exitCode: error.status || 1 };
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
exports.execTerraformCommand = execTerraformCommand;
|
|
39
|
+
function TerraformApply(stack, streamOutput = false) {
|
|
40
|
+
try {
|
|
41
|
+
const manifest = JSON.parse(fs.readFileSync(path.resolve(stack, "manifest.json"), "utf8"));
|
|
42
|
+
const stacks = Object.entries(manifest.stacks);
|
|
43
|
+
for (const [, stackDetails] of stacks) {
|
|
44
|
+
const opts = {
|
|
45
|
+
cwd: path.resolve(stack, stackDetails.workingDirectory),
|
|
46
|
+
env: process.env,
|
|
47
|
+
encoding: "utf-8",
|
|
48
|
+
};
|
|
49
|
+
const initResult = execTerraformCommand(`terraform init`, opts, streamOutput);
|
|
50
|
+
if (initResult.exitCode !== 0)
|
|
51
|
+
throw new Error(`Terraform init failed: ${initResult.stdout} ${initResult.stderr}`);
|
|
52
|
+
const applyResult = execTerraformCommand(`terraform apply -auto-approve`, opts, streamOutput);
|
|
53
|
+
if (applyResult.exitCode !== 0) {
|
|
54
|
+
return {
|
|
55
|
+
stdout: applyResult.stdout,
|
|
56
|
+
stderr: applyResult.stderr,
|
|
57
|
+
error: new Error(`Terraform apply failed: ${applyResult.stdout} ${applyResult.stderr}`),
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
return { stdout: "Terraform apply succeeded", stderr: "", error: null };
|
|
62
|
+
}
|
|
63
|
+
catch (error) {
|
|
64
|
+
console.error("Error during Terraform init or apply:", error);
|
|
65
|
+
return { stdout: "", stderr: "", error };
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
exports.TerraformApply = TerraformApply;
|
|
69
|
+
function TerraformPlanExitCode(stack, streamOutput = false) {
|
|
70
|
+
try {
|
|
71
|
+
const manifest = JSON.parse(fs.readFileSync(path.resolve(stack, "manifest.json"), "utf8"));
|
|
72
|
+
const stacks = Object.entries(manifest.stacks);
|
|
73
|
+
for (const [, stackDetails] of stacks) {
|
|
74
|
+
const opts = {
|
|
75
|
+
cwd: path.resolve(stack, stackDetails.workingDirectory),
|
|
76
|
+
env: process.env,
|
|
77
|
+
encoding: "utf-8",
|
|
78
|
+
};
|
|
79
|
+
const initResult = execTerraformCommand(`terraform init`, opts, streamOutput);
|
|
80
|
+
if (initResult.exitCode !== 0)
|
|
81
|
+
throw new Error(`Terraform init failed: ${initResult.stdout} ${initResult.stderr}`);
|
|
82
|
+
const planResult = execTerraformCommand(`terraform plan -input=false -lock=false -detailed-exitcode`, opts, streamOutput);
|
|
83
|
+
return {
|
|
84
|
+
stdout: planResult.stdout,
|
|
85
|
+
stderr: planResult.stderr,
|
|
86
|
+
exitCode: planResult.exitCode,
|
|
87
|
+
error: null,
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
return {
|
|
91
|
+
stdout: "Terraform plan succeeded",
|
|
92
|
+
stderr: "",
|
|
93
|
+
exitCode: 0,
|
|
94
|
+
error: null,
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
catch (error) {
|
|
98
|
+
console.error("Error during Terraform init or plan:", error);
|
|
99
|
+
return { stdout: "", stderr: "", exitCode: 1, error };
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
exports.TerraformPlanExitCode = TerraformPlanExitCode;
|
|
103
|
+
function TerraformIdempotentCheck(stack) {
|
|
104
|
+
try {
|
|
105
|
+
const manifest = JSON.parse(fs.readFileSync(path.resolve(stack, "manifest.json"), "utf8"));
|
|
106
|
+
const stacks = Object.entries(manifest.stacks);
|
|
107
|
+
for (const [, stackDetails] of stacks) {
|
|
108
|
+
const opts = {
|
|
109
|
+
cwd: path.resolve(stack, stackDetails.workingDirectory),
|
|
110
|
+
env: process.env,
|
|
111
|
+
stdio: "pipe",
|
|
112
|
+
};
|
|
113
|
+
(0, child_process_1.execSync)(`terraform init`, opts);
|
|
114
|
+
let planOutput;
|
|
115
|
+
try {
|
|
116
|
+
planOutput = (0, child_process_1.execSync)(`terraform plan -input=false -detailed-exitcode`, opts).toString();
|
|
117
|
+
}
|
|
118
|
+
catch (error) {
|
|
119
|
+
planOutput = error.stdout ? error.stdout.toString() : "";
|
|
120
|
+
}
|
|
121
|
+
if (planOutput.includes("No changes. Your infrastructure matches the configuration.")) {
|
|
122
|
+
return new AssertionReturn(`Expected subject to be idempotent with no changes`, true);
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
throw new Error(`Plan resulted in changes:\n${planOutput}`);
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
return new AssertionReturn(`Expected subject to be idempotent with no changes`, true);
|
|
129
|
+
}
|
|
130
|
+
catch (error) {
|
|
131
|
+
console.error("Error during Terraform init or plan:", error);
|
|
132
|
+
throw error;
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
exports.TerraformIdempotentCheck = TerraformIdempotentCheck;
|
|
136
|
+
function TerraformDestroy(stack, streamOutput = false) {
|
|
137
|
+
try {
|
|
138
|
+
const manifest = JSON.parse(fs.readFileSync(path.resolve(stack, "manifest.json"), "utf8"));
|
|
139
|
+
const stacks = Object.entries(manifest.stacks);
|
|
140
|
+
for (const [, stackDetails] of stacks) {
|
|
141
|
+
const opts = {
|
|
142
|
+
cwd: path.resolve(stack, stackDetails.workingDirectory),
|
|
143
|
+
env: process.env,
|
|
144
|
+
encoding: "utf-8",
|
|
145
|
+
};
|
|
146
|
+
const initResult = execTerraformCommand(`terraform init`, opts, streamOutput);
|
|
147
|
+
if (initResult.exitCode !== 0)
|
|
148
|
+
throw new Error(`Terraform init failed: ${initResult.stdout} ${initResult.stderr}`);
|
|
149
|
+
const destroyResult = execTerraformCommand(`terraform destroy -auto-approve`, opts, streamOutput);
|
|
150
|
+
if (destroyResult.exitCode !== 0)
|
|
151
|
+
throw new Error(`Terraform destroy failed: ${destroyResult.stdout} ${destroyResult.stderr}`);
|
|
152
|
+
}
|
|
153
|
+
return new AssertionReturn(`Expected subject to destroy successfully`, true);
|
|
154
|
+
}
|
|
155
|
+
catch (error) {
|
|
156
|
+
console.error("Error during Terraform init or destroy:", error);
|
|
157
|
+
return new AssertionReturn(`Expected subject to destroy successfully`, false);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
exports.TerraformDestroy = TerraformDestroy;
|
|
161
|
+
function TerraformApplyAndCheckIdempotency(stack, streamOutput = false) {
|
|
162
|
+
const applyResult = TerraformApply(stack, streamOutput);
|
|
163
|
+
if (applyResult.error) {
|
|
164
|
+
return new AssertionReturn(applyResult.error.message, false);
|
|
165
|
+
}
|
|
166
|
+
const planResult = TerraformPlanExitCode(stack, streamOutput);
|
|
167
|
+
if (planResult.error) {
|
|
168
|
+
return new AssertionReturn(planResult.error.message, false);
|
|
169
|
+
}
|
|
170
|
+
if (planResult.exitCode !== 0) {
|
|
171
|
+
return new AssertionReturn(`Terraform configuration not idempotent:\n${planResult.stdout}`, false);
|
|
172
|
+
}
|
|
173
|
+
return new AssertionReturn(`Terraform apply and idempotency check completed successfully`, true);
|
|
174
|
+
}
|
|
175
|
+
exports.TerraformApplyAndCheckIdempotency = TerraformApplyAndCheckIdempotency;
|
|
176
|
+
function TerraformApplyCheckAndDestroy(stack) {
|
|
177
|
+
try {
|
|
178
|
+
const applyAndCheckResult = TerraformApplyAndCheckIdempotency(stack);
|
|
179
|
+
if (!applyAndCheckResult.pass) {
|
|
180
|
+
throw new Error(applyAndCheckResult.message);
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
catch (error) {
|
|
184
|
+
console.error("Error during Terraform apply and idempotency check:", error);
|
|
185
|
+
throw error; // Re-throw the error to ensure the test fails
|
|
186
|
+
}
|
|
187
|
+
finally {
|
|
188
|
+
try {
|
|
189
|
+
const destroyResult = TerraformDestroy(stack);
|
|
190
|
+
if (!destroyResult.pass) {
|
|
191
|
+
console.error("Error during Terraform destroy:", destroyResult.message);
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
catch (destroyError) {
|
|
195
|
+
console.error("Error during Terraform destroy:", destroyError);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
exports.TerraformApplyCheckAndDestroy = TerraformApplyCheckAndDestroy;
|
|
200
|
+
function TerraformPlan(stack) {
|
|
201
|
+
try {
|
|
202
|
+
// Assuming the presence of a received variable pointing to the relevant directory
|
|
203
|
+
const manifest = JSON.parse(fs.readFileSync(path.resolve(stack, "manifest.json"), "utf8"));
|
|
204
|
+
const stacks = Object.entries(manifest.stacks);
|
|
205
|
+
stacks.forEach(([, stackDetails]) => {
|
|
206
|
+
const opts = {
|
|
207
|
+
cwd: path.resolve(stack, stackDetails.workingDirectory),
|
|
208
|
+
env: process.env,
|
|
209
|
+
stdio: "pipe",
|
|
210
|
+
};
|
|
211
|
+
(0, child_process_1.execSync)(`terraform init`, opts);
|
|
212
|
+
(0, child_process_1.execSync)(`terraform plan -input=false -lock=false`, opts);
|
|
213
|
+
});
|
|
214
|
+
return new AssertionReturn(`Expected subject not to plan successfully`, true);
|
|
215
|
+
}
|
|
216
|
+
catch (error) {
|
|
217
|
+
console.error("Error during Terraform init or plan:", error);
|
|
218
|
+
throw error;
|
|
219
|
+
return new AssertionReturn("Expected subject to plan successfully, false", false);
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
exports.TerraformPlan = TerraformPlan;
|
|
223
|
+
class AssertionReturn {
|
|
224
|
+
/**
|
|
225
|
+
* Create an AssertionReturn
|
|
226
|
+
* @param message - String message containing information about the result of the assertion
|
|
227
|
+
* @param pass - Boolean pass denoting the success of the assertion
|
|
228
|
+
*/
|
|
229
|
+
constructor(message, pass) {
|
|
230
|
+
this.message = message;
|
|
231
|
+
this.pass = pass;
|
|
232
|
+
if (!pass) {
|
|
233
|
+
throw new Error(message);
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
exports.AssertionReturn = AssertionReturn;
|
|
238
|
+
// Define a cleanup function that can be exported and used in tests.
|
|
239
|
+
function cleanupCdkTfOutDirs() {
|
|
240
|
+
try {
|
|
241
|
+
(0, child_process_1.execSync)('find /tmp -name "cdktf.outdir.*" -type d -exec rm -rf {} +');
|
|
242
|
+
// console.log(
|
|
243
|
+
// "Cleanup of cdktf.outdir.* directories in /tmp was successful.",
|
|
244
|
+
// );
|
|
245
|
+
}
|
|
246
|
+
catch (error) {
|
|
247
|
+
console.error("Error during cleanup:", error);
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
exports.cleanupCdkTfOutDirs = cleanupCdkTfOutDirs;
|
|
251
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/testing/index.ts"],"names":[],"mappings":";;;AAAA,iDAA4E;AAC5E,yBAAyB;AACzB,6BAA6B;AAC7B,+BAA+B;AAC/B,iCAAuC;AAGvC,MAAa,aAAc,SAAQ,sBAAc;IAG/C,YAAY,KAAgB,EAAE,EAAU;QACtC,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,IAAI,GAAG,IAAI,KAAK,CAAC,iBAAiB,CAAC,IAAI,EAAE,MAAM,EAAE;YACrD,IAAI,EAAE,QAAQ;YACd,OAAO,EAAE,MAAM;YACf,WAAW,EAAE,6CAA6C;SAC3D,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC;IACzB,CAAC;CACF;AAdD,sCAcC;AAED,SAAgB,oBAAoB,CAClC,OAAe,EACf,IAAuC,EACvC,YAAqB;IAErB,IAAI;QACF,IAAI,YAAY,EAAE;YAChB,IAAA,wBAAQ,EAAC,OAAO,EAAE,EAAE,GAAG,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC;YACjD,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,QAAQ,EAAE,CAAC,EAAE,CAAC;SAChD;aAAM;YACL,MAAM,MAAM,GAAG,IAAA,wBAAQ,EAAC,OAAO,EAAE,EAAE,GAAG,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC;YACxE,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,QAAQ,EAAE,CAAC,EAAE,CAAC;SAC5C;KACF;IAAC,OAAO,KAAU,EAAE;QACnB,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC3D,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC3D,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;KACxD;AACH,CAAC;AAlBD,oDAkBC;AAED,SAAgB,cAAc,CAC5B,KAAU,EACV,eAAwB,KAAK;IAE7B,IAAI;QACF,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CACzB,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,CAAC,EAAE,MAAM,CAAC,CAC9D,CAAC;QACF,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAE/C,KAAK,MAAM,CAAC,EAAE,YAAY,CAAC,IAAI,MAAM,EAAE;YACrC,MAAM,IAAI,GAAsC;gBAC9C,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,EAAG,YAAoB,CAAC,gBAAgB,CAAC;gBAChE,GAAG,EAAE,OAAO,CAAC,GAAG;gBAChB,QAAQ,EAAE,OAAO;aAClB,CAAC;YAEF,MAAM,UAAU,GAAG,oBAAoB,CACrC,gBAAgB,EAChB,IAAI,EACJ,YAAY,CACb,CAAC;YACF,IAAI,UAAU,CAAC,QAAQ,KAAK,CAAC;gBAC3B,MAAM,IAAI,KAAK,CACb,0BAA0B,UAAU,CAAC,MAAM,IAAI,UAAU,CAAC,MAAM,EAAE,CACnE,CAAC;YAEJ,MAAM,WAAW,GAAG,oBAAoB,CACtC,+BAA+B,EAC/B,IAAI,EACJ,YAAY,CACb,CAAC;YACF,IAAI,WAAW,CAAC,QAAQ,KAAK,CAAC,EAAE;gBAC9B,OAAO;oBACL,MAAM,EAAE,WAAW,CAAC,MAAM;oBAC1B,MAAM,EAAE,WAAW,CAAC,MAAM;oBAC1B,KAAK,EAAE,IAAI,KAAK,CACd,2BAA2B,WAAW,CAAC,MAAM,IAAI,WAAW,CAAC,MAAM,EAAE,CACtE;iBACF,CAAC;aACH;SACF;QAED,OAAO,EAAE,MAAM,EAAE,2BAA2B,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;KACzE;IAAC,OAAO,KAAU,EAAE;QACnB,OAAO,CAAC,KAAK,CAAC,uCAAuC,EAAE,KAAK,CAAC,CAAC;QAC9D,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC;KAC1C;AACH,CAAC;AAhDD,wCAgDC;AAED,SAAgB,qBAAqB,CACnC,KAAU,EACV,eAAwB,KAAK;IAE7B,IAAI;QACF,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CACzB,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,CAAC,EAAE,MAAM,CAAC,CAC9D,CAAC;QACF,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAE/C,KAAK,MAAM,CAAC,EAAE,YAAY,CAAC,IAAI,MAAM,EAAE;YACrC,MAAM,IAAI,GAAsC;gBAC9C,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,EAAG,YAAoB,CAAC,gBAAgB,CAAC;gBAChE,GAAG,EAAE,OAAO,CAAC,GAAG;gBAChB,QAAQ,EAAE,OAAO;aAClB,CAAC;YAEF,MAAM,UAAU,GAAG,oBAAoB,CACrC,gBAAgB,EAChB,IAAI,EACJ,YAAY,CACb,CAAC;YACF,IAAI,UAAU,CAAC,QAAQ,KAAK,CAAC;gBAC3B,MAAM,IAAI,KAAK,CACb,0BAA0B,UAAU,CAAC,MAAM,IAAI,UAAU,CAAC,MAAM,EAAE,CACnE,CAAC;YAEJ,MAAM,UAAU,GAAG,oBAAoB,CACrC,4DAA4D,EAC5D,IAAI,EACJ,YAAY,CACb,CAAC;YACF,OAAO;gBACL,MAAM,EAAE,UAAU,CAAC,MAAM;gBACzB,MAAM,EAAE,UAAU,CAAC,MAAM;gBACzB,QAAQ,EAAE,UAAU,CAAC,QAAQ;gBAC7B,KAAK,EAAE,IAAI;aACZ,CAAC;SACH;QAED,OAAO;YACL,MAAM,EAAE,0BAA0B;YAClC,MAAM,EAAE,EAAE;YACV,QAAQ,EAAE,CAAC;YACX,KAAK,EAAE,IAAI;SACZ,CAAC;KACH;IAAC,OAAO,KAAU,EAAE;QACnB,OAAO,CAAC,KAAK,CAAC,sCAAsC,EAAE,KAAK,CAAC,CAAC;QAC7D,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,QAAQ,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC;KACvD;AACH,CAAC;AAlDD,sDAkDC;AACD,SAAgB,wBAAwB,CAAC,KAAU;IACjD,IAAI;QACF,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CACzB,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,CAAC,EAAE,MAAM,CAAC,CAC9D,CAAC;QACF,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAE/C,KAAK,MAAM,CAAC,EAAE,YAAY,CAAC,IAAI,MAAM,EAAE;YACrC,MAAM,IAAI,GAAG;gBACX,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,EAAG,YAAoB,CAAC,gBAAgB,CAAC;gBAChE,GAAG,EAAE,OAAO,CAAC,GAAG;gBAChB,KAAK,EAAE,MAAM;aACP,CAAC;YAET,IAAA,wBAAQ,EAAC,gBAAgB,EAAE,IAAI,CAAC,CAAC;YAEjC,IAAI,UAAkB,CAAC;YACvB,IAAI;gBACF,UAAU,GAAG,IAAA,wBAAQ,EACnB,gDAAgD,EAChD,IAAI,CACL,CAAC,QAAQ,EAAE,CAAC;aACd;YAAC,OAAO,KAAU,EAAE;gBACnB,UAAU,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;aAC1D;YAED,IACE,UAAU,CAAC,QAAQ,CACjB,4DAA4D,CAC7D,EACD;gBACA,OAAO,IAAI,eAAe,CACxB,mDAAmD,EACnD,IAAI,CACL,CAAC;aACH;iBAAM;gBACL,MAAM,IAAI,KAAK,CAAC,8BAA8B,UAAU,EAAE,CAAC,CAAC;aAC7D;SACF;QAED,OAAO,IAAI,eAAe,CACxB,mDAAmD,EACnD,IAAI,CACL,CAAC;KACH;IAAC,OAAO,KAAK,EAAE;QACd,OAAO,CAAC,KAAK,CAAC,sCAAsC,EAAE,KAAK,CAAC,CAAC;QAC7D,MAAM,KAAK,CAAC;KACb;AACH,CAAC;AAhDD,4DAgDC;AAED,SAAgB,gBAAgB,CAC9B,KAAU,EACV,eAAwB,KAAK;IAE7B,IAAI;QACF,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CACzB,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,CAAC,EAAE,MAAM,CAAC,CAC9D,CAAC;QACF,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAE/C,KAAK,MAAM,CAAC,EAAE,YAAY,CAAC,IAAI,MAAM,EAAE;YACrC,MAAM,IAAI,GAAsC;gBAC9C,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,EAAG,YAAoB,CAAC,gBAAgB,CAAC;gBAChE,GAAG,EAAE,OAAO,CAAC,GAAG;gBAChB,QAAQ,EAAE,OAAO;aAClB,CAAC;YAEF,MAAM,UAAU,GAAG,oBAAoB,CACrC,gBAAgB,EAChB,IAAI,EACJ,YAAY,CACb,CAAC;YACF,IAAI,UAAU,CAAC,QAAQ,KAAK,CAAC;gBAC3B,MAAM,IAAI,KAAK,CACb,0BAA0B,UAAU,CAAC,MAAM,IAAI,UAAU,CAAC,MAAM,EAAE,CACnE,CAAC;YAEJ,MAAM,aAAa,GAAG,oBAAoB,CACxC,iCAAiC,EACjC,IAAI,EACJ,YAAY,CACb,CAAC;YACF,IAAI,aAAa,CAAC,QAAQ,KAAK,CAAC;gBAC9B,MAAM,IAAI,KAAK,CACb,6BAA6B,aAAa,CAAC,MAAM,IAAI,aAAa,CAAC,MAAM,EAAE,CAC5E,CAAC;SACL;QAED,OAAO,IAAI,eAAe,CACxB,0CAA0C,EAC1C,IAAI,CACL,CAAC;KACH;IAAC,OAAO,KAAU,EAAE;QACnB,OAAO,CAAC,KAAK,CAAC,yCAAyC,EAAE,KAAK,CAAC,CAAC;QAChE,OAAO,IAAI,eAAe,CACxB,0CAA0C,EAC1C,KAAK,CACN,CAAC;KACH;AACH,CAAC;AAjDD,4CAiDC;AAED,SAAgB,iCAAiC,CAC/C,KAAU,EACV,eAAwB,KAAK;IAE7B,MAAM,WAAW,GAAG,cAAc,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;IACxD,IAAI,WAAW,CAAC,KAAK,EAAE;QACrB,OAAO,IAAI,eAAe,CAAC,WAAW,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;KAC9D;IAED,MAAM,UAAU,GAAG,qBAAqB,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;IAC9D,IAAI,UAAU,CAAC,KAAK,EAAE;QACpB,OAAO,IAAI,eAAe,CAAC,UAAU,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;KAC7D;IAED,IAAI,UAAU,CAAC,QAAQ,KAAK,CAAC,EAAE;QAC7B,OAAO,IAAI,eAAe,CACxB,4CAA4C,UAAU,CAAC,MAAM,EAAE,EAC/D,KAAK,CACN,CAAC;KACH;IAED,OAAO,IAAI,eAAe,CACxB,8DAA8D,EAC9D,IAAI,CACL,CAAC;AACJ,CAAC;AAzBD,8EAyBC;AAED,SAAgB,6BAA6B,CAAC,KAAU;IACtD,IAAI;QACF,MAAM,mBAAmB,GAAG,iCAAiC,CAAC,KAAK,CAAC,CAAC;QACrE,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;SAC9C;KACF;IAAC,OAAO,KAAK,EAAE;QACd,OAAO,CAAC,KAAK,CAAC,qDAAqD,EAAE,KAAK,CAAC,CAAC;QAC5E,MAAM,KAAK,CAAC,CAAC,8CAA8C;KAC5D;YAAS;QACR,IAAI;YACF,MAAM,aAAa,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAC;YAC9C,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE;gBACvB,OAAO,CAAC,KAAK,CAAC,iCAAiC,EAAE,aAAa,CAAC,OAAO,CAAC,CAAC;aACzE;SACF;QAAC,OAAO,YAAY,EAAE;YACrB,OAAO,CAAC,KAAK,CAAC,iCAAiC,EAAE,YAAY,CAAC,CAAC;SAChE;KACF;AACH,CAAC;AAnBD,sEAmBC;AAED,SAAgB,aAAa,CAAC,KAAU;IACtC,IAAI;QACF,kFAAkF;QAClF,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CACzB,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,CAAC,EAAE,MAAM,CAAC,CAC9D,CAAC;QACF,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAC/C,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,EAAE,EAAE;YAClC,MAAM,IAAI,GAAG;gBACX,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,EAAG,YAAoB,CAAC,gBAAgB,CAAC;gBAChE,GAAG,EAAE,OAAO,CAAC,GAAG;gBAChB,KAAK,EAAE,MAAM;aACP,CAAC;YACT,IAAA,wBAAQ,EAAC,gBAAgB,EAAE,IAAI,CAAC,CAAC;YACjC,IAAA,wBAAQ,EAAC,yCAAyC,EAAE,IAAI,CAAC,CAAC;QAC5D,CAAC,CAAC,CAAC;QAEH,OAAO,IAAI,eAAe,CACxB,2CAA2C,EAC3C,IAAI,CACL,CAAC;KACH;IAAC,OAAO,KAAK,EAAE;QACd,OAAO,CAAC,KAAK,CAAC,sCAAsC,EAAE,KAAK,CAAC,CAAC;QAC7D,MAAM,KAAK,CAAC;QACZ,OAAO,IAAI,eAAe,CACxB,8CAA8C,EAC9C,KAAK,CACN,CAAC;KACH;AACH,CAAC;AA7BD,sCA6BC;AAED,MAAa,eAAe;IAC1B;;;;OAIG;IACH,YACkB,OAAe,EACf,IAAa;QADb,YAAO,GAAP,OAAO,CAAQ;QACf,SAAI,GAAJ,IAAI,CAAS;QAE7B,IAAI,CAAC,IAAI,EAAE;YACT,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC;SAC1B;IACH,CAAC;CACF;AAdD,0CAcC;AAED,oEAAoE;AACpE,SAAgB,mBAAmB;IACjC,IAAI;QACF,IAAA,wBAAQ,EAAC,4DAA4D,CAAC,CAAC;QACvE,eAAe;QACf,qEAAqE;QACrE,KAAK;KACN;IAAC,OAAO,KAAK,EAAE;QACd,OAAO,CAAC,KAAK,CAAC,uBAAuB,EAAE,KAAK,CAAC,CAAC;KAC/C;AACH,CAAC;AATD,kDASC","sourcesContent":["import { execSync, ExecSyncOptionsWithStringEncoding } from \"child_process\";\nimport * as fs from \"fs\";\nimport * as path from \"path\";\nimport * as cdktf from \"cdktf\";\nimport { TerraformStack } from \"cdktf\";\nimport { Construct } from \"constructs\";\n\nexport class BaseTestStack extends TerraformStack {\n  public readonly name: string;\n\n  constructor(scope: Construct, id: string) {\n    super(scope, id);\n\n    const name = new cdktf.TerraformVariable(this, \"name\", {\n      type: \"string\",\n      default: \"test\",\n      description: \"System name used to randomize the resources\",\n    });\n\n    this.name = name.value;\n  }\n}\n\nexport function execTerraformCommand(\n  command: string,\n  opts: ExecSyncOptionsWithStringEncoding,\n  streamOutput: boolean,\n): { stdout: string; stderr: string; exitCode: number } {\n  try {\n    if (streamOutput) {\n      execSync(command, { ...opts, stdio: \"inherit\" });\n      return { stdout: \"\", stderr: \"\", exitCode: 0 };\n    } else {\n      const stdout = execSync(command, { ...opts, stdio: \"pipe\" }).toString();\n      return { stdout, stderr: \"\", exitCode: 0 };\n    }\n  } catch (error: any) {\n    const stdout = error.stdout ? error.stdout.toString() : \"\";\n    const stderr = error.stderr ? error.stderr.toString() : \"\";\n    return { stdout, stderr, exitCode: error.status || 1 };\n  }\n}\n\nexport function TerraformApply(\n  stack: any,\n  streamOutput: boolean = false,\n): { stdout: string; stderr: string; error: any } {\n  try {\n    const manifest = JSON.parse(\n      fs.readFileSync(path.resolve(stack, \"manifest.json\"), \"utf8\"),\n    );\n    const stacks = Object.entries(manifest.stacks);\n\n    for (const [, stackDetails] of stacks) {\n      const opts: ExecSyncOptionsWithStringEncoding = {\n        cwd: path.resolve(stack, (stackDetails as any).workingDirectory),\n        env: process.env,\n        encoding: \"utf-8\",\n      };\n\n      const initResult = execTerraformCommand(\n        `terraform init`,\n        opts,\n        streamOutput,\n      );\n      if (initResult.exitCode !== 0)\n        throw new Error(\n          `Terraform init failed: ${initResult.stdout} ${initResult.stderr}`,\n        );\n\n      const applyResult = execTerraformCommand(\n        `terraform apply -auto-approve`,\n        opts,\n        streamOutput,\n      );\n      if (applyResult.exitCode !== 0) {\n        return {\n          stdout: applyResult.stdout,\n          stderr: applyResult.stderr,\n          error: new Error(\n            `Terraform apply failed: ${applyResult.stdout} ${applyResult.stderr}`,\n          ),\n        };\n      }\n    }\n\n    return { stdout: \"Terraform apply succeeded\", stderr: \"\", error: null };\n  } catch (error: any) {\n    console.error(\"Error during Terraform init or apply:\", error);\n    return { stdout: \"\", stderr: \"\", error };\n  }\n}\n\nexport function TerraformPlanExitCode(\n  stack: any,\n  streamOutput: boolean = false,\n): { stdout: string; stderr: string; exitCode: number; error: any } {\n  try {\n    const manifest = JSON.parse(\n      fs.readFileSync(path.resolve(stack, \"manifest.json\"), \"utf8\"),\n    );\n    const stacks = Object.entries(manifest.stacks);\n\n    for (const [, stackDetails] of stacks) {\n      const opts: ExecSyncOptionsWithStringEncoding = {\n        cwd: path.resolve(stack, (stackDetails as any).workingDirectory),\n        env: process.env,\n        encoding: \"utf-8\",\n      };\n\n      const initResult = execTerraformCommand(\n        `terraform init`,\n        opts,\n        streamOutput,\n      );\n      if (initResult.exitCode !== 0)\n        throw new Error(\n          `Terraform init failed: ${initResult.stdout} ${initResult.stderr}`,\n        );\n\n      const planResult = execTerraformCommand(\n        `terraform plan -input=false -lock=false -detailed-exitcode`,\n        opts,\n        streamOutput,\n      );\n      return {\n        stdout: planResult.stdout,\n        stderr: planResult.stderr,\n        exitCode: planResult.exitCode,\n        error: null,\n      };\n    }\n\n    return {\n      stdout: \"Terraform plan succeeded\",\n      stderr: \"\",\n      exitCode: 0,\n      error: null,\n    };\n  } catch (error: any) {\n    console.error(\"Error during Terraform init or plan:\", error);\n    return { stdout: \"\", stderr: \"\", exitCode: 1, error };\n  }\n}\nexport function TerraformIdempotentCheck(stack: any): AssertionReturn {\n  try {\n    const manifest = JSON.parse(\n      fs.readFileSync(path.resolve(stack, \"manifest.json\"), \"utf8\"),\n    );\n    const stacks = Object.entries(manifest.stacks);\n\n    for (const [, stackDetails] of stacks) {\n      const opts = {\n        cwd: path.resolve(stack, (stackDetails as any).workingDirectory),\n        env: process.env,\n        stdio: \"pipe\",\n      } as any;\n\n      execSync(`terraform init`, opts);\n\n      let planOutput: string;\n      try {\n        planOutput = execSync(\n          `terraform plan -input=false -detailed-exitcode`,\n          opts,\n        ).toString();\n      } catch (error: any) {\n        planOutput = error.stdout ? error.stdout.toString() : \"\";\n      }\n\n      if (\n        planOutput.includes(\n          \"No changes. Your infrastructure matches the configuration.\",\n        )\n      ) {\n        return new AssertionReturn(\n          `Expected subject to be idempotent with no changes`,\n          true,\n        );\n      } else {\n        throw new Error(`Plan resulted in changes:\\n${planOutput}`);\n      }\n    }\n\n    return new AssertionReturn(\n      `Expected subject to be idempotent with no changes`,\n      true,\n    );\n  } catch (error) {\n    console.error(\"Error during Terraform init or plan:\", error);\n    throw error;\n  }\n}\n\nexport function TerraformDestroy(\n  stack: any,\n  streamOutput: boolean = false,\n): AssertionReturn {\n  try {\n    const manifest = JSON.parse(\n      fs.readFileSync(path.resolve(stack, \"manifest.json\"), \"utf8\"),\n    );\n    const stacks = Object.entries(manifest.stacks);\n\n    for (const [, stackDetails] of stacks) {\n      const opts: ExecSyncOptionsWithStringEncoding = {\n        cwd: path.resolve(stack, (stackDetails as any).workingDirectory),\n        env: process.env,\n        encoding: \"utf-8\",\n      };\n\n      const initResult = execTerraformCommand(\n        `terraform init`,\n        opts,\n        streamOutput,\n      );\n      if (initResult.exitCode !== 0)\n        throw new Error(\n          `Terraform init failed: ${initResult.stdout} ${initResult.stderr}`,\n        );\n\n      const destroyResult = execTerraformCommand(\n        `terraform destroy -auto-approve`,\n        opts,\n        streamOutput,\n      );\n      if (destroyResult.exitCode !== 0)\n        throw new Error(\n          `Terraform destroy failed: ${destroyResult.stdout} ${destroyResult.stderr}`,\n        );\n    }\n\n    return new AssertionReturn(\n      `Expected subject to destroy successfully`,\n      true,\n    );\n  } catch (error: any) {\n    console.error(\"Error during Terraform init or destroy:\", error);\n    return new AssertionReturn(\n      `Expected subject to destroy successfully`,\n      false,\n    );\n  }\n}\n\nexport function TerraformApplyAndCheckIdempotency(\n  stack: any,\n  streamOutput: boolean = false,\n): AssertionReturn {\n  const applyResult = TerraformApply(stack, streamOutput);\n  if (applyResult.error) {\n    return new AssertionReturn(applyResult.error.message, false);\n  }\n\n  const planResult = TerraformPlanExitCode(stack, streamOutput);\n  if (planResult.error) {\n    return new AssertionReturn(planResult.error.message, false);\n  }\n\n  if (planResult.exitCode !== 0) {\n    return new AssertionReturn(\n      `Terraform configuration not idempotent:\\n${planResult.stdout}`,\n      false,\n    );\n  }\n\n  return new AssertionReturn(\n    `Terraform apply and idempotency check completed successfully`,\n    true,\n  );\n}\n\nexport function TerraformApplyCheckAndDestroy(stack: any): void {\n  try {\n    const applyAndCheckResult = TerraformApplyAndCheckIdempotency(stack);\n    if (!applyAndCheckResult.pass) {\n      throw new Error(applyAndCheckResult.message);\n    }\n  } catch (error) {\n    console.error(\"Error during Terraform apply and idempotency check:\", error);\n    throw error; // Re-throw the error to ensure the test fails\n  } finally {\n    try {\n      const destroyResult = TerraformDestroy(stack);\n      if (!destroyResult.pass) {\n        console.error(\"Error during Terraform destroy:\", destroyResult.message);\n      }\n    } catch (destroyError) {\n      console.error(\"Error during Terraform destroy:\", destroyError);\n    }\n  }\n}\n\nexport function TerraformPlan(stack: any): AssertionReturn {\n  try {\n    // Assuming the presence of a received variable pointing to the relevant directory\n    const manifest = JSON.parse(\n      fs.readFileSync(path.resolve(stack, \"manifest.json\"), \"utf8\"),\n    );\n    const stacks = Object.entries(manifest.stacks);\n    stacks.forEach(([, stackDetails]) => {\n      const opts = {\n        cwd: path.resolve(stack, (stackDetails as any).workingDirectory),\n        env: process.env,\n        stdio: \"pipe\",\n      } as any;\n      execSync(`terraform init`, opts);\n      execSync(`terraform plan -input=false -lock=false`, opts);\n    });\n\n    return new AssertionReturn(\n      `Expected subject not to plan successfully`,\n      true,\n    );\n  } catch (error) {\n    console.error(\"Error during Terraform init or plan:\", error);\n    throw error;\n    return new AssertionReturn(\n      \"Expected subject to plan successfully, false\",\n      false,\n    );\n  }\n}\n\nexport class AssertionReturn {\n  /**\n   * Create an AssertionReturn\n   * @param message - String message containing information about the result of the assertion\n   * @param pass - Boolean pass denoting the success of the assertion\n   */\n  constructor(\n    public readonly message: string,\n    public readonly pass: boolean,\n  ) {\n    if (!pass) {\n      throw new Error(message);\n    }\n  }\n}\n\n// Define a cleanup function that can be exported and used in tests.\nexport function cleanupCdkTfOutDirs() {\n  try {\n    execSync('find /tmp -name \"cdktf.outdir.*\" -type d -exec rm -rf {} +');\n    // console.log(\n    //   \"Cleanup of cdktf.outdir.* directories in /tmp was successful.\",\n    // );\n  } catch (error) {\n    console.error(\"Error during cleanup:\", error);\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -17,18 +17,23 @@
|
|
|
17
17
|
"eslint": "npx projen eslint",
|
|
18
18
|
"package": "npx projen package",
|
|
19
19
|
"package-all": "npx projen package-all",
|
|
20
|
+
"package:dotnet": "npx projen package:dotnet",
|
|
21
|
+
"package:java": "npx projen package:java",
|
|
20
22
|
"package:js": "npx projen package:js",
|
|
23
|
+
"package:python": "npx projen package:python",
|
|
21
24
|
"post-compile": "npx projen post-compile",
|
|
22
25
|
"post-upgrade": "npx projen post-upgrade",
|
|
23
26
|
"pre-compile": "npx projen pre-compile",
|
|
24
27
|
"release": "npx projen release",
|
|
25
|
-
"test": "
|
|
28
|
+
"test": "jest --testMatch '**/*.spec.ts'",
|
|
26
29
|
"test:update": "npx projen test:update",
|
|
27
30
|
"test:watch": "npx projen test:watch",
|
|
28
31
|
"unbump": "npx projen unbump",
|
|
29
32
|
"upgrade": "npx projen upgrade",
|
|
30
33
|
"watch": "npx projen watch",
|
|
31
34
|
"projen": "npx projen",
|
|
35
|
+
"integration": "STREAM_OUTPUT=true jest --testMatch '**/*.integ.ts'",
|
|
36
|
+
"integration:nostream": "STREAM_OUTPUT=false jest --maxWorkers=12 --testMatch '**/*.integ.ts'",
|
|
32
37
|
"generate-index": "node ./scripts/generate-index.js"
|
|
33
38
|
},
|
|
34
39
|
"author": {
|
|
@@ -38,7 +43,7 @@
|
|
|
38
43
|
},
|
|
39
44
|
"devDependencies": {
|
|
40
45
|
"@cdktf/provider-azurerm": "9.0.8",
|
|
41
|
-
"@types/jest": "^29.5.
|
|
46
|
+
"@types/jest": "^29.5.12",
|
|
42
47
|
"@types/moment": "^2.13.0",
|
|
43
48
|
"@types/node": "^20",
|
|
44
49
|
"@typescript-eslint/eslint-plugin": "^6",
|
|
@@ -53,14 +58,14 @@
|
|
|
53
58
|
"jest": "^29.7.0",
|
|
54
59
|
"jest-junit": "^15",
|
|
55
60
|
"jsii": "~5.2.0",
|
|
56
|
-
"jsii-diff": "^1.
|
|
57
|
-
"jsii-docgen": "^10.
|
|
58
|
-
"jsii-pacmak": "^1.
|
|
61
|
+
"jsii-diff": "^1.98.0",
|
|
62
|
+
"jsii-docgen": "^10.4.9",
|
|
63
|
+
"jsii-pacmak": "^1.98.0",
|
|
59
64
|
"jsii-rosetta": "~5.2.0",
|
|
60
|
-
"prettier": "^3.2.
|
|
61
|
-
"projen": "^0.
|
|
65
|
+
"prettier": "^3.2.5",
|
|
66
|
+
"projen": "^0.81.15",
|
|
62
67
|
"standard-version": "^9",
|
|
63
|
-
"ts-jest": "^29.1.
|
|
68
|
+
"ts-jest": "^29.1.3",
|
|
64
69
|
"ts-node": "^10.9.2",
|
|
65
70
|
"typescript": "~5.2.0"
|
|
66
71
|
},
|
|
@@ -98,11 +103,11 @@
|
|
|
98
103
|
"publishConfig": {
|
|
99
104
|
"access": "public"
|
|
100
105
|
},
|
|
101
|
-
"version": "0.0.3-pre.
|
|
106
|
+
"version": "0.0.3-pre.12",
|
|
102
107
|
"jest": {
|
|
103
108
|
"testMatch": [
|
|
104
109
|
"<rootDir>/src/**/__tests__/**/*.ts?(x)",
|
|
105
|
-
"<rootDir
|
|
110
|
+
"<rootDir>/@(|src)/**/*(*.)@(spec|test|integ).ts?(x)"
|
|
106
111
|
],
|
|
107
112
|
"clearMocks": true,
|
|
108
113
|
"collectCoverage": true,
|
|
@@ -150,7 +155,23 @@
|
|
|
150
155
|
"stability": "stable",
|
|
151
156
|
"jsii": {
|
|
152
157
|
"outdir": "dist",
|
|
153
|
-
"targets": {
|
|
158
|
+
"targets": {
|
|
159
|
+
"java": {
|
|
160
|
+
"package": "com.microsoft.terraformcdkconstructs",
|
|
161
|
+
"maven": {
|
|
162
|
+
"groupId": "com.microsoft.terraformcdkconstructs",
|
|
163
|
+
"artifactId": "cdktf-azure-constructs"
|
|
164
|
+
}
|
|
165
|
+
},
|
|
166
|
+
"python": {
|
|
167
|
+
"distName": "microsoft-cdktfconstructs",
|
|
168
|
+
"module": "microsoft_cdktfconstructs"
|
|
169
|
+
},
|
|
170
|
+
"dotnet": {
|
|
171
|
+
"namespace": "Microsoft.Cdktf.Azure.TFConstructs",
|
|
172
|
+
"packageId": "Microsoft.Cdktf.Azure.TFConstructs"
|
|
173
|
+
}
|
|
174
|
+
},
|
|
154
175
|
"tsc": {
|
|
155
176
|
"outDir": "lib",
|
|
156
177
|
"rootDir": "src"
|
package/cdktf.out/manifest.json
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": "0.17.3",
|
|
3
|
-
"stacks": {
|
|
4
|
-
"testExampleAzureResource": {
|
|
5
|
-
"name": "testExampleAzureResource",
|
|
6
|
-
"constructPath": "testExampleAzureResource",
|
|
7
|
-
"workingDirectory": "stacks/testExampleAzureResource",
|
|
8
|
-
"synthesizedStackPath": "stacks/testExampleAzureResource/cdk.tf.json",
|
|
9
|
-
"annotations": [],
|
|
10
|
-
"dependencies": []
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
}
|