@microsoft/terraform-cdk-constructs 1.7.1 → 1.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (121) hide show
  1. package/.jsii +46476 -27231
  2. package/API.md +68443 -28286
  3. package/lib/azure-actiongroup/lib/action-group.js +1 -1
  4. package/lib/azure-activitylogalert/lib/activity-log-alert.js +1 -1
  5. package/lib/azure-aks/lib/aks-cluster.js +1 -1
  6. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +1 -1
  7. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +1 -1
  8. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +1 -1
  9. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +1 -1
  10. package/lib/azure-dnsresolver/lib/dns-resolver.js +1 -1
  11. package/lib/azure-dnsresolver/lib/inbound-endpoint.js +1 -1
  12. package/lib/azure-dnsresolver/lib/outbound-endpoint.js +1 -1
  13. package/lib/azure-dnszone/lib/dns-zone.js +1 -1
  14. package/lib/azure-dnszone/lib/index.d.ts +1 -0
  15. package/lib/azure-dnszone/lib/index.js +2 -1
  16. package/lib/azure-dnszone/lib/records/dns-record-schemas.d.ts +68 -0
  17. package/lib/azure-dnszone/lib/records/dns-record-schemas.js +813 -0
  18. package/lib/azure-dnszone/lib/records/dns-records.d.ts +688 -0
  19. package/lib/azure-dnszone/lib/records/dns-records.js +924 -0
  20. package/lib/azure-dnszone/lib/records/index.d.ts +19 -0
  21. package/lib/azure-dnszone/lib/records/index.js +38 -0
  22. package/lib/azure-dnszone/test/dns-records.integ.d.ts +21 -0
  23. package/lib/azure-dnszone/test/dns-records.integ.js +321 -0
  24. package/lib/azure-dnszone/test/dns-records.spec.d.ts +20 -0
  25. package/lib/azure-dnszone/test/dns-records.spec.js +950 -0
  26. package/lib/azure-loganalyticsworkspace/index.d.ts +6 -0
  27. package/lib/azure-loganalyticsworkspace/index.js +23 -0
  28. package/lib/azure-loganalyticsworkspace/lib/index.d.ts +5 -0
  29. package/lib/azure-loganalyticsworkspace/lib/index.js +22 -0
  30. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace-schemas.d.ts +51 -0
  31. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace-schemas.js +255 -0
  32. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.d.ts +301 -0
  33. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.js +213 -0
  34. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.d.ts +9 -0
  35. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.js +71 -0
  36. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.d.ts +8 -0
  37. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.js +504 -0
  38. package/lib/azure-metricalert/lib/metric-alert.js +1 -1
  39. package/lib/azure-networkinterface/lib/network-interface.js +1 -1
  40. package/lib/azure-networksecuritygroup/lib/network-security-group.js +1 -1
  41. package/lib/azure-networkwatcher/index.d.ts +14 -0
  42. package/lib/azure-networkwatcher/index.js +31 -0
  43. package/lib/azure-networkwatcher/lib/index.d.ts +5 -0
  44. package/lib/azure-networkwatcher/lib/index.js +22 -0
  45. package/lib/azure-networkwatcher/lib/network-watcher-schemas.d.ts +47 -0
  46. package/lib/azure-networkwatcher/lib/network-watcher-schemas.js +167 -0
  47. package/lib/azure-networkwatcher/lib/network-watcher.d.ts +181 -0
  48. package/lib/azure-networkwatcher/lib/network-watcher.js +187 -0
  49. package/lib/azure-networkwatcher/test/network-watcher.integ.d.ts +12 -0
  50. package/lib/azure-networkwatcher/test/network-watcher.integ.js +84 -0
  51. package/lib/azure-networkwatcher/test/network-watcher.spec.d.ts +8 -0
  52. package/lib/azure-networkwatcher/test/network-watcher.spec.js +312 -0
  53. package/lib/azure-policyassignment/lib/policy-assignment.js +1 -1
  54. package/lib/azure-policydefinition/lib/policy-definition.js +1 -1
  55. package/lib/azure-policysetdefinition/index.d.ts +10 -0
  56. package/lib/azure-policysetdefinition/index.js +27 -0
  57. package/lib/azure-policysetdefinition/lib/index.d.ts +5 -0
  58. package/lib/azure-policysetdefinition/lib/index.js +22 -0
  59. package/lib/azure-policysetdefinition/lib/policy-set-definition-schemas.d.ts +50 -0
  60. package/lib/azure-policysetdefinition/lib/policy-set-definition-schemas.js +255 -0
  61. package/lib/azure-policysetdefinition/lib/policy-set-definition.d.ts +426 -0
  62. package/lib/azure-policysetdefinition/lib/policy-set-definition.js +255 -0
  63. package/lib/azure-policysetdefinition/test/policy-set-definition.integ.d.ts +9 -0
  64. package/lib/azure-policysetdefinition/test/policy-set-definition.integ.js +56 -0
  65. package/lib/azure-policysetdefinition/test/policy-set-definition.spec.d.ts +8 -0
  66. package/lib/azure-policysetdefinition/test/policy-set-definition.spec.js +745 -0
  67. package/lib/azure-privatednszone/lib/index.d.ts +1 -0
  68. package/lib/azure-privatednszone/lib/index.js +2 -1
  69. package/lib/azure-privatednszone/lib/private-dns-zone.d.ts +0 -2
  70. package/lib/azure-privatednszone/lib/private-dns-zone.js +6 -13
  71. package/lib/azure-privatednszone/lib/records/index.d.ts +7 -0
  72. package/lib/azure-privatednszone/lib/records/index.js +26 -0
  73. package/lib/azure-privatednszone/lib/records/private-dns-record-schemas.d.ts +52 -0
  74. package/lib/azure-privatednszone/lib/records/private-dns-record-schemas.js +683 -0
  75. package/lib/azure-privatednszone/lib/records/private-dns-records.d.ts +523 -0
  76. package/lib/azure-privatednszone/lib/records/private-dns-records.js +739 -0
  77. package/lib/azure-privatednszone/test/private-dns-records.integ.d.ts +19 -0
  78. package/lib/azure-privatednszone/test/private-dns-records.integ.js +245 -0
  79. package/lib/azure-privatednszone/test/private-dns-records.spec.d.ts +18 -0
  80. package/lib/azure-privatednszone/test/private-dns-records.spec.js +756 -0
  81. package/lib/azure-privatednszone/test/private-dns-zone.spec.js +5 -5
  82. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +1 -1
  83. package/lib/azure-publicipaddress/lib/public-ip-address.js +1 -1
  84. package/lib/azure-resourcegroup/lib/resource-group.js +1 -1
  85. package/lib/azure-roleassignment/lib/role-assignment.js +1 -1
  86. package/lib/azure-roledefinition/lib/role-definition.js +1 -1
  87. package/lib/azure-storageaccount/lib/storage-account.js +1 -1
  88. package/lib/azure-subnet/lib/subnet.js +1 -1
  89. package/lib/azure-virtualmachine/lib/virtual-machine.js +1 -1
  90. package/lib/azure-virtualnetwork/lib/virtual-network.js +1 -1
  91. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway-schemas.js +2 -2
  92. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.d.ts +4 -2
  93. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.js +8 -5
  94. package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.spec.js +109 -1
  95. package/lib/azure-virtualnetworkgatewayconnection/lib/virtual-network-gateway-connection.js +1 -1
  96. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +1 -1
  97. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +1 -1
  98. package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +1 -1
  99. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +1 -1
  100. package/lib/azure-virtualnetworkmanager/lib/network-group.js +1 -1
  101. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +1 -1
  102. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +1 -1
  103. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +1 -1
  104. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +1 -1
  105. package/lib/azure-vmss/lib/virtual-machine-scale-set.js +1 -1
  106. package/lib/core-azure/lib/azapi/azapi-resource.js +4 -4
  107. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
  108. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
  109. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +1 -1
  110. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
  111. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
  112. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
  113. package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +1 -1
  114. package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
  115. package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
  116. package/lib/index.d.ts +23 -0
  117. package/lib/index.js +25 -2
  118. package/lib/testing/index.js +2 -2
  119. package/lib/testing/lib/cleanup.js +1 -1
  120. package/lib/testing/lib/metadata.js +1 -1
  121. package/package.json +1 -1
@@ -0,0 +1,19 @@
1
+ /**
2
+ * Integration test for Azure Private DNS Zone Records
3
+ *
4
+ * This test demonstrates usage of all Private DNS record types
5
+ * and validates deployment, idempotency, and cleanup for child resources.
6
+ *
7
+ * Supported Record Types:
8
+ * - A record (IPv4 addresses)
9
+ * - AAAA record (IPv6 addresses)
10
+ * - CNAME record
11
+ * - MX record
12
+ * - PTR record
13
+ * - SRV record
14
+ * - TXT record
15
+ * - (SOA is managed by Azure automatically)
16
+ *
17
+ * Run with: npm run integration:nostream
18
+ */
19
+ import "cdktf/lib/testing/adapters/jest";
@@ -0,0 +1,245 @@
1
+ "use strict";
2
+ /**
3
+ * Integration test for Azure Private DNS Zone Records
4
+ *
5
+ * This test demonstrates usage of all Private DNS record types
6
+ * and validates deployment, idempotency, and cleanup for child resources.
7
+ *
8
+ * Supported Record Types:
9
+ * - A record (IPv4 addresses)
10
+ * - AAAA record (IPv6 addresses)
11
+ * - CNAME record
12
+ * - MX record
13
+ * - PTR record
14
+ * - SRV record
15
+ * - TXT record
16
+ * - (SOA is managed by Azure automatically)
17
+ *
18
+ * Run with: npm run integration:nostream
19
+ */
20
+ Object.defineProperty(exports, "__esModule", { value: true });
21
+ const cdktf_1 = require("cdktf");
22
+ require("cdktf/lib/testing/adapters/jest");
23
+ const resource_group_1 = require("../../azure-resourcegroup/lib/resource-group");
24
+ const provider_1 = require("../../core-azure/lib/azapi/providers-azapi/provider");
25
+ const testing_1 = require("../../testing");
26
+ const metadata_1 = require("../../testing/lib/metadata");
27
+ const private_dns_zone_1 = require("../lib/private-dns-zone");
28
+ const records_1 = require("../lib/records");
29
+ // Generate unique test run metadata for this test suite
30
+ const testMetadata = new metadata_1.TestRunMetadata("privatednsrec-integration", {
31
+ maxAgeHours: 4,
32
+ });
33
+ /**
34
+ * Example stack demonstrating Private DNS Records usage
35
+ *
36
+ * Creates a Private DNS Zone and various record types within it.
37
+ */
38
+ class PrivateDnsRecordsExampleStack extends testing_1.BaseTestStack {
39
+ constructor(scope, id) {
40
+ super(scope, id, {
41
+ testRunOptions: {
42
+ maxAgeHours: testMetadata.maxAgeHours,
43
+ autoCleanup: testMetadata.autoCleanup,
44
+ cleanupPolicy: testMetadata.cleanupPolicy,
45
+ },
46
+ });
47
+ // Configure AZAPI provider
48
+ new provider_1.AzapiProvider(this, "azapi", {});
49
+ // Generate unique names
50
+ const resourceGroupName = this.generateResourceName("Microsoft.Resources/resourceGroups", "privatednsrec");
51
+ // Create resource group for the Private DNS zone and records
52
+ const resourceGroup = new resource_group_1.ResourceGroup(this, "test-rg", {
53
+ name: resourceGroupName,
54
+ location: "eastus2",
55
+ tags: {
56
+ ...this.systemTags(),
57
+ purpose: "private-dns-records-testing",
58
+ },
59
+ });
60
+ // Create Private DNS Zone - using a unique zone name
61
+ const zoneName = this.generateResourceName("Microsoft.Network/privateDnsZones", "rec");
62
+ const zone = new private_dns_zone_1.PrivateDnsZone(this, "private-dns-zone", {
63
+ name: `${zoneName}.internal`,
64
+ location: "global",
65
+ resourceGroupId: resourceGroup.id,
66
+ tags: {
67
+ ...this.systemTags(),
68
+ purpose: "dns-records-testing",
69
+ },
70
+ });
71
+ // =========================================================================
72
+ // A Record - Single IP
73
+ // =========================================================================
74
+ new records_1.PrivateDnsARecord(this, "a-record-single", {
75
+ name: "web",
76
+ privateDnsZoneId: zone.id,
77
+ ttl: 300,
78
+ records: [{ ipv4Address: "10.0.1.4" }],
79
+ metadata: {
80
+ purpose: "web-server",
81
+ },
82
+ });
83
+ // =========================================================================
84
+ // A Record - Multiple IPs (load balancing)
85
+ // =========================================================================
86
+ new records_1.PrivateDnsARecord(this, "a-record-multi", {
87
+ name: "api",
88
+ privateDnsZoneId: zone.id,
89
+ ttl: 300,
90
+ records: [
91
+ { ipv4Address: "10.0.1.10" },
92
+ { ipv4Address: "10.0.1.11" },
93
+ { ipv4Address: "10.0.1.12" },
94
+ ],
95
+ metadata: {
96
+ purpose: "api-servers-loadbalanced",
97
+ },
98
+ });
99
+ // =========================================================================
100
+ // AAAA Record - IPv6 addresses
101
+ // =========================================================================
102
+ new records_1.PrivateDnsAaaaRecord(this, "aaaa-record", {
103
+ name: "ipv6host",
104
+ privateDnsZoneId: zone.id,
105
+ ttl: 300,
106
+ records: [{ ipv6Address: "2001:db8::1" }, { ipv6Address: "2001:db8::2" }],
107
+ metadata: {
108
+ purpose: "ipv6-servers",
109
+ },
110
+ });
111
+ // =========================================================================
112
+ // CNAME Record - Alias
113
+ // =========================================================================
114
+ new records_1.PrivateDnsCnameRecord(this, "cname-record", {
115
+ name: "www",
116
+ privateDnsZoneId: zone.id,
117
+ ttl: 3600,
118
+ cname: `web.${zoneName}.internal`,
119
+ metadata: {
120
+ purpose: "alias-to-web",
121
+ },
122
+ });
123
+ // =========================================================================
124
+ // MX Record - Mail exchange servers
125
+ // =========================================================================
126
+ new records_1.PrivateDnsMxRecord(this, "mx-record", {
127
+ name: "@",
128
+ privateDnsZoneId: zone.id,
129
+ ttl: 3600,
130
+ records: [
131
+ { preference: 10, exchange: `mail1.${zoneName}.internal` },
132
+ { preference: 20, exchange: `mail2.${zoneName}.internal` },
133
+ ],
134
+ metadata: {
135
+ purpose: "mail-servers",
136
+ },
137
+ });
138
+ // =========================================================================
139
+ // PTR Record - Reverse DNS
140
+ // Note: In practice, PTR records are created in reverse DNS zones
141
+ // (e.g., 1.0.10.in-addr.arpa), but for this test we demonstrate
142
+ // the record creation in a forward zone
143
+ // =========================================================================
144
+ new records_1.PrivateDnsPtrRecord(this, "ptr-record", {
145
+ name: "ptr",
146
+ privateDnsZoneId: zone.id,
147
+ ttl: 3600,
148
+ records: [{ ptrdname: `server1.${zoneName}.internal` }],
149
+ metadata: {
150
+ purpose: "reverse-dns-lookup",
151
+ },
152
+ });
153
+ // =========================================================================
154
+ // SRV Record - Service location
155
+ // Format: _service._protocol (e.g., _sip._tcp)
156
+ // =========================================================================
157
+ new records_1.PrivateDnsSrvRecord(this, "srv-record", {
158
+ name: "_sip._tcp",
159
+ privateDnsZoneId: zone.id,
160
+ ttl: 3600,
161
+ records: [
162
+ {
163
+ priority: 10,
164
+ weight: 60,
165
+ port: 5060,
166
+ target: `sipserver1.${zoneName}.internal`,
167
+ },
168
+ {
169
+ priority: 10,
170
+ weight: 40,
171
+ port: 5060,
172
+ target: `sipserver2.${zoneName}.internal`,
173
+ },
174
+ {
175
+ priority: 20,
176
+ weight: 100,
177
+ port: 5060,
178
+ target: `sipserver-backup.${zoneName}.internal`,
179
+ },
180
+ ],
181
+ metadata: {
182
+ purpose: "sip-service-discovery",
183
+ },
184
+ });
185
+ // =========================================================================
186
+ // TXT Record - SPF record
187
+ // =========================================================================
188
+ new records_1.PrivateDnsTxtRecord(this, "txt-record-spf", {
189
+ name: "@",
190
+ privateDnsZoneId: zone.id,
191
+ ttl: 3600,
192
+ records: [{ value: ["v=spf1 include:_spf.internal.example.com ~all"] }],
193
+ metadata: {
194
+ purpose: "spf-record",
195
+ },
196
+ });
197
+ // =========================================================================
198
+ // TXT Record - Domain verification
199
+ // =========================================================================
200
+ new records_1.PrivateDnsTxtRecord(this, "txt-record-verification", {
201
+ name: "_verify",
202
+ privateDnsZoneId: zone.id,
203
+ ttl: 3600,
204
+ records: [
205
+ { value: ["verification-token=abc123def456"] },
206
+ { value: ["another-verification=xyz789"] },
207
+ ],
208
+ metadata: {
209
+ purpose: "domain-verification",
210
+ },
211
+ });
212
+ // =========================================================================
213
+ // Additional SRV Record - LDAP service
214
+ // =========================================================================
215
+ new records_1.PrivateDnsSrvRecord(this, "srv-record-ldap", {
216
+ name: "_ldap._tcp",
217
+ privateDnsZoneId: zone.id,
218
+ ttl: 3600,
219
+ records: [
220
+ {
221
+ priority: 0,
222
+ weight: 100,
223
+ port: 389,
224
+ target: `ldap.${zoneName}.internal`,
225
+ },
226
+ ],
227
+ metadata: {
228
+ purpose: "ldap-service-discovery",
229
+ },
230
+ });
231
+ }
232
+ }
233
+ describe("PrivateDnsRecords Integration Test", () => {
234
+ it("should deploy, validate idempotency, and cleanup resources", () => {
235
+ const app = cdktf_1.Testing.app();
236
+ const stack = new PrivateDnsRecordsExampleStack(app, "test-privatednsrecords");
237
+ const synthesized = cdktf_1.Testing.fullSynth(stack);
238
+ // This will:
239
+ // 1. Run terraform apply to deploy resources (including parent-child relationships)
240
+ // 2. Run terraform plan to check idempotency (no changes expected)
241
+ // 3. Run terraform destroy to cleanup resources (child resources cleanup before parent)
242
+ (0, testing_1.TerraformApplyCheckAndDestroy)(synthesized, { verifyCleanup: true });
243
+ }, 600000); // 10 minute timeout for deployment and cleanup
244
+ });
245
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJpdmF0ZS1kbnMtcmVjb3Jkcy5pbnRlZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9henVyZS1wcml2YXRlZG5zem9uZS90ZXN0L3ByaXZhdGUtZG5zLXJlY29yZHMuaW50ZWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7Ozs7Ozs7OztHQWlCRzs7QUFFSCxpQ0FBZ0M7QUFFaEMsMkNBQXlDO0FBQ3pDLGlGQUE2RTtBQUM3RSxrRkFBb0Y7QUFDcEYsMkNBQTZFO0FBQzdFLHlEQUE2RDtBQUM3RCw4REFBeUQ7QUFDekQsNENBUXdCO0FBRXhCLHdEQUF3RDtBQUN4RCxNQUFNLFlBQVksR0FBRyxJQUFJLDBCQUFlLENBQUMsMkJBQTJCLEVBQUU7SUFDcEUsV0FBVyxFQUFFLENBQUM7Q0FDZixDQUFDLENBQUM7QUFFSDs7OztHQUlHO0FBQ0gsTUFBTSw2QkFBOEIsU0FBUSx1QkFBYTtJQUN2RCxZQUFZLEtBQWdCLEVBQUUsRUFBVTtRQUN0QyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRTtZQUNmLGNBQWMsRUFBRTtnQkFDZCxXQUFXLEVBQUUsWUFBWSxDQUFDLFdBQVc7Z0JBQ3JDLFdBQVcsRUFBRSxZQUFZLENBQUMsV0FBVztnQkFDckMsYUFBYSxFQUFFLFlBQVksQ0FBQyxhQUFhO2FBQzFDO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsMkJBQTJCO1FBQzNCLElBQUksd0JBQWEsQ0FBQyxJQUFJLEVBQUUsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRXJDLHdCQUF3QjtRQUN4QixNQUFNLGlCQUFpQixHQUFHLElBQUksQ0FBQyxvQkFBb0IsQ0FDakQsb0NBQW9DLEVBQ3BDLGVBQWUsQ0FDaEIsQ0FBQztRQUVGLDZEQUE2RDtRQUM3RCxNQUFNLGFBQWEsR0FBRyxJQUFJLDhCQUFhLENBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRTtZQUN2RCxJQUFJLEVBQUUsaUJBQWlCO1lBQ3ZCLFFBQVEsRUFB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QU0sRUFBRSxHQUFHO29CQUNYLElBQUksRUFBRSxHQUFHO29CQUNULE1BQU0sRUFBRSxRQUFRLFFBQVEsV0FBVztpQkFDcEM7YUFDRjtZQUNELFFBQVEsRUFBRTtnQkFDUixPQUFPLEVBQUUsd0JBQXdCO2FBQ2xDO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBRUQsUUFBUSxDQUFDLG9DQUFvQyxFQUFFLEdBQUcsRUFBRTtJQUNsRCxFQUFFLENBQUMsNERBQTRELEVBQUUsR0FBRyxFQUFFO1FBQ3BFLE1BQU0sR0FBRyxHQUFHLGVBQU8sQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUMxQixNQUFNLEtBQUssR0FBRyxJQUFJLDZCQUE2QixDQUM3QyxHQUFHLEVBQ0gsd0JBQXdCLENBQ3pCLENBQUM7UUFDRixNQUFNLFdBQVcsR0FBRyxlQUFPLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRTdDLGFBQWE7UUFDYixvRkFBb0Y7UUFDcEYsbUVBQW1FO1FBQ25FLHdGQUF3RjtRQUN4RixJQUFBLHVDQUE2QixFQUFDLFdBQVcsRUFBRSxFQUFFLGFBQWEsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ3RFLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLCtDQUErQztBQUM3RCxDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogSW50ZWdyYXRpb24gdGVzdCBmb3IgQXp1cmUgUHJpdmF0ZSBETlMgWm9uZSBSZWNvcmRzXG4gKlxuICogVGhpcyB0ZXN0IGRlbW9uc3RyYXRlcyB1c2FnZSBvZiBhbGwgUHJpdmF0ZSBETlMgcmVjb3JkIHR5cGVzXG4gKiBhbmQgdmFsaWRhdGVzIGRlcGxveW1lbnQsIGlkZW1wb3RlbmN5LCBhbmQgY2xlYW51cCBmb3IgY2hpbGQgcmVzb3VyY2VzLlxuICpcbiAqIFN1cHBvcnRlZCBSZWNvcmQgVHlwZXM6XG4gKiAtIEEgcmVjb3JkIChJUHY0IGFkZHJlc3NlcylcbiAqIC0gQUFBQSByZWNvcmQgKElQdjYgYWRkcmVzc2VzKVxuICogLSBDTkFNRSByZWNvcmRcbiAqIC0gTVggcmVjb3JkXG4gKiAtIFBUUiByZWNvcmRcbiAqIC0gU1JWIHJlY29yZFxuICogLSBUWFQgcmVjb3JkXG4gKiAtIChTT0EgaXMgbWFuYWdlZCBieSBBenVyZSBhdXRvbWF0aWNhbGx5KVxuICpcbiAqIFJ1biB3aXRoOiBucG0gcnVuIGludGVncmF0aW9uOm5vc3RyZWFtXG4gKi9cblxuaW1wb3J0IHsgVGVzdGluZyB9IGZyb20gXCJjZGt0ZlwiO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcbmltcG9ydCBcImNka3RmL2xpYi90ZXN0aW5nL2FkYXB0ZXJzL2plc3RcIjtcbmltcG9ydCB7IFJlc291cmNlR3JvdXAgfSBmcm9tIFwiLi4vLi4vYXp1cmUtcmVzb3VyY2Vncm91cC9saWIvcmVzb3VyY2UtZ3JvdXBcIjtcbmltcG9ydCB7IEF6YXBpUHJvdmlkZXIgfSBmcm9tIFwiLi4vLi4vY29yZS1henVyZS9saWIvYXphcGkvcHJvdmlkZXJzLWF6YXBpL3Byb3ZpZGVyXCI7XG5pbXBvcnQgeyBCYXNlVGVzdFN0YWNrLCBUZXJyYWZvcm1BcHBseUNoZWNrQW5kRGVzdHJveSB9IGZyb20gXCIuLi8uLi90ZXN0aW5nXCI7XG5pbXBvcnQgeyBUZXN0UnVuTWV0YWRhdGEgfSBmcm9tIFwiLi4vLi4vdGVzdGluZy9saWIvbWV0YWRhdGFcIjtcbmltcG9ydCB7IFByaXZhdGVEbnNab25lIH0gZnJvbSBcIi4uL2xpYi9wcml2YXRlLWRucy16b25lXCI7XG5pbXBvcnQge1xuICBQcml2YXRlRG5zQVJlY29yZCxcbiAgUHJpdmF0ZURuc0FhYWFSZWNvcmQsXG4gIFByaXZhdGVEbnNDbmFtZVJlY29yZCxcbiAgUHJpdmF0ZURuc014UmVjb3JkLFxuICBQcml2YXRlRG5zUHRyUmVjb3JkLFxuICBQcml2YXRlRG5zU3J2UmVjb3JkLFxuICBQcml2YXRlRG5zVHh0UmVjb3JkLFxufSBmcm9tIFwiLi4vbGliL3JlY29yZHNcIjtcblxuLy8gR2VuZXJhdGUgdW5pcXVlIHRlc3QgcnVuIG1ldGFkYXRhIGZvciB0aGlzIHRlc3Qgc3VpdGVcbmNvbnN0IHRlc3RNZXRhZGF0YSA9IG5ldyBUZXN0UnVuTWV0YWRhdGEoXCJwcml2YXRlZG5zcmVjLWludGVncmF0aW9uXCIsIHtcbiAgbWF4QWdlSG91cnM6IDQsXG59KTtcblxuLyoqXG4gKiBFeGFtcGxlIHN0YWNrIGRlbW9uc3RyYXRpbmcgUHJpdmF0ZSBETlMgUmVjb3JkcyB1c2FnZVxuICpcbiAqIENyZWF0ZXMgYSBQcml2YXRlIEROUyBab25lIGFuZCB2YXJpb3VzIHJlY29yZCB0eXBlcyB3aXRoaW4gaXQuXG4gKi9cbmNsYXNzIFByaXZhdGVEbnNSZWNvcmRzRXhhbXBsZVN0YWNrIGV4dGVuZHMgQmFzZVRlc3RTdGFjayB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcpIHtcbiAgICBzdXBlcihzY29wZSwgaWQsIHtcbiAgICAgIHRlc3RSdW5PcHRpb25zOiB7XG4gICAgICAgIG1heEFnZUhvdXJzOiB0ZXN0TWV0YWRhdGEubWF4QWdlSG91cnMsXG4gICAgICAgIGF1dG9DbGVhbnVwOiB0ZXN0TWV0YWRhdGEuYXV0b0NsZWFudXAsXG4gICAgICAgIGNsZWFudXBQb2xpY3k6IHRlc3RNZXRhZGF0YS5jbGVhbnVwUG9saWN5LFxuICAgICAgfSxcbiAgICB9KTtcblxuICAgIC8vIENvbmZpZ3VyZSBBWkFQSSBwcm92aWRlclxuICAgIG5ldyBBemFwaVByb3ZpZGVyKHRoaXMsIFwiYXphcGlcIiwge30pO1xuXG4gICAgLy8gR2VuZXJhdGUgdW5pcXVlIG5hbWVzXG4gICAgY29uc3QgcmVzb3VyY2VHcm91cE5hbWUgPSB0aGlzLmdlbmVyYXRlUmVzb3VyY2VOYW1lKFxuICAgICAgXCJNaWNyb3NvZnQuUmVzb3VyY2VzL3Jlc291cmNlR3JvdXBzXCIsXG4gICAgICBcInByaXZhdGVkbnNyZWNcIixcbiAgICApO1xuXG4gICAgLy8gQ3JlYXRlIHJlc291cmNlIGdyb3VwIGZvciB0aGUgUHJpdmF0ZSBETlMgem9uZSBhbmQgcmVjb3Jkc1xuICAgIGNvbnN0IHJlc291cmNlR3JvdXAgPSBuZXcgUmVzb3VyY2VHcm91cCh0aGlzLCBcInRlc3QtcmdcIiwge1xuICAgICAgbmFtZTogcmVzb3VyY2VHcm91cE5hbWUsXG4gICAgICBsb2NhdGlvbjogXCJlYXN0dXMyXCIsXG4gICAgICB0YWdzOiB7XG4gICAgICAgIC4uLnRoaXMuc3lzdGVtVGFncygpLFxuICAgICAgICBwdXJwb3NlOiBcInByaXZhdGUtZG5zLXJlY29yZHMtdGVzdGluZ1wiLFxuICAgICAgfSxcbiAgICB9KTtcblxuICAgIC8vIENyZWF0ZSBQcml2YXRlIEROUyBab25lIC0gdXNpbmcgYSB1bmlxdWUgem9uZSBuYW1lXG4gICAgY29uc3Qgem9uZU5hbWUgPSB0aGlzLmdlbmVyYXRlUmVzb3VyY2VOYW1lKFxuICAgICAgXCJNaWNyb3NvZnQuTmV0d29yay9wcml2YXRlRG5zWm9uZXNcIixcbiAgICAgIFwicmVjXCIsXG4gICAgKTtcbiAgICBjb25zdCB6b25lID0gbmV3IFByaXZhdGVEbnNab25lKHRoaXMsIFwicHJpdmF0ZS1kbnMtem9uZVwiLCB7XG4gICAgICBuYW1lOiBgJHt6b25lTmFtZX0uaW50ZXJuYWxgLFxuICAgICAgbG9jYXRpb246IFwiZ2xvYmFsXCIsXG4gICAgICByZXNvdXJjZUdyb3VwSWQ6IHJlc291cmNlR3JvdXAuaWQsXG4gICAgICB0YWdzOiB7XG4gICAgICAgIC4uLnRoaXMuc3lzdGVtVGFncygpLFxuICAgICAgICBwdXJwb3NlOiBcImRucy1yZWNvcmRzLXRlc3RpbmdcIixcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICAvLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4gICAgLy8gQSBSZWNvcmQgLSBTaW5nbGUgSVBcbiAgICAvLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4gICAgbmV3IFByaXZhdGVEbnNBUmVjb3JkKHRoaXMsIFwiYS1yZWNvcmQtc2luZ2xlXCIsIHtcbiAgICAgIG5hbWU6IFwid2ViXCIsXG4gICAgICBwcml2YXRlRG5zWm9uZUlkOiB6b25lLmlkLFxuICAgICAgdHRsOiAzMDAsXG4gICAgICByZWNvcmRzOiBbeyBpcHY0QWRkcmVzczogXCIxMC4wLjEuNFwiIH1dLFxuICAgICAgbWV0YWRhdGE6IHtcbiAgICAgICAgcHVycG9zZTogXCJ3ZWItc2VydmVyXCIsXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuICAgIC8vIEEgUmVjb3JkIC0gTXVsdGlwbGUgSVBzIChsb2FkIGJhbGFuY2luZylcbiAgICAvLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4gICAgbmV3IFByaXZhdGVEbnNBUmVjb3JkKHRoaXMsIFwiYS1yZWNvcmQtbXVsdGlcIiwge1xuICAgICAgbmFtZTogXCJhcGlcIixcbiAgICAgIHByaXZhdGVEbnNab25lSWQ6IHpvbmUuaWQsXG4gICAgICB0dGw6IDMwMCxcbiAgICAgIHJlY29yZHM6IFtcbiAgICAgICAgeyBpcHY0QWRkcmVzczogXCIxMC4wLjEuMTBcIiB9LFxuICAgICAgICB7IGlwdjRBZGRyZXNzOiBcIjEwLjAuMS4xMVwiIH0sXG4gICAgICAgIHsgaXB2NEFkZHJlc3M6IFwiMTAuMC4xLjEyXCIgfSxcbiAgICAgIF0sXG4gICAgICBtZXRhZGF0YToge1xuICAgICAgICBwdXJwb3NlOiBcImFwaS1zZXJ2ZXJzLWxvYWRiYWxhbmNlZFwiLFxuICAgICAgfSxcbiAgICB9KTtcblxuICAgIC8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbiAgICAvLyBBQUFBIFJlY29yZCAtIElQdjYgYWRkcmVzc2VzXG4gICAgLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuICAgIG5ldyBQcml2YXRlRG5zQWFhYVJlY29yZCh0aGlzLCBcImFhYWEtcmVjb3JkXCIsIHtcbiAgICAgIG5hbWU6IFwiaXB2Nmhvc3RcIixcbiAgICAgIHByaXZhdGVEbnNab25lSWQ6IHpvbmUuaWQsXG4gICAgICB0dGw6IDMwMCxcbiAgICAgIHJlY29yZHM6IFt7IGlwdjZBZGRyZXNzOiBcIjIwMDE6ZGI4OjoxXCIgfSwgeyBpcHY2QWRkcmVzczogXCIyMDAxOmRiODo6MlwiIH1dLFxuICAgICAgbWV0YWRhdGE6IHtcbiAgICAgICAgcHVycG9zZTogXCJpcHY2LXNlcnZlcnNcIixcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICAvLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4gICAgLy8gQ05BTUUgUmVjb3JkIC0gQWxpYXNcbiAgICAvLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4gICAgbmV3IFByaXZhdGVEbnNDbmFtZVJlY29yZCh0aGlzLCBcImNuYW1lLXJlY29yZFwiLCB7XG4gICAgICBuYW1lOiBcInd3d1wiLFxuICAgICAgcHJpdmF0ZURuc1pvbmVJZDogem9uZS5pZCxcbiAgICAgIHR0bDogMzYwMCxcbiAgICAgIGNuYW1lOiBgd2ViLiR7em9uZU5hbWV9LmludGVybmFsYCxcbiAgICAgIG1ldGFkYXRhOiB7XG4gICAgICAgIHB1cnBvc2U6IFwiYWxpYXMtdG8td2ViXCIsXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuICAgIC8vIE1YIFJlY29yZCAtIE1haWwgZXhjaGFuZ2Ugc2VydmVyc1xuICAgIC8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbiAgICBuZXcgUHJpdmF0ZURuc014UmVjb3JkKHRoaXMsIFwibXgtcmVjb3JkXCIsIHtcbiAgICAgIG5hbWU6IFwiQFwiLFxuICAgICAgcHJpdmF0ZURuc1pvbmVJZDogem9uZS5pZCxcbiAgICAgIHR0bDogMzYwMCxcbiAgICAgIHJlY29yZHM6IFtcbiAgICAgICAgeyBwcmVmZXJlbmNlOiAxMCwgZXhjaGFuZ2U6IGBtYWlsMS4ke3pvbmVOYW1lfS5pbnRlcm5hbGAgfSxcbiAgICAgICAgeyBwcmVmZXJlbmNlOiAyMCwgZXhjaGFuZ2U6IGBtYWlsMi4ke3pvbmVOYW1lfS5pbnRlcm5hbGAgfSxcbiAgICAgIF0sXG4gICAgICBtZXRhZGF0YToge1xuICAgICAgICBwdXJwb3NlOiBcIm1haWwtc2VydmVyc1wiLFxuICAgICAgfSxcbiAgICB9KTtcblxuICAgIC8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbiAgICAvLyBQVFIgUmVjb3JkIC0gUmV2ZXJzZSBETlNcbiAgICAvLyBOb3RlOiBJbiBwcmFjdGljZSwgUFRSIHJlY29yZHMgYXJlIGNyZWF0ZWQgaW4gcmV2ZXJzZSBETlMgem9uZXNcbiAgICAvLyAoZS5nLiwgMS4wLjEwLmluLWFkZHIuYXJwYSksIGJ1dCBmb3IgdGhpcyB0ZXN0IHdlIGRlbW9uc3RyYXRlXG4gICAgLy8gdGhlIHJlY29yZCBjcmVhdGlvbiBpbiBhIGZvcndhcmQgem9uZVxuICAgIC8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbiAgICBuZXcgUHJpdmF0ZURuc1B0clJlY29yZCh0aGlzLCBcInB0ci1yZWNvcmRcIiwge1xuICAgICAgbmFtZTogXCJwdHJcIixcbiAgICAgIHByaXZhdGVEbnNab25lSWQ6IHpvbmUuaWQsXG4gICAgICB0dGw6IDM2MDAsXG4gICAgICByZWNvcmRzOiBbeyBwdHJkbmFtZTogYHNlcnZlcjEuJHt6b25lTmFtZX0uaW50ZXJuYWxgIH1dLFxuICAgICAgbWV0YWRhdGE6IHtcbiAgICAgICAgcHVycG9zZTogXCJyZXZlcnNlLWRucy1sb29rdXBcIixcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICAvLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4gICAgLy8gU1JWIFJlY29yZCAtIFNlcnZpY2UgbG9jYXRpb25cbiAgICAvLyBGb3JtYXQ6IF9zZXJ2aWNlLl9wcm90b2NvbCAoZS5nLiwgX3NpcC5fdGNwKVxuICAgIC8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbiAgICBuZXcgUHJpdmF0ZURuc1NydlJlY29yZCh0aGlzLCBcInNydi1yZWNvcmRcIiwge1xuICAgICAgbmFtZTogXCJfc2lwLl90Y3BcIixcbiAgICAgIHByaXZhdGVEbnNab25lSWQ6IHpvbmUuaWQsXG4gICAgICB0dGw6IDM2MDAsXG4gICAgICByZWNvcmRzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICBwcmlvcml0eTogMTAsXG4gICAgICAgICAgd2VpZ2h0OiA2MCxcbiAgICAgICAgICBwb3J0OiA1MDYwLFxuICAgICAgICAgIHRhcmdldDogYHNpcHNlcnZlcjEuJHt6b25lTmFtZX0uaW50ZXJuYWxgLFxuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgcHJpb3JpdHk6IDEwLFxuICAgICAgICAgIHdlaWdodDogNDAsXG4gICAgICAgICAgcG9ydDogNTA2MCxcbiAgICAgICAgICB0YXJnZXQ6IGBzaXBzZXJ2ZXIyLiR7em9uZU5hbWV9LmludGVybmFsYCxcbiAgICAgICAgfSxcbiAgICAgICAge1xuICAgICAgICAgIHByaW9yaXR5OiAyMCxcbiAgICAgICAgICB3ZWlnaHQ6IDEwMCxcbiAgICAgICAgICBwb3J0OiA1MDYwLFxuICAgICAgICAgIHRhcmdldDogYHNpcHNlcnZlci1iYWNrdXAuJHt6b25lTmFtZX0uaW50ZXJuYWxgLFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICAgIG1ldGFkYXRhOiB7XG4gICAgICAgIHB1cnBvc2U6IFwic2lwLXNlcnZpY2UtZGlzY292ZXJ5XCIsXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuICAgIC8vIFRYVCBSZWNvcmQgLSBTUEYgcmVjb3JkXG4gICAgLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuICAgIG5ldyBQcml2YXRlRG5zVHh0UmVjb3JkKHRoaXMsIFwidHh0LXJlY29yZC1zcGZcIiwge1xuICAgICAgbmFtZTogXCJAXCIsXG4gICAgICBwcml2YXRlRG5zWm9uZUlkOiB6b25lLmlkLFxuICAgICAgdHRsOiAzNjAwLFxuICAgICAgcmVjb3JkczogW3sgdmFsdWU6IFtcInY9c3BmMSBpbmNsdWRlOl9zcGYuaW50ZXJuYWwuZXhhbXBsZS5jb20gfmFsbFwiXSB9XSxcbiAgICAgIG1ldGFkYXRhOiB7XG4gICAgICAgIHB1cnBvc2U6IFwic3BmLXJlY29yZFwiLFxuICAgICAgfSxcbiAgICB9KTtcblxuICAgIC8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbiAgICAvLyBUWFQgUmVjb3JkIC0gRG9tYWluIHZlcmlmaWNhdGlvblxuICAgIC8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbiAgICBuZXcgUHJpdmF0ZURuc1R4dFJlY29yZCh0aGlzLCBcInR4dC1yZWNvcmQtdmVyaWZpY2F0aW9uXCIsIHtcbiAgICAgIG5hbWU6IFwiX3ZlcmlmeVwiLFxuICAgICAgcHJpdmF0ZURuc1pvbmVJZDogem9uZS5pZCxcbiAgICAgIHR0bDogMzYwMCxcbiAgICAgIHJlY29yZHM6IFtcbiAgICAgICAgeyB2YWx1ZTogW1widmVyaWZpY2F0aW9uLXRva2VuPWFiYzEyM2RlZjQ1NlwiXSB9LFxuICAgICAgICB7IHZhbHVlOiBbXCJhbm90aGVyLXZlcmlmaWNhdGlvbj14eXo3ODlcIl0gfSxcbiAgICAgIF0sXG4gICAgICBtZXRhZGF0YToge1xuICAgICAgICBwdXJwb3NlOiBcImRvbWFpbi12ZXJpZmljYXRpb25cIixcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICAvLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4gICAgLy8gQWRkaXRpb25hbCBTUlYgUmVjb3JkIC0gTERBUCBzZXJ2aWNlXG4gICAgLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuICAgIG5ldyBQcml2YXRlRG5zU3J2UmVjb3JkKHRoaXMsIFwic3J2LXJlY29yZC1sZGFwXCIsIHtcbiAgICAgIG5hbWU6IFwiX2xkYXAuX3RjcFwiLFxuICAgICAgcHJpdmF0ZURuc1pvbmVJZDogem9uZS5pZCxcbiAgICAgIHR0bDogMzYwMCxcbiAgICAgIHJlY29yZHM6IFtcbiAgICAgICAge1xuICAgICAgICAgIHByaW9yaXR5OiAwLFxuICAgICAgICAgIHdlaWdodDogMTAwLFxuICAgICAgICAgIHBvcnQ6IDM4OSxcbiAgICAgICAgICB0YXJnZXQ6IGBsZGFwLiR7em9uZU5hbWV9LmludGVybmFsYCxcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgICBtZXRhZGF0YToge1xuICAgICAgICBwdXJwb3NlOiBcImxkYXAtc2VydmljZS1kaXNjb3ZlcnlcIixcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cbn1cblxuZGVzY3JpYmUoXCJQcml2YXRlRG5zUmVjb3JkcyBJbnRlZ3JhdGlvbiBUZXN0XCIsICgpID0+IHtcbiAgaXQoXCJzaG91bGQgZGVwbG95LCB2YWxpZGF0ZSBpZGVtcG90ZW5jeSwgYW5kIGNsZWFudXAgcmVzb3VyY2VzXCIsICgpID0+IHtcbiAgICBjb25zdCBhcHAgPSBUZXN0aW5nLmFwcCgpO1xuICAgIGNvbnN0IHN0YWNrID0gbmV3IFByaXZhdGVEbnNSZWNvcmRzRXhhbXBsZVN0YWNrKFxuICAgICAgYXBwLFxuICAgICAgXCJ0ZXN0LXByaXZhdGVkbnNyZWNvcmRzXCIsXG4gICAgKTtcbiAgICBjb25zdCBzeW50aGVzaXplZCA9IFRlc3RpbmcuZnVsbFN5bnRoKHN0YWNrKTtcblxuICAgIC8vIFRoaXMgd2lsbDpcbiAgICAvLyAxLiBSdW4gdGVycmFmb3JtIGFwcGx5IHRvIGRlcGxveSByZXNvdXJjZXMgKGluY2x1ZGluZyBwYXJlbnQtY2hpbGQgcmVsYXRpb25zaGlwcylcbiAgICAvLyAyLiBSdW4gdGVycmFmb3JtIHBsYW4gdG8gY2hlY2sgaWRlbXBvdGVuY3kgKG5vIGNoYW5nZXMgZXhwZWN0ZWQpXG4gICAgLy8gMy4gUnVuIHRlcnJhZm9ybSBkZXN0cm95IHRvIGNsZWFudXAgcmVzb3VyY2VzIChjaGlsZCByZXNvdXJjZXMgY2xlYW51cCBiZWZvcmUgcGFyZW50KVxuICAgIFRlcnJhZm9ybUFwcGx5Q2hlY2tBbmREZXN0cm95KHN5bnRoZXNpemVkLCB7IHZlcmlmeUNsZWFudXA6IHRydWUgfSk7XG4gIH0sIDYwMDAwMCk7IC8vIDEwIG1pbnV0ZSB0aW1lb3V0IGZvciBkZXBsb3ltZW50IGFuZCBjbGVhbnVwXG59KTtcbiJdfQ==
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Unit tests for Azure Private DNS Zone Record implementations
3
+ *
4
+ * This test suite validates all 8 Private DNS record types:
5
+ * - PrivateDnsARecord
6
+ * - PrivateDnsAaaaRecord
7
+ * - PrivateDnsCnameRecord
8
+ * - PrivateDnsMxRecord
9
+ * - PrivateDnsPtrRecord
10
+ * - PrivateDnsSoaRecord
11
+ * - PrivateDnsSrvRecord
12
+ * - PrivateDnsTxtRecord
13
+ *
14
+ * Tests verify basic creation, correct resource types, API versions,
15
+ * parent ID resolution, resource body structure, TTL handling,
16
+ * record-specific properties, and metadata handling.
17
+ */
18
+ export {};