@microsoft/terraform-cdk-constructs 1.2.0 → 1.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (291) hide show
  1. package/.jsii +54630 -26185
  2. package/API.md +72091 -23784
  3. package/lib/azure-actiongroup/index.d.ts +0 -10
  4. package/lib/azure-actiongroup/index.js +1 -11
  5. package/lib/azure-actiongroup/lib/action-group.d.ts +0 -10
  6. package/lib/azure-actiongroup/lib/action-group.js +6 -32
  7. package/lib/azure-actiongroup/lib/index.d.ts +1 -4
  8. package/lib/azure-actiongroup/lib/index.js +2 -5
  9. package/lib/azure-activitylogalert/index.d.ts +0 -10
  10. package/lib/azure-activitylogalert/index.js +1 -11
  11. package/lib/azure-activitylogalert/lib/activity-log-alert.d.ts +0 -10
  12. package/lib/azure-activitylogalert/lib/activity-log-alert.js +6 -32
  13. package/lib/azure-activitylogalert/lib/index.d.ts +1 -4
  14. package/lib/azure-activitylogalert/lib/index.js +2 -5
  15. package/lib/azure-aks/index.d.ts +0 -8
  16. package/lib/azure-aks/index.js +1 -11
  17. package/lib/azure-aks/lib/aks-cluster.d.ts +4 -13
  18. package/lib/azure-aks/lib/aks-cluster.js +13 -36
  19. package/lib/azure-aks/lib/index.d.ts +1 -10
  20. package/lib/azure-aks/lib/index.js +2 -21
  21. package/lib/azure-diagnosticsettings/index.d.ts +0 -6
  22. package/lib/azure-diagnosticsettings/index.js +1 -7
  23. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.d.ts +0 -10
  24. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +6 -32
  25. package/lib/azure-diagnosticsettings/lib/index.d.ts +1 -7
  26. package/lib/azure-diagnosticsettings/lib/index.js +2 -8
  27. package/lib/azure-dnsforwardingruleset/index.d.ts +1 -0
  28. package/lib/azure-dnsforwardingruleset/index.js +18 -0
  29. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset-schemas.d.ts +24 -0
  30. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset-schemas.js +206 -0
  31. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.d.ts +174 -0
  32. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +214 -0
  33. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule-schemas.d.ts +24 -0
  34. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule-schemas.js +242 -0
  35. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.d.ts +193 -0
  36. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +193 -0
  37. package/lib/azure-dnsforwardingruleset/lib/index.d.ts +6 -0
  38. package/lib/azure-dnsforwardingruleset/lib/index.js +23 -0
  39. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link-schemas.d.ts +24 -0
  40. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link-schemas.js +199 -0
  41. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.d.ts +160 -0
  42. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +178 -0
  43. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.integ.d.ts +9 -0
  44. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.integ.js +133 -0
  45. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.spec.d.ts +9 -0
  46. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.spec.js +350 -0
  47. package/lib/azure-dnsforwardingruleset/test/forwarding-rule.spec.d.ts +9 -0
  48. package/lib/azure-dnsforwardingruleset/test/forwarding-rule.spec.js +397 -0
  49. package/lib/azure-dnsforwardingruleset/test/virtual-network-link.spec.d.ts +9 -0
  50. package/lib/azure-dnsforwardingruleset/test/virtual-network-link.spec.js +285 -0
  51. package/lib/azure-dnsresolver/index.d.ts +1 -0
  52. package/lib/azure-dnsresolver/index.js +18 -0
  53. package/lib/azure-dnsresolver/lib/dns-resolver-schemas.d.ts +24 -0
  54. package/lib/azure-dnsresolver/lib/dns-resolver-schemas.js +218 -0
  55. package/lib/azure-dnsresolver/lib/dns-resolver.d.ts +170 -0
  56. package/lib/azure-dnsresolver/lib/dns-resolver.js +236 -0
  57. package/lib/azure-dnsresolver/lib/inbound-endpoint-schemas.d.ts +24 -0
  58. package/lib/azure-dnsresolver/lib/inbound-endpoint-schemas.js +261 -0
  59. package/lib/azure-dnsresolver/lib/inbound-endpoint.d.ts +189 -0
  60. package/lib/azure-dnsresolver/lib/inbound-endpoint.js +243 -0
  61. package/lib/azure-dnsresolver/lib/index.d.ts +6 -0
  62. package/lib/azure-dnsresolver/lib/index.js +23 -0
  63. package/lib/azure-dnsresolver/lib/outbound-endpoint-schemas.d.ts +24 -0
  64. package/lib/azure-dnsresolver/lib/outbound-endpoint-schemas.js +231 -0
  65. package/lib/azure-dnsresolver/lib/outbound-endpoint.d.ts +175 -0
  66. package/lib/azure-dnsresolver/lib/outbound-endpoint.js +234 -0
  67. package/lib/azure-dnsresolver/test/dns-resolver.integ.d.ts +14 -0
  68. package/lib/azure-dnsresolver/test/dns-resolver.integ.js +117 -0
  69. package/lib/azure-dnsresolver/test/dns-resolver.spec.d.ts +9 -0
  70. package/lib/azure-dnsresolver/test/dns-resolver.spec.js +353 -0
  71. package/lib/azure-dnsresolver/test/inbound-endpoint.integ.d.ts +9 -0
  72. package/lib/azure-dnsresolver/test/inbound-endpoint.integ.js +151 -0
  73. package/lib/azure-dnsresolver/test/inbound-endpoint.spec.d.ts +9 -0
  74. package/lib/azure-dnsresolver/test/inbound-endpoint.spec.js +441 -0
  75. package/lib/azure-dnsresolver/test/outbound-endpoint.integ.d.ts +9 -0
  76. package/lib/azure-dnsresolver/test/outbound-endpoint.integ.js +149 -0
  77. package/lib/azure-dnsresolver/test/outbound-endpoint.spec.d.ts +9 -0
  78. package/lib/azure-dnsresolver/test/outbound-endpoint.spec.js +301 -0
  79. package/lib/azure-dnszone/index.d.ts +1 -0
  80. package/lib/azure-dnszone/index.js +18 -0
  81. package/lib/azure-dnszone/lib/dns-zone-schemas.d.ts +24 -0
  82. package/lib/azure-dnszone/lib/dns-zone-schemas.js +191 -0
  83. package/lib/azure-dnszone/lib/dns-zone.d.ts +182 -0
  84. package/lib/azure-dnszone/lib/dns-zone.js +228 -0
  85. package/lib/azure-dnszone/lib/index.d.ts +2 -0
  86. package/lib/azure-dnszone/lib/index.js +19 -0
  87. package/lib/azure-dnszone/test/dns-zone.integ.d.ts +9 -0
  88. package/lib/azure-dnszone/test/dns-zone.integ.js +85 -0
  89. package/lib/azure-dnszone/test/dns-zone.spec.d.ts +9 -0
  90. package/lib/azure-dnszone/test/dns-zone.spec.js +285 -0
  91. package/lib/azure-metricalert/index.d.ts +0 -10
  92. package/lib/azure-metricalert/index.js +1 -11
  93. package/lib/azure-metricalert/lib/index.d.ts +1 -4
  94. package/lib/azure-metricalert/lib/index.js +2 -5
  95. package/lib/azure-metricalert/lib/metric-alert.d.ts +0 -10
  96. package/lib/azure-metricalert/lib/metric-alert.js +6 -32
  97. package/lib/azure-networkinterface/index.d.ts +0 -3
  98. package/lib/azure-networkinterface/index.js +1 -4
  99. package/lib/azure-networkinterface/lib/index.d.ts +1 -5
  100. package/lib/azure-networkinterface/lib/index.js +2 -5
  101. package/lib/azure-networkinterface/lib/network-interface.d.ts +4 -9
  102. package/lib/azure-networkinterface/lib/network-interface.js +14 -29
  103. package/lib/azure-networkinterface/test/network-interface.integ.js +20 -6
  104. package/lib/azure-networksecuritygroup/index.d.ts +0 -5
  105. package/lib/azure-networksecuritygroup/index.js +1 -6
  106. package/lib/azure-networksecuritygroup/lib/index.d.ts +2 -5
  107. package/lib/azure-networksecuritygroup/lib/index.js +17 -14
  108. package/lib/azure-networksecuritygroup/lib/network-security-group.d.ts +4 -13
  109. package/lib/azure-networksecuritygroup/lib/network-security-group.js +14 -36
  110. package/lib/azure-policyassignment/index.d.ts +1 -0
  111. package/lib/azure-policyassignment/index.js +18 -0
  112. package/lib/azure-policyassignment/lib/index.d.ts +2 -0
  113. package/lib/azure-policyassignment/lib/index.js +19 -0
  114. package/lib/azure-policyassignment/lib/policy-assignment-schemas.d.ts +25 -0
  115. package/lib/azure-policyassignment/lib/policy-assignment-schemas.js +260 -0
  116. package/lib/azure-policyassignment/lib/policy-assignment.d.ts +349 -0
  117. package/lib/azure-policyassignment/lib/policy-assignment.js +237 -0
  118. package/lib/azure-policyassignment/test/policy-assignment.integ.d.ts +13 -0
  119. package/lib/azure-policyassignment/test/policy-assignment.integ.js +153 -0
  120. package/lib/azure-policyassignment/test/policy-assignment.spec.d.ts +9 -0
  121. package/lib/azure-policyassignment/test/policy-assignment.spec.js +651 -0
  122. package/lib/azure-policydefinition/index.d.ts +1 -0
  123. package/lib/azure-policydefinition/index.js +18 -0
  124. package/lib/azure-policydefinition/lib/index.d.ts +2 -0
  125. package/lib/azure-policydefinition/lib/index.js +19 -0
  126. package/lib/azure-policydefinition/lib/policy-definition-schemas.d.ts +25 -0
  127. package/lib/azure-policydefinition/lib/policy-definition-schemas.js +210 -0
  128. package/lib/azure-policydefinition/lib/policy-definition.d.ts +281 -0
  129. package/lib/azure-policydefinition/lib/policy-definition.js +236 -0
  130. package/lib/azure-policydefinition/test/policy-definition.integ.d.ts +9 -0
  131. package/lib/azure-policydefinition/test/policy-definition.integ.js +137 -0
  132. package/lib/azure-policydefinition/test/policy-definition.spec.d.ts +9 -0
  133. package/lib/azure-policydefinition/test/policy-definition.spec.js +806 -0
  134. package/lib/azure-privatednszone/index.d.ts +1 -0
  135. package/lib/azure-privatednszone/index.js +18 -0
  136. package/lib/azure-privatednszone/lib/index.d.ts +2 -0
  137. package/lib/azure-privatednszone/lib/index.js +19 -0
  138. package/lib/azure-privatednszone/lib/private-dns-zone-schemas.d.ts +24 -0
  139. package/lib/azure-privatednszone/lib/private-dns-zone-schemas.js +254 -0
  140. package/lib/azure-privatednszone/lib/private-dns-zone.d.ts +178 -0
  141. package/lib/azure-privatednszone/lib/private-dns-zone.js +272 -0
  142. package/lib/azure-privatednszone/test/private-dns-zone.integ.d.ts +9 -0
  143. package/lib/azure-privatednszone/test/private-dns-zone.integ.js +84 -0
  144. package/lib/azure-privatednszone/test/private-dns-zone.spec.d.ts +9 -0
  145. package/lib/azure-privatednszone/test/private-dns-zone.spec.js +341 -0
  146. package/lib/azure-privatednszonelink/index.d.ts +1 -0
  147. package/lib/azure-privatednszonelink/index.js +18 -0
  148. package/lib/azure-privatednszonelink/lib/index.d.ts +2 -0
  149. package/lib/azure-privatednszonelink/lib/index.js +19 -0
  150. package/lib/azure-privatednszonelink/lib/private-dns-zone-link-schemas.d.ts +24 -0
  151. package/lib/azure-privatednszonelink/lib/private-dns-zone-link-schemas.js +262 -0
  152. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.d.ts +202 -0
  153. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +250 -0
  154. package/lib/azure-privatednszonelink/test/private-dns-zone-link.integ.d.ts +9 -0
  155. package/lib/azure-privatednszonelink/test/private-dns-zone-link.integ.js +110 -0
  156. package/lib/azure-privatednszonelink/test/private-dns-zone-link.spec.d.ts +9 -0
  157. package/lib/azure-privatednszonelink/test/private-dns-zone-link.spec.js +465 -0
  158. package/lib/azure-publicipaddress/index.d.ts +0 -5
  159. package/lib/azure-publicipaddress/index.js +1 -6
  160. package/lib/azure-publicipaddress/lib/index.d.ts +2 -9
  161. package/lib/azure-publicipaddress/lib/index.js +17 -17
  162. package/lib/azure-publicipaddress/lib/public-ip-address.d.ts +4 -13
  163. package/lib/azure-publicipaddress/lib/public-ip-address.js +14 -36
  164. package/lib/azure-resourcegroup/index.d.ts +0 -37
  165. package/lib/azure-resourcegroup/index.js +1 -39
  166. package/lib/azure-resourcegroup/lib/index.d.ts +1 -44
  167. package/lib/azure-resourcegroup/lib/index.js +2 -43
  168. package/lib/azure-resourcegroup/lib/resource-group.d.ts +9 -23
  169. package/lib/azure-resourcegroup/lib/resource-group.js +23 -56
  170. package/lib/azure-resourcegroup/test/resource-group.spec.js +13 -19
  171. package/lib/azure-roleassignment/index.d.ts +1 -0
  172. package/lib/azure-roleassignment/index.js +18 -0
  173. package/lib/azure-roleassignment/lib/index.d.ts +2 -0
  174. package/lib/azure-roleassignment/lib/index.js +19 -0
  175. package/lib/azure-roleassignment/lib/role-assignment-schemas.d.ts +25 -0
  176. package/lib/azure-roleassignment/lib/role-assignment-schemas.js +238 -0
  177. package/lib/azure-roleassignment/lib/role-assignment.d.ts +294 -0
  178. package/lib/azure-roleassignment/lib/role-assignment.js +257 -0
  179. package/lib/azure-roleassignment/test/role-assignment.integ.d.ts +12 -0
  180. package/lib/azure-roleassignment/test/role-assignment.integ.js +101 -0
  181. package/lib/azure-roleassignment/test/role-assignment.spec.d.ts +9 -0
  182. package/lib/azure-roleassignment/test/role-assignment.spec.js +633 -0
  183. package/lib/azure-roledefinition/index.d.ts +1 -0
  184. package/lib/azure-roledefinition/index.js +18 -0
  185. package/lib/azure-roledefinition/lib/index.d.ts +2 -0
  186. package/lib/azure-roledefinition/lib/index.js +19 -0
  187. package/lib/azure-roledefinition/lib/role-definition-schemas.d.ts +25 -0
  188. package/lib/azure-roledefinition/lib/role-definition-schemas.js +195 -0
  189. package/lib/azure-roledefinition/lib/role-definition.d.ts +236 -0
  190. package/lib/azure-roledefinition/lib/role-definition.js +192 -0
  191. package/lib/azure-roledefinition/test/role-definition.integ.d.ts +12 -0
  192. package/lib/azure-roledefinition/test/role-definition.integ.js +142 -0
  193. package/lib/azure-roledefinition/test/role-definition.spec.d.ts +9 -0
  194. package/lib/azure-roledefinition/test/role-definition.spec.js +946 -0
  195. package/lib/azure-storageaccount/index.d.ts +0 -19
  196. package/lib/azure-storageaccount/index.js +1 -20
  197. package/lib/azure-storageaccount/lib/index.d.ts +1 -7
  198. package/lib/azure-storageaccount/lib/index.js +2 -8
  199. package/lib/azure-storageaccount/lib/storage-account.d.ts +4 -9
  200. package/lib/azure-storageaccount/lib/storage-account.js +15 -29
  201. package/lib/azure-subnet/index.d.ts +0 -3
  202. package/lib/azure-subnet/index.js +1 -4
  203. package/lib/azure-subnet/lib/index.d.ts +1 -4
  204. package/lib/azure-subnet/lib/index.js +2 -5
  205. package/lib/azure-subnet/lib/subnet.d.ts +3 -14
  206. package/lib/azure-subnet/lib/subnet.js +28 -47
  207. package/lib/azure-subnet/test/subnet.integ.js +19 -7
  208. package/lib/azure-subnet/test/subnet.spec.js +1 -2
  209. package/lib/azure-virtualmachine/index.d.ts +0 -6
  210. package/lib/azure-virtualmachine/index.js +1 -7
  211. package/lib/azure-virtualmachine/lib/index.d.ts +1 -10
  212. package/lib/azure-virtualmachine/lib/index.js +2 -21
  213. package/lib/azure-virtualmachine/lib/virtual-machine.d.ts +4 -13
  214. package/lib/azure-virtualmachine/lib/virtual-machine.js +15 -36
  215. package/lib/azure-virtualnetwork/index.d.ts +0 -9
  216. package/lib/azure-virtualnetwork/index.js +1 -11
  217. package/lib/azure-virtualnetwork/lib/index.d.ts +2 -9
  218. package/lib/azure-virtualnetwork/lib/index.js +17 -20
  219. package/lib/azure-virtualnetwork/lib/virtual-network.d.ts +4 -13
  220. package/lib/azure-virtualnetwork/lib/virtual-network.js +15 -36
  221. package/lib/azure-virtualnetworkmanager/index.d.ts +1 -0
  222. package/lib/azure-virtualnetworkmanager/index.js +18 -0
  223. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration-schemas.d.ts +48 -0
  224. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration-schemas.js +265 -0
  225. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.d.ts +185 -0
  226. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +206 -0
  227. package/lib/azure-virtualnetworkmanager/lib/index.d.ts +14 -0
  228. package/lib/azure-virtualnetworkmanager/lib/index.js +31 -0
  229. package/lib/azure-virtualnetworkmanager/lib/network-group-schemas.d.ts +32 -0
  230. package/lib/azure-virtualnetworkmanager/lib/network-group-schemas.js +189 -0
  231. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member-schemas.d.ts +32 -0
  232. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member-schemas.js +201 -0
  233. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.d.ts +135 -0
  234. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +163 -0
  235. package/lib/azure-virtualnetworkmanager/lib/network-group.d.ts +139 -0
  236. package/lib/azure-virtualnetworkmanager/lib/network-group.js +158 -0
  237. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration-schemas.d.ts +32 -0
  238. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration-schemas.js +182 -0
  239. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.d.ts +144 -0
  240. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +164 -0
  241. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection-schemas.d.ts +38 -0
  242. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection-schemas.js +206 -0
  243. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.d.ts +142 -0
  244. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +162 -0
  245. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-schemas.d.ts +39 -0
  246. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-schemas.js +359 -0
  247. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.d.ts +221 -0
  248. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +204 -0
  249. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager-schemas.d.ts +32 -0
  250. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager-schemas.js +236 -0
  251. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.d.ts +337 -0
  252. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +283 -0
  253. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.d.ts +25 -0
  254. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.js +402 -0
  255. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.d.ts +9 -0
  256. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.js +1652 -0
  257. package/lib/azure-vmss/index.d.ts +0 -5
  258. package/lib/azure-vmss/index.js +1 -6
  259. package/lib/azure-vmss/lib/index.d.ts +0 -7
  260. package/lib/azure-vmss/lib/index.js +1 -21
  261. package/lib/azure-vmss/lib/virtual-machine-scale-set.d.ts +5 -13
  262. package/lib/azure-vmss/lib/virtual-machine-scale-set.js +29 -53
  263. package/lib/core-azure/lib/azapi/azapi-resource-tags.spec.d.ts +10 -0
  264. package/lib/core-azure/lib/azapi/azapi-resource-tags.spec.js +218 -0
  265. package/lib/core-azure/lib/azapi/azapi-resource.d.ts +206 -26
  266. package/lib/core-azure/lib/azapi/azapi-resource.js +379 -91
  267. package/lib/core-azure/lib/azapi/azapi-resource.spec.js +2 -2
  268. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
  269. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
  270. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +5 -3
  271. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
  272. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
  273. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
  274. package/lib/core-azure/lib/azapi/resource-schema-validator.d.ts +118 -0
  275. package/lib/core-azure/lib/azapi/resource-schema-validator.js +236 -0
  276. package/lib/core-azure/lib/azapi/resource-version-manager.d.ts +103 -0
  277. package/lib/core-azure/lib/azapi/resource-version-manager.js +168 -0
  278. package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +11 -6
  279. package/lib/core-azure/lib/index.d.ts +2 -2
  280. package/lib/core-azure/lib/index.js +5 -5
  281. package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
  282. package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
  283. package/lib/index.d.ts +19 -0
  284. package/lib/index.js +21 -2
  285. package/lib/testing/index.js +2 -2
  286. package/lib/testing/lib/cleanup.d.ts +1 -0
  287. package/lib/testing/lib/cleanup.js +19 -12
  288. package/lib/testing/lib/metadata.js +19 -16
  289. package/package.json +1 -1
  290. package/scripts/cleanup-test-resources.ts +22 -4
  291. package/scripts/generate-index.js +25 -8
@@ -0,0 +1,133 @@
1
+ "use strict";
2
+ /**
3
+ * Integration test for Azure DNS Forwarding Ruleset with child resources
4
+ *
5
+ * This test demonstrates basic usage of the DNS Forwarding Ruleset constructs
6
+ * including one ForwardingRule and one VirtualNetworkLink.
7
+ *
8
+ * Run with: npm run integration:nostream
9
+ */
10
+ Object.defineProperty(exports, "__esModule", { value: true });
11
+ const cdktf_1 = require("cdktf");
12
+ require("cdktf/lib/testing/adapters/jest");
13
+ const dns_resolver_1 = require("../../azure-dnsresolver/lib/dns-resolver");
14
+ const outbound_endpoint_1 = require("../../azure-dnsresolver/lib/outbound-endpoint");
15
+ const resource_group_1 = require("../../azure-resourcegroup/lib/resource-group");
16
+ const subnet_1 = require("../../azure-subnet/lib/subnet");
17
+ const virtual_network_1 = require("../../azure-virtualnetwork/lib/virtual-network");
18
+ const provider_1 = require("../../core-azure/lib/azapi/providers-azapi/provider");
19
+ const testing_1 = require("../../testing");
20
+ const metadata_1 = require("../../testing/lib/metadata");
21
+ const dns_forwarding_ruleset_1 = require("../lib/dns-forwarding-ruleset");
22
+ const forwarding_rule_1 = require("../lib/forwarding-rule");
23
+ const virtual_network_link_1 = require("../lib/virtual-network-link");
24
+ // Generate unique test run metadata for this test suite
25
+ const testMetadata = new metadata_1.TestRunMetadata("dnsforwardingruleset-integration", {
26
+ maxAgeHours: 4,
27
+ });
28
+ /**
29
+ * Example stack demonstrating DNS Forwarding Ruleset with child resources
30
+ */
31
+ class DnsForwardingRulesetExampleStack extends testing_1.BaseTestStack {
32
+ constructor(scope, id) {
33
+ super(scope, id, {
34
+ testRunOptions: {
35
+ maxAgeHours: testMetadata.maxAgeHours,
36
+ autoCleanup: testMetadata.autoCleanup,
37
+ cleanupPolicy: testMetadata.cleanupPolicy,
38
+ },
39
+ });
40
+ // Configure AZAPI provider
41
+ new provider_1.AzapiProvider(this, "azapi", {});
42
+ // Generate unique names
43
+ const resourceGroupName = this.generateResourceName("Microsoft.Resources/resourceGroups", "dnsfwd");
44
+ const vnetName = this.generateResourceName("Microsoft.Network/virtualNetworks", "resolver");
45
+ const resolverName = this.generateResourceName("Microsoft.Network/dnsResolvers", "resolver");
46
+ const rulesetName = this.generateResourceName("Microsoft.Network/dnsForwardingRulesets", "ruleset");
47
+ // Create resource group
48
+ const resourceGroup = new resource_group_1.ResourceGroup(this, "test-rg", {
49
+ name: resourceGroupName,
50
+ location: "eastus",
51
+ tags: this.systemTags(),
52
+ });
53
+ // Create Virtual Network
54
+ const vnet = new virtual_network_1.VirtualNetwork(this, "test-vnet", {
55
+ name: vnetName,
56
+ location: "eastus",
57
+ resourceGroupId: resourceGroup.id,
58
+ addressSpace: {
59
+ addressPrefixes: ["10.0.0.0/16"],
60
+ },
61
+ tags: this.systemTags(),
62
+ });
63
+ // Create subnet for Outbound Endpoint
64
+ const outboundSubnet = new subnet_1.Subnet(this, "outbound-subnet", {
65
+ name: "outbound-subnet",
66
+ resourceGroupId: resourceGroup.id,
67
+ virtualNetworkName: vnetName,
68
+ virtualNetworkId: vnet.id,
69
+ addressPrefix: "10.0.1.0/28",
70
+ delegations: [
71
+ {
72
+ name: "Microsoft.Network.dnsResolvers",
73
+ serviceName: "Microsoft.Network/dnsResolvers",
74
+ },
75
+ ],
76
+ });
77
+ // Create DNS Resolver
78
+ const resolver = new dns_resolver_1.DnsResolver(this, "dns-resolver", {
79
+ name: resolverName,
80
+ location: "eastus",
81
+ resourceGroupId: resourceGroup.id,
82
+ virtualNetworkId: vnet.id,
83
+ tags: this.systemTags(),
84
+ });
85
+ // Create Outbound Endpoint
86
+ const outboundEndpoint = new outbound_endpoint_1.DnsResolverOutboundEndpoint(this, "outbound-endpoint", {
87
+ name: "outbound-ep",
88
+ location: "eastus",
89
+ dnsResolverId: resolver.id,
90
+ subnetId: outboundSubnet.id,
91
+ tags: this.systemTags(),
92
+ });
93
+ // Create DNS Forwarding Ruleset
94
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(this, "ruleset", {
95
+ name: rulesetName,
96
+ location: "eastus",
97
+ resourceGroupId: resourceGroup.id,
98
+ dnsResolverOutboundEndpointIds: [outboundEndpoint.id],
99
+ tags: this.systemTags(),
100
+ });
101
+ // Create Forwarding Rule
102
+ new forwarding_rule_1.ForwardingRule(this, "rule", {
103
+ name: "contoso-rule",
104
+ dnsForwardingRulesetId: ruleset.id,
105
+ domainName: "contoso.com.",
106
+ targetDnsServers: [
107
+ { ipAddress: "10.0.10.4", port: 53 },
108
+ { ipAddress: "10.0.10.5" },
109
+ ],
110
+ metadata: this.systemTags(),
111
+ });
112
+ // Create Virtual Network Link
113
+ new virtual_network_link_1.DnsForwardingRulesetVirtualNetworkLink(this, "vnet-link", {
114
+ name: "vnet-link",
115
+ dnsForwardingRulesetId: ruleset.id,
116
+ virtualNetworkId: vnet.id,
117
+ metadata: this.systemTags(),
118
+ });
119
+ }
120
+ }
121
+ describe("DnsForwardingRuleset Integration Test", () => {
122
+ it("should deploy, validate idempotency, and cleanup resources", () => {
123
+ const app = cdktf_1.Testing.app();
124
+ const stack = new DnsForwardingRulesetExampleStack(app, "test-dnsforwardingruleset");
125
+ const synthesized = cdktf_1.Testing.fullSynth(stack);
126
+ // This will:
127
+ // 1. Run terraform apply to deploy all resources
128
+ // 2. Run terraform plan to check idempotency
129
+ // 3. Run terraform destroy to cleanup all resources
130
+ (0, testing_1.TerraformApplyCheckAndDestroy)(synthesized, { verifyCleanup: true });
131
+ }, 900000); // 15 minute timeout
132
+ });
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dns-forwarding-ruleset.integ.js","sourceRoot":"","sources":["../../../src/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.integ.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Integration test for Azure DNS Forwarding Ruleset with child resources\n *\n * This test demonstrates basic usage of the DNS Forwarding Ruleset constructs\n * including one ForwardingRule and one VirtualNetworkLink.\n *\n * Run with: npm run integration:nostream\n */\n\nimport { Testing } from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport \"cdktf/lib/testing/adapters/jest\";\nimport { DnsResolver } from \"../../azure-dnsresolver/lib/dns-resolver\";\nimport { DnsResolverOutboundEndpoint } from \"../../azure-dnsresolver/lib/outbound-endpoint\";\nimport { ResourceGroup } from \"../../azure-resourcegroup/lib/resource-group\";\nimport { Subnet } from \"../../azure-subnet/lib/subnet\";\nimport { VirtualNetwork } from \"../../azure-virtualnetwork/lib/virtual-network\";\nimport { AzapiProvider } from \"../../core-azure/lib/azapi/providers-azapi/provider\";\nimport { BaseTestStack, TerraformApplyCheckAndDestroy } from \"../../testing\";\nimport { TestRunMetadata } from \"../../testing/lib/metadata\";\nimport { DnsForwardingRuleset } from \"../lib/dns-forwarding-ruleset\";\nimport { ForwardingRule } from \"../lib/forwarding-rule\";\nimport { DnsForwardingRulesetVirtualNetworkLink } from \"../lib/virtual-network-link\";\n\n// Generate unique test run metadata for this test suite\nconst testMetadata = new TestRunMetadata(\"dnsforwardingruleset-integration\", {\n  maxAgeHours: 4,\n});\n\n/**\n * Example stack demonstrating DNS Forwarding Ruleset with child resources\n */\nclass DnsForwardingRulesetExampleStack extends BaseTestStack {\n  constructor(scope: Construct, id: string) {\n    super(scope, id, {\n      testRunOptions: {\n        maxAgeHours: testMetadata.maxAgeHours,\n        autoCleanup: testMetadata.autoCleanup,\n        cleanupPolicy: testMetadata.cleanupPolicy,\n      },\n    });\n\n    // Configure AZAPI provider\n    new AzapiProvider(this, \"azapi\", {});\n\n    // Generate unique names\n    const resourceGroupName = this.generateResourceName(\n      \"Microsoft.Resources/resourceGroups\",\n      \"dnsfwd\",\n    );\n    const vnetName = this.generateResourceName(\n      \"Microsoft.Network/virtualNetworks\",\n      \"resolver\",\n    );\n    const resolverName = this.generateResourceName(\n      \"Microsoft.Network/dnsResolvers\",\n      \"resolver\",\n    );\n    const rulesetName = this.generateResourceName(\n      \"Microsoft.Network/dnsForwardingRulesets\",\n      \"ruleset\",\n    );\n\n    // Create resource group\n    const resourceGroup = new ResourceGroup(this, \"test-rg\", {\n      name: resourceGroupName,\n      location: \"eastus\",\n      tags: this.systemTags(),\n    });\n\n    // Create Virtual Network\n    const vnet = new VirtualNetwork(this, \"test-vnet\", {\n      name: vnetName,\n      location: \"eastus\",\n      resourceGroupId: resourceGroup.id,\n      addressSpace: {\n        addressPrefixes: [\"10.0.0.0/16\"],\n      },\n      tags: this.systemTags(),\n    });\n\n    // Create subnet for Outbound Endpoint\n    const outboundSubnet = new Subnet(this, \"outbound-subnet\", {\n      name: \"outbound-subnet\",\n      resourceGroupId: resourceGroup.id,\n      virtualNetworkName: vnetName,\n      virtualNetworkId: vnet.id,\n      addressPrefix: \"10.0.1.0/28\",\n      delegations: [\n        {\n          name: \"Microsoft.Network.dnsResolvers\",\n          serviceName: \"Microsoft.Network/dnsResolvers\",\n        },\n      ],\n    });\n\n    // Create DNS Resolver\n    const resolver = new DnsResolver(this, \"dns-resolver\", {\n      name: resolverName,\n      location: \"eastus\",\n      resourceGroupId: resourceGroup.id,\n      virtualNetworkId: vnet.id,\n      tags: this.systemTags(),\n    });\n\n    // Create Outbound Endpoint\n    const outboundEndpoint = new DnsResolverOutboundEndpoint(\n      this,\n      \"outbound-endpoint\",\n      {\n        name: \"outbound-ep\",\n        location: \"eastus\",\n        dnsResolverId: resolver.id,\n        subnetId: outboundSubnet.id,\n        tags: this.systemTags(),\n      },\n    );\n\n    // Create DNS Forwarding Ruleset\n    const ruleset = new DnsForwardingRuleset(this, \"ruleset\", {\n      name: rulesetName,\n      location: \"eastus\",\n      resourceGroupId: resourceGroup.id,\n      dnsResolverOutboundEndpointIds: [outboundEndpoint.id],\n      tags: this.systemTags(),\n    });\n\n    // Create Forwarding Rule\n    new ForwardingRule(this, \"rule\", {\n      name: \"contoso-rule\",\n      dnsForwardingRulesetId: ruleset.id,\n      domainName: \"contoso.com.\",\n      targetDnsServers: [\n        { ipAddress: \"10.0.10.4\", port: 53 },\n        { ipAddress: \"10.0.10.5\" },\n      ],\n      metadata: this.systemTags(),\n    });\n\n    // Create Virtual Network Link\n    new DnsForwardingRulesetVirtualNetworkLink(this, \"vnet-link\", {\n      name: \"vnet-link\",\n      dnsForwardingRulesetId: ruleset.id,\n      virtualNetworkId: vnet.id,\n      metadata: this.systemTags(),\n    });\n  }\n}\n\ndescribe(\"DnsForwardingRuleset Integration Test\", () => {\n  it(\"should deploy, validate idempotency, and cleanup resources\", () => {\n    const app = Testing.app();\n    const stack = new DnsForwardingRulesetExampleStack(\n      app,\n      \"test-dnsforwardingruleset\",\n    );\n    const synthesized = Testing.fullSynth(stack);\n\n    // This will:\n    // 1. Run terraform apply to deploy all resources\n    // 2. Run terraform plan to check idempotency\n    // 3. Run terraform destroy to cleanup all resources\n    TerraformApplyCheckAndDestroy(synthesized, { verifyCleanup: true });\n  }, 900000); // 15 minute timeout\n});\n"]}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Comprehensive tests for the DnsForwardingRuleset implementation
3
+ *
4
+ * This test suite validates the DnsForwardingRuleset class using the
5
+ * AzapiResource framework. Tests cover automatic version resolution,
6
+ * explicit version pinning, schema validation, property transformation,
7
+ * and full backward compatibility.
8
+ */
9
+ export {};
@@ -0,0 +1,350 @@
1
+ "use strict";
2
+ /**
3
+ * Comprehensive tests for the DnsForwardingRuleset implementation
4
+ *
5
+ * This test suite validates the DnsForwardingRuleset class using the
6
+ * AzapiResource framework. Tests cover automatic version resolution,
7
+ * explicit version pinning, schema validation, property transformation,
8
+ * and full backward compatibility.
9
+ */
10
+ Object.defineProperty(exports, "__esModule", { value: true });
11
+ const cdktf_1 = require("cdktf");
12
+ const cdktf = require("cdktf");
13
+ const api_version_manager_1 = require("../../core-azure/lib/version-manager/api-version-manager");
14
+ const version_interfaces_1 = require("../../core-azure/lib/version-manager/interfaces/version-interfaces");
15
+ const dns_forwarding_ruleset_1 = require("../lib/dns-forwarding-ruleset");
16
+ const dns_forwarding_ruleset_schemas_1 = require("../lib/dns-forwarding-ruleset-schemas");
17
+ describe("DnsForwardingRuleset - Implementation", () => {
18
+ let app;
19
+ let stack;
20
+ let manager;
21
+ const mockOutboundEndpointId = "/subscriptions/12345678-1234-1234-1234-123456789012/resourceGroups/test-rg/providers/Microsoft.Network/dnsResolvers/test-resolver/outboundEndpoints/test-endpoint";
22
+ const mockResourceGroupId = "/subscriptions/12345678-1234-1234-1234-123456789012/resourceGroups/test-rg";
23
+ beforeEach(() => {
24
+ app = cdktf_1.Testing.app();
25
+ stack = new cdktf.TerraformStack(app, "TestStack");
26
+ manager = api_version_manager_1.ApiVersionManager.instance();
27
+ // Ensure schemas are registered
28
+ try {
29
+ manager.registerResourceType(dns_forwarding_ruleset_schemas_1.DNS_FORWARDING_RULESET_TYPE, dns_forwarding_ruleset_schemas_1.ALL_DNS_FORWARDING_RULESET_VERSIONS);
30
+ }
31
+ catch (error) {
32
+ // Ignore if already registered
33
+ }
34
+ });
35
+ describe("Constructor and Basic Properties", () => {
36
+ it("should create DNS Forwarding Ruleset with automatic latest version resolution", () => {
37
+ const props = {
38
+ name: "my-ruleset",
39
+ location: "eastus",
40
+ resourceGroupId: mockResourceGroupId,
41
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
42
+ };
43
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", props);
44
+ expect(ruleset).toBeInstanceOf(dns_forwarding_ruleset_1.DnsForwardingRuleset);
45
+ expect(ruleset.resolvedApiVersion).toBe("2022-07-01");
46
+ expect(ruleset.props).toBe(props);
47
+ });
48
+ it("should create DNS Forwarding Ruleset with explicit version pinning", () => {
49
+ const props = {
50
+ name: "my-ruleset",
51
+ location: "eastus",
52
+ resourceGroupId: mockResourceGroupId,
53
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
54
+ apiVersion: "2022-07-01",
55
+ tags: { environment: "test" },
56
+ };
57
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", props);
58
+ expect(ruleset.resolvedApiVersion).toBe("2022-07-01");
59
+ expect(ruleset.tags).toEqual({ environment: "test" });
60
+ });
61
+ it("should use location from props", () => {
62
+ const props = {
63
+ name: "my-ruleset",
64
+ location: "westus",
65
+ resourceGroupId: mockResourceGroupId,
66
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
67
+ };
68
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", props);
69
+ expect(ruleset.location).toBe("westus");
70
+ });
71
+ it("should create DNS Forwarding Ruleset with multiple outbound endpoints", () => {
72
+ const props = {
73
+ name: "my-ruleset",
74
+ location: "eastus",
75
+ resourceGroupId: mockResourceGroupId,
76
+ dnsResolverOutboundEndpointIds: [
77
+ mockOutboundEndpointId,
78
+ `${mockOutboundEndpointId}-2`,
79
+ ],
80
+ };
81
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", props);
82
+ expect(ruleset).toBeDefined();
83
+ expect(ruleset.props.dnsResolverOutboundEndpointIds).toHaveLength(2);
84
+ });
85
+ });
86
+ describe("Framework Integration", () => {
87
+ it("should resolve latest API version automatically", () => {
88
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
89
+ name: "my-ruleset",
90
+ location: "eastus",
91
+ resourceGroupId: mockResourceGroupId,
92
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
93
+ });
94
+ expect(ruleset.resolvedApiVersion).toBe("2022-07-01");
95
+ expect(ruleset.latestVersion()).toBe("2022-07-01");
96
+ });
97
+ it("should provide version configuration", () => {
98
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
99
+ name: "my-ruleset",
100
+ location: "eastus",
101
+ resourceGroupId: mockResourceGroupId,
102
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
103
+ });
104
+ expect(ruleset.versionConfig).toBeDefined();
105
+ expect(ruleset.versionConfig.version).toBe("2022-07-01");
106
+ expect(ruleset.versionConfig.supportLevel).toBe(version_interfaces_1.VersionSupportLevel.ACTIVE);
107
+ });
108
+ it("should provide supported versions", () => {
109
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
110
+ name: "my-ruleset",
111
+ location: "eastus",
112
+ resourceGroupId: mockResourceGroupId,
113
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
114
+ });
115
+ const versions = ruleset.supportedVersions();
116
+ expect(versions).toContain("2022-07-01");
117
+ expect(versions.length).toBeGreaterThan(0);
118
+ });
119
+ });
120
+ describe("Public Methods - DNS Forwarding Ruleset Properties", () => {
121
+ it("should provide provisioning state", () => {
122
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
123
+ name: "my-ruleset",
124
+ location: "eastus",
125
+ resourceGroupId: mockResourceGroupId,
126
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
127
+ });
128
+ expect(ruleset.provisioningState).toBeDefined();
129
+ expect(typeof ruleset.provisioningState).toBe("string");
130
+ });
131
+ it("should provide resource GUID", () => {
132
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
133
+ name: "my-ruleset",
134
+ location: "eastus",
135
+ resourceGroupId: mockResourceGroupId,
136
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
137
+ });
138
+ expect(ruleset.resourceGuid).toBeDefined();
139
+ expect(typeof ruleset.resourceGuid).toBe("string");
140
+ });
141
+ });
142
+ describe("Tag Management", () => {
143
+ it("should allow adding tags", () => {
144
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
145
+ name: "my-ruleset",
146
+ location: "eastus",
147
+ resourceGroupId: mockResourceGroupId,
148
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
149
+ tags: { initial: "tag" },
150
+ });
151
+ ruleset.addTag("newKey", "newValue");
152
+ expect(ruleset.props.tags).toHaveProperty("newKey", "newValue");
153
+ expect(ruleset.props.tags).toHaveProperty("initial", "tag");
154
+ });
155
+ it("should allow removing tags", () => {
156
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
157
+ name: "my-ruleset",
158
+ location: "eastus",
159
+ resourceGroupId: mockResourceGroupId,
160
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
161
+ tags: { key1: "value1", key2: "value2" },
162
+ });
163
+ ruleset.removeTag("key1");
164
+ expect(ruleset.props.tags).not.toHaveProperty("key1");
165
+ expect(ruleset.props.tags).toHaveProperty("key2", "value2");
166
+ });
167
+ it("should handle adding tags when no initial tags exist", () => {
168
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
169
+ name: "my-ruleset",
170
+ location: "eastus",
171
+ resourceGroupId: mockResourceGroupId,
172
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
173
+ });
174
+ ruleset.addTag("newKey", "newValue");
175
+ expect(ruleset.props.tags).toHaveProperty("newKey", "newValue");
176
+ });
177
+ });
178
+ describe("Outputs", () => {
179
+ it("should create all required outputs", () => {
180
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
181
+ name: "my-ruleset",
182
+ location: "eastus",
183
+ resourceGroupId: mockResourceGroupId,
184
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
185
+ });
186
+ expect(ruleset.idOutput).toBeDefined();
187
+ expect(ruleset.nameOutput).toBeDefined();
188
+ expect(ruleset.locationOutput).toBeDefined();
189
+ expect(ruleset.tagsOutput).toBeDefined();
190
+ expect(ruleset.provisioningStateOutput).toBeDefined();
191
+ expect(ruleset.resourceGuidOutput).toBeDefined();
192
+ });
193
+ it("should have correct logical IDs for outputs", () => {
194
+ new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
195
+ name: "my-ruleset",
196
+ location: "eastus",
197
+ resourceGroupId: mockResourceGroupId,
198
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
199
+ });
200
+ const synthesized = cdktf_1.Testing.synth(stack);
201
+ expect(synthesized).toContain('"id"');
202
+ expect(synthesized).toContain('"name"');
203
+ expect(synthesized).toContain('"location"');
204
+ expect(synthesized).toContain('"tags"');
205
+ expect(synthesized).toContain('"provisioning_state"');
206
+ expect(synthesized).toContain('"resource_guid"');
207
+ });
208
+ });
209
+ describe("Ignore Changes Configuration", () => {
210
+ it("should apply ignore changes lifecycle rules", () => {
211
+ new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
212
+ name: "my-ruleset",
213
+ location: "eastus",
214
+ resourceGroupId: mockResourceGroupId,
215
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
216
+ ignoreChanges: ["tags"],
217
+ });
218
+ const synthesized = cdktf_1.Testing.synth(stack);
219
+ expect(synthesized).toContain("ignore_changes");
220
+ });
221
+ it("should handle multiple ignore changes properties", () => {
222
+ new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
223
+ name: "my-ruleset",
224
+ location: "eastus",
225
+ resourceGroupId: mockResourceGroupId,
226
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
227
+ ignoreChanges: ["tags", "location"],
228
+ });
229
+ const synthesized = cdktf_1.Testing.synth(stack);
230
+ expect(synthesized).toBeDefined();
231
+ });
232
+ });
233
+ describe("CDK Terraform Integration", () => {
234
+ it("should synthesize to valid Terraform configuration", () => {
235
+ new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "SynthTest", {
236
+ name: "my-ruleset",
237
+ location: "eastus",
238
+ resourceGroupId: mockResourceGroupId,
239
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
240
+ tags: { test: "synthesis" },
241
+ });
242
+ const synthesized = cdktf_1.Testing.synth(stack);
243
+ expect(synthesized).toBeDefined();
244
+ const stackConfig = JSON.parse(synthesized);
245
+ expect(stackConfig.resource).toBeDefined();
246
+ });
247
+ it("should generate correct resource type in Terraform", () => {
248
+ new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "SynthTest", {
249
+ name: "my-ruleset",
250
+ location: "eastus",
251
+ resourceGroupId: mockResourceGroupId,
252
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
253
+ });
254
+ const synthesized = cdktf_1.Testing.synth(stack);
255
+ expect(synthesized).toContain("dnsForwardingRulesets");
256
+ expect(synthesized).toContain("2022-07-01");
257
+ });
258
+ it("should include all properties in Terraform body", () => {
259
+ new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "SynthTest", {
260
+ name: "my-ruleset",
261
+ location: "eastus",
262
+ resourceGroupId: mockResourceGroupId,
263
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
264
+ tags: { env: "test" },
265
+ });
266
+ const synthesized = cdktf_1.Testing.synth(stack);
267
+ expect(synthesized).toContain("eastus");
268
+ expect(synthesized).toContain("env");
269
+ expect(synthesized).toContain(mockOutboundEndpointId);
270
+ });
271
+ });
272
+ describe("Resource Identification", () => {
273
+ it("should provide resource ID", () => {
274
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
275
+ name: "my-ruleset",
276
+ location: "eastus",
277
+ resourceGroupId: mockResourceGroupId,
278
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
279
+ });
280
+ expect(ruleset.id).toBeDefined();
281
+ expect(typeof ruleset.id).toBe("string");
282
+ });
283
+ it("should provide resource name from props when specified", () => {
284
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
285
+ name: "my-ruleset",
286
+ location: "eastus",
287
+ resourceGroupId: mockResourceGroupId,
288
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
289
+ });
290
+ expect(ruleset.name).toBe("my-ruleset");
291
+ });
292
+ });
293
+ describe("JSII Compliance", () => {
294
+ it("should have proper return types for all public methods", () => {
295
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
296
+ name: "my-ruleset",
297
+ location: "eastus",
298
+ resourceGroupId: mockResourceGroupId,
299
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
300
+ });
301
+ // All getter methods should return strings for Terraform interpolations
302
+ expect(typeof ruleset.provisioningState).toBe("string");
303
+ expect(typeof ruleset.resourceGuid).toBe("string");
304
+ });
305
+ it("should not use function types in public interface", () => {
306
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
307
+ name: "my-ruleset",
308
+ location: "eastus",
309
+ resourceGroupId: mockResourceGroupId,
310
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
311
+ });
312
+ // Verify methods exist and are callable
313
+ expect(typeof ruleset.addTag).toBe("function");
314
+ expect(typeof ruleset.removeTag).toBe("function");
315
+ // Test that they work correctly
316
+ ruleset.addTag("test", "value");
317
+ expect(ruleset.props.tags).toHaveProperty("test", "value");
318
+ });
319
+ });
320
+ describe("Schema Registration", () => {
321
+ it("should register schemas successfully", () => {
322
+ const ruleset = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset", {
323
+ name: "my-ruleset",
324
+ location: "eastus",
325
+ resourceGroupId: mockResourceGroupId,
326
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
327
+ });
328
+ // If the ruleset was created successfully, schemas were registered
329
+ expect(ruleset).toBeDefined();
330
+ expect(ruleset.resolvedApiVersion).toBe("2022-07-01");
331
+ });
332
+ it("should handle multiple instantiations without errors", () => {
333
+ new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset1", {
334
+ name: "my-ruleset-1",
335
+ location: "eastus",
336
+ resourceGroupId: mockResourceGroupId,
337
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
338
+ });
339
+ // Second instantiation should not throw an error even if schemas are already registered
340
+ const ruleset2 = new dns_forwarding_ruleset_1.DnsForwardingRuleset(stack, "TestRuleset2", {
341
+ name: "my-ruleset-2",
342
+ location: "eastus",
343
+ resourceGroupId: mockResourceGroupId,
344
+ dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],
345
+ });
346
+ expect(ruleset2).toBeDefined();
347
+ });
348
+ });
349
+ });
350
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dns-forwarding-ruleset.spec.js","sourceRoot":"","sources":["../../../src/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.spec.ts"],"names":[],"mappings":";AAAA;;;;;;;GAOG;;AAEH,iCAAgC;AAChC,+BAA+B;AAC/B,kGAA6F;AAC7F,2GAAyG;AACzG,0EAGuC;AACvC,0FAG+C;AAE/C,QAAQ,CAAC,uCAAuC,EAAE,GAAG,EAAE;IACrD,IAAI,GAAc,CAAC;IACnB,IAAI,KAA2B,CAAC;IAChC,IAAI,OAA0B,CAAC;IAE/B,MAAM,sBAAsB,GAC1B,mKAAmK,CAAC;IACtK,MAAM,mBAAmB,GACvB,4EAA4E,CAAC;IAE/E,UAAU,CAAC,GAAG,EAAE;QACd,GAAG,GAAG,eAAO,CAAC,GAAG,EAAE,CAAC;QACpB,KAAK,GAAG,IAAI,KAAK,CAAC,cAAc,CAAC,GAAG,EAAE,WAAW,CAAC,CAAC;QACnD,OAAO,GAAG,uCAAiB,CAAC,QAAQ,EAAE,CAAC;QAEvC,gCAAgC;QAChC,IAAI,CAAC;YACH,OAAO,CAAC,oBAAoB,CAC1B,4DAA2B,EAC3B,oEAAmC,CACpC,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,+BAA+B;QACjC,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAChD,EAAE,CAAC,+EAA+E,EAAE,GAAG,EAAE;YACvF,MAAM,KAAK,GAA8B;gBACvC,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC;YAEF,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE,KAAK,CAAC,CAAC;YAEtE,MAAM,CAAC,OAAO,CAAC,CAAC,cAAc,CAAC,6CAAoB,CAAC,CAAC;YACrD,MAAM,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACtD,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,oEAAoE,EAAE,GAAG,EAAE;YAC5E,MAAM,KAAK,GAA8B;gBACvC,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;gBACxD,UAAU,EAAE,YAAY;gBACxB,IAAI,EAAE,EAAE,WAAW,EAAE,MAAM,EAAE;aAC9B,CAAC;YAEF,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE,KAAK,CAAC,CAAC;YAEtE,MAAM,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACtD,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,MAAM,EAAE,CAAC,CAAC;QACxD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;YACxC,MAAM,KAAK,GAA8B;gBACvC,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC;YAEF,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE,KAAK,CAAC,CAAC;YAEtE,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,uEAAuE,EAAE,GAAG,EAAE;YAC/E,MAAM,KAAK,GAA8B;gBACvC,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE;oBAC9B,sBAAsB;oBACtB,GAAG,sBAAsB,IAAI;iBAC9B;aACF,CAAC;YAEF,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE,KAAK,CAAC,CAAC;YAEtE,MAAM,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC;YAC9B,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,8BAA8B,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACvE,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;QACrC,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;YACzD,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7D,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC,CAAC;YAEH,MAAM,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACtD,MAAM,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,sCAAsC,EAAE,GAAG,EAAE;YAC9C,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7D,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC,CAAC;YAEH,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,WAAW,EAAE,CAAC;YAC5C,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACzD,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,IAAI,CAC7C,wCAAmB,CAAC,MAAM,CAC3B,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;YAC3C,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7D,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC,CAAC;YAEH,MAAM,QAAQ,GAAG,OAAO,CAAC,iBAAiB,EAAE,CAAC;YAC7C,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;YACzC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QAC7C,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,oDAAoD,EAAE,GAAG,EAAE;QAClE,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;YAC3C,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7D,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC,CAAC;YAEH,MAAM,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC,WAAW,EAAE,CAAC;YAChD,MAAM,CAAC,OAAO,OAAO,CAAC,iBAAiB,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,8BAA8B,EAAE,GAAG,EAAE;YACtC,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7D,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC,CAAC;YAEH,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,WAAW,EAAE,CAAC;YAC3C,MAAM,CAAC,OAAO,OAAO,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;QAC9B,EAAE,CAAC,0BAA0B,EAAE,GAAG,EAAE;YAClC,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7D,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;gBACxD,IAAI,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE;aACzB,CAAC,CAAC;YAEH,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;YACrC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,cAAc,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;YAChE,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,cAAc,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QAC9D,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;YACpC,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7D,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;gBACxD,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE;aACzC,CAAC,CAAC;YAEH,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;YAC1B,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;YACtD,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QAC9D,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,sDAAsD,EAAE,GAAG,EAAE;YAC9D,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7D,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC,CAAC;YAEH,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;YACrC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,cAAc,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;QAClE,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,SAAS,EAAE,GAAG,EAAE;QACvB,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;YAC5C,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7D,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC,CAAC;YAEH,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;YACvC,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC;YACzC,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,WAAW,EAAE,CAAC;YAC7C,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC;YACzC,MAAM,CAAC,OAAO,CAAC,uBAAuB,CAAC,CAAC,WAAW,EAAE,CAAC;YACtD,MAAM,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,WAAW,EAAE,CAAC;QACnD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;YACrD,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7C,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC,CAAC;YAEH,MAAM,WAAW,GAAG,eAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACzC,MAAM,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;YACtC,MAAM,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;YACxC,MAAM,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;YAC5C,MAAM,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;YACxC,MAAM,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,sBAAsB,CAAC,CAAC;YACtD,MAAM,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,iBAAiB,CAAC,CAAC;QACnD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,8BAA8B,EAAE,GAAG,EAAE;QAC5C,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;YACrD,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7C,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;gBACxD,aAAa,EAAE,CAAC,MAAM,CAAC;aACxB,CAAC,CAAC;YAEH,MAAM,WAAW,GAAG,eAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACzC,MAAM,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;QAClD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,kDAAkD,EAAE,GAAG,EAAE;YAC1D,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7C,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;gBACxD,aAAa,EAAE,CAAC,MAAM,EAAE,UAAU,CAAC;aACpC,CAAC,CAAC;YAEH,MAAM,WAAW,GAAG,eAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACzC,MAAM,CAAC,WAAW,CAAC,CAAC,WAAW,EAAE,CAAC;QACpC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;QACzC,EAAE,CAAC,oDAAoD,EAAE,GAAG,EAAE;YAC5D,IAAI,6CAAoB,CAAC,KAAK,EAAE,WAAW,EAAE;gBAC3C,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;gBACxD,IAAI,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE;aAC5B,CAAC,CAAC;YAEH,MAAM,WAAW,GAAG,eAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACzC,MAAM,CAAC,WAAW,CAAC,CAAC,WAAW,EAAE,CAAC;YAElC,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;YAC5C,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;QAC7C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,oDAAoD,EAAE,GAAG,EAAE;YAC5D,IAAI,6CAAoB,CAAC,KAAK,EAAE,WAAW,EAAE;gBAC3C,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC,CAAC;YAEH,MAAM,WAAW,GAAG,eAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACzC,MAAM,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,uBAAuB,CAAC,CAAC;YACvD,MAAM,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QAC9C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;YACzD,IAAI,6CAAoB,CAAC,KAAK,EAAE,WAAW,EAAE;gBAC3C,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;gBACxD,IAAI,EAAE,EAAE,GAAG,EAAE,MAAM,EAAE;aACtB,CAAC,CAAC;YAEH,MAAM,WAAW,GAAG,eAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACzC,MAAM,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;YACxC,MAAM,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;YACrC,MAAM,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,sBAAsB,CAAC,CAAC;QACxD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;QACvC,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;YACpC,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7D,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC,CAAC;YAEH,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC;YACjC,MAAM,CAAC,OAAO,OAAO,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,wDAAwD,EAAE,GAAG,EAAE;YAChE,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7D,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC,CAAC;YAEH,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;QAC/B,EAAE,CAAC,wDAAwD,EAAE,GAAG,EAAE;YAChE,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7D,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC,CAAC;YAEH,wEAAwE;YACxE,MAAM,CAAC,OAAO,OAAO,CAAC,iBAAiB,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACxD,MAAM,CAAC,OAAO,OAAO,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;YAC3D,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7D,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC,CAAC;YAEH,wCAAwC;YACxC,MAAM,CAAC,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC/C,MAAM,CAAC,OAAO,OAAO,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAElD,gCAAgC;YAChC,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;YAChC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,cAAc,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;QACnC,EAAE,CAAC,sCAAsC,EAAE,GAAG,EAAE;YAC9C,MAAM,OAAO,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAC7D,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC,CAAC;YAEH,mEAAmE;YACnE,MAAM,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC;YAC9B,MAAM,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACxD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,sDAAsD,EAAE,GAAG,EAAE;YAC9D,IAAI,6CAAoB,CAAC,KAAK,EAAE,cAAc,EAAE;gBAC9C,IAAI,EAAE,cAAc;gBACpB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC,CAAC;YAEH,wFAAwF;YACxF,MAAM,QAAQ,GAAG,IAAI,6CAAoB,CAAC,KAAK,EAAE,cAAc,EAAE;gBAC/D,IAAI,EAAE,cAAc;gBACpB,QAAQ,EAAE,QAAQ;gBAClB,eAAe,EAAE,mBAAmB;gBACpC,8BAA8B,EAAE,CAAC,sBAAsB,CAAC;aACzD,CAAC,CAAC;YAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;QACjC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["/**\n * Comprehensive tests for the DnsForwardingRuleset implementation\n *\n * This test suite validates the DnsForwardingRuleset class using the\n * AzapiResource framework. Tests cover automatic version resolution,\n * explicit version pinning, schema validation, property transformation,\n * and full backward compatibility.\n */\n\nimport { Testing } from \"cdktf\";\nimport * as cdktf from \"cdktf\";\nimport { ApiVersionManager } from \"../../core-azure/lib/version-manager/api-version-manager\";\nimport { VersionSupportLevel } from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\nimport {\n  DnsForwardingRuleset,\n  DnsForwardingRulesetProps,\n} from \"../lib/dns-forwarding-ruleset\";\nimport {\n  ALL_DNS_FORWARDING_RULESET_VERSIONS,\n  DNS_FORWARDING_RULESET_TYPE,\n} from \"../lib/dns-forwarding-ruleset-schemas\";\n\ndescribe(\"DnsForwardingRuleset - Implementation\", () => {\n  let app: cdktf.App;\n  let stack: cdktf.TerraformStack;\n  let manager: ApiVersionManager;\n\n  const mockOutboundEndpointId =\n    \"/subscriptions/12345678-1234-1234-1234-123456789012/resourceGroups/test-rg/providers/Microsoft.Network/dnsResolvers/test-resolver/outboundEndpoints/test-endpoint\";\n  const mockResourceGroupId =\n    \"/subscriptions/12345678-1234-1234-1234-123456789012/resourceGroups/test-rg\";\n\n  beforeEach(() => {\n    app = Testing.app();\n    stack = new cdktf.TerraformStack(app, \"TestStack\");\n    manager = ApiVersionManager.instance();\n\n    // Ensure schemas are registered\n    try {\n      manager.registerResourceType(\n        DNS_FORWARDING_RULESET_TYPE,\n        ALL_DNS_FORWARDING_RULESET_VERSIONS,\n      );\n    } catch (error) {\n      // Ignore if already registered\n    }\n  });\n\n  describe(\"Constructor and Basic Properties\", () => {\n    it(\"should create DNS Forwarding Ruleset with automatic latest version resolution\", () => {\n      const props: DnsForwardingRulesetProps = {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      };\n\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", props);\n\n      expect(ruleset).toBeInstanceOf(DnsForwardingRuleset);\n      expect(ruleset.resolvedApiVersion).toBe(\"2022-07-01\");\n      expect(ruleset.props).toBe(props);\n    });\n\n    it(\"should create DNS Forwarding Ruleset with explicit version pinning\", () => {\n      const props: DnsForwardingRulesetProps = {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n        apiVersion: \"2022-07-01\",\n        tags: { environment: \"test\" },\n      };\n\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", props);\n\n      expect(ruleset.resolvedApiVersion).toBe(\"2022-07-01\");\n      expect(ruleset.tags).toEqual({ environment: \"test\" });\n    });\n\n    it(\"should use location from props\", () => {\n      const props: DnsForwardingRulesetProps = {\n        name: \"my-ruleset\",\n        location: \"westus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      };\n\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", props);\n\n      expect(ruleset.location).toBe(\"westus\");\n    });\n\n    it(\"should create DNS Forwarding Ruleset with multiple outbound endpoints\", () => {\n      const props: DnsForwardingRulesetProps = {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [\n          mockOutboundEndpointId,\n          `${mockOutboundEndpointId}-2`,\n        ],\n      };\n\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", props);\n\n      expect(ruleset).toBeDefined();\n      expect(ruleset.props.dnsResolverOutboundEndpointIds).toHaveLength(2);\n    });\n  });\n\n  describe(\"Framework Integration\", () => {\n    it(\"should resolve latest API version automatically\", () => {\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      });\n\n      expect(ruleset.resolvedApiVersion).toBe(\"2022-07-01\");\n      expect(ruleset.latestVersion()).toBe(\"2022-07-01\");\n    });\n\n    it(\"should provide version configuration\", () => {\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      });\n\n      expect(ruleset.versionConfig).toBeDefined();\n      expect(ruleset.versionConfig.version).toBe(\"2022-07-01\");\n      expect(ruleset.versionConfig.supportLevel).toBe(\n        VersionSupportLevel.ACTIVE,\n      );\n    });\n\n    it(\"should provide supported versions\", () => {\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      });\n\n      const versions = ruleset.supportedVersions();\n      expect(versions).toContain(\"2022-07-01\");\n      expect(versions.length).toBeGreaterThan(0);\n    });\n  });\n\n  describe(\"Public Methods - DNS Forwarding Ruleset Properties\", () => {\n    it(\"should provide provisioning state\", () => {\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      });\n\n      expect(ruleset.provisioningState).toBeDefined();\n      expect(typeof ruleset.provisioningState).toBe(\"string\");\n    });\n\n    it(\"should provide resource GUID\", () => {\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      });\n\n      expect(ruleset.resourceGuid).toBeDefined();\n      expect(typeof ruleset.resourceGuid).toBe(\"string\");\n    });\n  });\n\n  describe(\"Tag Management\", () => {\n    it(\"should allow adding tags\", () => {\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n        tags: { initial: \"tag\" },\n      });\n\n      ruleset.addTag(\"newKey\", \"newValue\");\n      expect(ruleset.props.tags).toHaveProperty(\"newKey\", \"newValue\");\n      expect(ruleset.props.tags).toHaveProperty(\"initial\", \"tag\");\n    });\n\n    it(\"should allow removing tags\", () => {\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n        tags: { key1: \"value1\", key2: \"value2\" },\n      });\n\n      ruleset.removeTag(\"key1\");\n      expect(ruleset.props.tags).not.toHaveProperty(\"key1\");\n      expect(ruleset.props.tags).toHaveProperty(\"key2\", \"value2\");\n    });\n\n    it(\"should handle adding tags when no initial tags exist\", () => {\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      });\n\n      ruleset.addTag(\"newKey\", \"newValue\");\n      expect(ruleset.props.tags).toHaveProperty(\"newKey\", \"newValue\");\n    });\n  });\n\n  describe(\"Outputs\", () => {\n    it(\"should create all required outputs\", () => {\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      });\n\n      expect(ruleset.idOutput).toBeDefined();\n      expect(ruleset.nameOutput).toBeDefined();\n      expect(ruleset.locationOutput).toBeDefined();\n      expect(ruleset.tagsOutput).toBeDefined();\n      expect(ruleset.provisioningStateOutput).toBeDefined();\n      expect(ruleset.resourceGuidOutput).toBeDefined();\n    });\n\n    it(\"should have correct logical IDs for outputs\", () => {\n      new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      });\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toContain('\"id\"');\n      expect(synthesized).toContain('\"name\"');\n      expect(synthesized).toContain('\"location\"');\n      expect(synthesized).toContain('\"tags\"');\n      expect(synthesized).toContain('\"provisioning_state\"');\n      expect(synthesized).toContain('\"resource_guid\"');\n    });\n  });\n\n  describe(\"Ignore Changes Configuration\", () => {\n    it(\"should apply ignore changes lifecycle rules\", () => {\n      new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n        ignoreChanges: [\"tags\"],\n      });\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toContain(\"ignore_changes\");\n    });\n\n    it(\"should handle multiple ignore changes properties\", () => {\n      new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n        ignoreChanges: [\"tags\", \"location\"],\n      });\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toBeDefined();\n    });\n  });\n\n  describe(\"CDK Terraform Integration\", () => {\n    it(\"should synthesize to valid Terraform configuration\", () => {\n      new DnsForwardingRuleset(stack, \"SynthTest\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n        tags: { test: \"synthesis\" },\n      });\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toBeDefined();\n\n      const stackConfig = JSON.parse(synthesized);\n      expect(stackConfig.resource).toBeDefined();\n    });\n\n    it(\"should generate correct resource type in Terraform\", () => {\n      new DnsForwardingRuleset(stack, \"SynthTest\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      });\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toContain(\"dnsForwardingRulesets\");\n      expect(synthesized).toContain(\"2022-07-01\");\n    });\n\n    it(\"should include all properties in Terraform body\", () => {\n      new DnsForwardingRuleset(stack, \"SynthTest\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n        tags: { env: \"test\" },\n      });\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toContain(\"eastus\");\n      expect(synthesized).toContain(\"env\");\n      expect(synthesized).toContain(mockOutboundEndpointId);\n    });\n  });\n\n  describe(\"Resource Identification\", () => {\n    it(\"should provide resource ID\", () => {\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      });\n\n      expect(ruleset.id).toBeDefined();\n      expect(typeof ruleset.id).toBe(\"string\");\n    });\n\n    it(\"should provide resource name from props when specified\", () => {\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      });\n\n      expect(ruleset.name).toBe(\"my-ruleset\");\n    });\n  });\n\n  describe(\"JSII Compliance\", () => {\n    it(\"should have proper return types for all public methods\", () => {\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      });\n\n      // All getter methods should return strings for Terraform interpolations\n      expect(typeof ruleset.provisioningState).toBe(\"string\");\n      expect(typeof ruleset.resourceGuid).toBe(\"string\");\n    });\n\n    it(\"should not use function types in public interface\", () => {\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      });\n\n      // Verify methods exist and are callable\n      expect(typeof ruleset.addTag).toBe(\"function\");\n      expect(typeof ruleset.removeTag).toBe(\"function\");\n\n      // Test that they work correctly\n      ruleset.addTag(\"test\", \"value\");\n      expect(ruleset.props.tags).toHaveProperty(\"test\", \"value\");\n    });\n  });\n\n  describe(\"Schema Registration\", () => {\n    it(\"should register schemas successfully\", () => {\n      const ruleset = new DnsForwardingRuleset(stack, \"TestRuleset\", {\n        name: \"my-ruleset\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      });\n\n      // If the ruleset was created successfully, schemas were registered\n      expect(ruleset).toBeDefined();\n      expect(ruleset.resolvedApiVersion).toBe(\"2022-07-01\");\n    });\n\n    it(\"should handle multiple instantiations without errors\", () => {\n      new DnsForwardingRuleset(stack, \"TestRuleset1\", {\n        name: \"my-ruleset-1\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      });\n\n      // Second instantiation should not throw an error even if schemas are already registered\n      const ruleset2 = new DnsForwardingRuleset(stack, \"TestRuleset2\", {\n        name: \"my-ruleset-2\",\n        location: \"eastus\",\n        resourceGroupId: mockResourceGroupId,\n        dnsResolverOutboundEndpointIds: [mockOutboundEndpointId],\n      });\n\n      expect(ruleset2).toBeDefined();\n    });\n  });\n});\n"]}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Comprehensive tests for the ForwardingRule implementation
3
+ *
4
+ * This test suite validates the ForwardingRule class using the
5
+ * AzapiResource framework. Tests cover automatic version resolution,
6
+ * explicit version pinning, schema validation, property transformation,
7
+ * parent-child resource relationships, and full backward compatibility.
8
+ */
9
+ export {};