@microsoft/terraform-cdk-constructs 1.2.0 → 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (291) hide show
  1. package/.jsii +54846 -26661
  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 +342 -0
  117. package/lib/azure-policyassignment/lib/policy-assignment.js +228 -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 +260 -0
  129. package/lib/azure-policydefinition/lib/policy-definition.js +199 -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 +596 -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 +178 -26
  266. package/lib/core-azure/lib/azapi/azapi-resource.js +328 -90
  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,441 @@
1
+ "use strict";
2
+ /**
3
+ * Comprehensive tests for the DnsResolverInboundEndpoint implementation
4
+ *
5
+ * This test suite validates the DnsResolverInboundEndpoint class using the
6
+ * AzapiResource framework. Tests cover automatic version resolution,
7
+ * explicit version pinning, schema validation, property transformation,
8
+ * parent-child resource relationships, 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 inbound_endpoint_1 = require("../lib/inbound-endpoint");
16
+ const inbound_endpoint_schemas_1 = require("../lib/inbound-endpoint-schemas");
17
+ describe("DnsResolverInboundEndpoint - Implementation", () => {
18
+ let app;
19
+ let stack;
20
+ let manager;
21
+ const mockDnsResolverId = "/subscriptions/12345678-1234-1234-1234-123456789012/resourceGroups/test-rg/providers/Microsoft.Network/dnsResolvers/test-resolver";
22
+ const mockSubnetId = "/subscriptions/12345678-1234-1234-1234-123456789012/resourceGroups/test-rg/providers/Microsoft.Network/virtualNetworks/test-vnet/subnets/inbound-subnet";
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(inbound_endpoint_schemas_1.DNS_RESOLVER_INBOUND_ENDPOINT_TYPE, inbound_endpoint_schemas_1.ALL_DNS_RESOLVER_INBOUND_ENDPOINT_VERSIONS);
30
+ }
31
+ catch (error) {
32
+ // Ignore if already registered
33
+ }
34
+ });
35
+ describe("Constructor and Basic Properties", () => {
36
+ it("should create Inbound Endpoint with automatic latest version resolution", () => {
37
+ const props = {
38
+ name: "my-inbound-endpoint",
39
+ location: "eastus",
40
+ dnsResolverId: mockDnsResolverId,
41
+ subnetId: mockSubnetId,
42
+ };
43
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", props);
44
+ expect(endpoint).toBeInstanceOf(inbound_endpoint_1.DnsResolverInboundEndpoint);
45
+ expect(endpoint.resolvedApiVersion).toBe("2022-07-01");
46
+ expect(endpoint.props).toBe(props);
47
+ });
48
+ it("should create Inbound Endpoint with explicit version pinning", () => {
49
+ const props = {
50
+ name: "my-inbound-endpoint",
51
+ location: "eastus",
52
+ dnsResolverId: mockDnsResolverId,
53
+ subnetId: mockSubnetId,
54
+ apiVersion: "2022-07-01",
55
+ tags: { environment: "test" },
56
+ };
57
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", props);
58
+ expect(endpoint.resolvedApiVersion).toBe("2022-07-01");
59
+ expect(endpoint.tags).toEqual({ environment: "test" });
60
+ });
61
+ it("should use location from props", () => {
62
+ const props = {
63
+ name: "my-inbound-endpoint",
64
+ location: "westus",
65
+ dnsResolverId: mockDnsResolverId,
66
+ subnetId: mockSubnetId,
67
+ };
68
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", props);
69
+ expect(endpoint.location).toBe("westus");
70
+ });
71
+ it("should create Inbound Endpoint with static IP address", () => {
72
+ const props = {
73
+ name: "my-inbound-endpoint",
74
+ location: "eastus",
75
+ dnsResolverId: mockDnsResolverId,
76
+ subnetId: mockSubnetId,
77
+ privateIpAddress: "10.0.1.4",
78
+ privateIpAllocationMethod: "Static",
79
+ };
80
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", props);
81
+ expect(endpoint).toBeDefined();
82
+ expect(endpoint.props.privateIpAddress).toBe("10.0.1.4");
83
+ expect(endpoint.props.privateIpAllocationMethod).toBe("Static");
84
+ });
85
+ it("should create Inbound Endpoint with dynamic IP allocation", () => {
86
+ const props = {
87
+ name: "my-inbound-endpoint",
88
+ location: "eastus",
89
+ dnsResolverId: mockDnsResolverId,
90
+ subnetId: mockSubnetId,
91
+ privateIpAllocationMethod: "Dynamic",
92
+ };
93
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", props);
94
+ expect(endpoint).toBeDefined();
95
+ expect(endpoint.props.privateIpAllocationMethod).toBe("Dynamic");
96
+ });
97
+ });
98
+ describe("Framework Integration", () => {
99
+ it("should resolve latest API version automatically", () => {
100
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
101
+ name: "my-inbound-endpoint",
102
+ location: "eastus",
103
+ dnsResolverId: mockDnsResolverId,
104
+ subnetId: mockSubnetId,
105
+ });
106
+ expect(endpoint.resolvedApiVersion).toBe("2022-07-01");
107
+ expect(endpoint.latestVersion()).toBe("2022-07-01");
108
+ });
109
+ it("should provide version configuration", () => {
110
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
111
+ name: "my-inbound-endpoint",
112
+ location: "eastus",
113
+ dnsResolverId: mockDnsResolverId,
114
+ subnetId: mockSubnetId,
115
+ });
116
+ expect(endpoint.versionConfig).toBeDefined();
117
+ expect(endpoint.versionConfig.version).toBe("2022-07-01");
118
+ expect(endpoint.versionConfig.supportLevel).toBe(version_interfaces_1.VersionSupportLevel.ACTIVE);
119
+ });
120
+ it("should provide supported versions", () => {
121
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
122
+ name: "my-inbound-endpoint",
123
+ location: "eastus",
124
+ dnsResolverId: mockDnsResolverId,
125
+ subnetId: mockSubnetId,
126
+ });
127
+ const versions = endpoint.supportedVersions();
128
+ expect(versions).toContain("2022-07-01");
129
+ expect(versions.length).toBeGreaterThan(0);
130
+ });
131
+ });
132
+ describe("Parent-Child Resource Relationship", () => {
133
+ it("should use dnsResolverId as parent ID", () => {
134
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
135
+ name: "my-inbound-endpoint",
136
+ location: "eastus",
137
+ dnsResolverId: mockDnsResolverId,
138
+ subnetId: mockSubnetId,
139
+ });
140
+ // Verify the endpoint was created successfully with proper parent
141
+ expect(endpoint).toBeDefined();
142
+ expect(endpoint.props.dnsResolverId).toBe(mockDnsResolverId);
143
+ });
144
+ it("should correctly handle child resource in Terraform synthesis", () => {
145
+ new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
146
+ name: "my-inbound-endpoint",
147
+ location: "eastus",
148
+ dnsResolverId: mockDnsResolverId,
149
+ subnetId: mockSubnetId,
150
+ });
151
+ const synthesized = cdktf_1.Testing.synth(stack);
152
+ expect(synthesized).toContain("inboundEndpoints");
153
+ expect(synthesized).toContain(mockDnsResolverId);
154
+ });
155
+ });
156
+ describe("Public Methods - Inbound Endpoint Properties", () => {
157
+ it("should provide subnet ID", () => {
158
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
159
+ name: "my-inbound-endpoint",
160
+ location: "eastus",
161
+ dnsResolverId: mockDnsResolverId,
162
+ subnetId: mockSubnetId,
163
+ });
164
+ expect(endpoint.subnetId).toBeDefined();
165
+ expect(typeof endpoint.subnetId).toBe("string");
166
+ });
167
+ it("should provide private IP address", () => {
168
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
169
+ name: "my-inbound-endpoint",
170
+ location: "eastus",
171
+ dnsResolverId: mockDnsResolverId,
172
+ subnetId: mockSubnetId,
173
+ privateIpAddress: "10.0.1.4",
174
+ });
175
+ expect(endpoint.privateIpAddress).toBeDefined();
176
+ expect(typeof endpoint.privateIpAddress).toBe("string");
177
+ });
178
+ it("should provide provisioning state", () => {
179
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
180
+ name: "my-inbound-endpoint",
181
+ location: "eastus",
182
+ dnsResolverId: mockDnsResolverId,
183
+ subnetId: mockSubnetId,
184
+ });
185
+ expect(endpoint.provisioningState).toBeDefined();
186
+ expect(typeof endpoint.provisioningState).toBe("string");
187
+ });
188
+ });
189
+ describe("Tag Management", () => {
190
+ it("should allow adding tags", () => {
191
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
192
+ name: "my-inbound-endpoint",
193
+ location: "eastus",
194
+ dnsResolverId: mockDnsResolverId,
195
+ subnetId: mockSubnetId,
196
+ tags: { initial: "tag" },
197
+ });
198
+ endpoint.addTag("newKey", "newValue");
199
+ expect(endpoint.props.tags).toHaveProperty("newKey", "newValue");
200
+ expect(endpoint.props.tags).toHaveProperty("initial", "tag");
201
+ });
202
+ it("should allow removing tags", () => {
203
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
204
+ name: "my-inbound-endpoint",
205
+ location: "eastus",
206
+ dnsResolverId: mockDnsResolverId,
207
+ subnetId: mockSubnetId,
208
+ tags: { key1: "value1", key2: "value2" },
209
+ });
210
+ endpoint.removeTag("key1");
211
+ expect(endpoint.props.tags).not.toHaveProperty("key1");
212
+ expect(endpoint.props.tags).toHaveProperty("key2", "value2");
213
+ });
214
+ it("should handle adding tags when no initial tags exist", () => {
215
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
216
+ name: "my-inbound-endpoint",
217
+ location: "eastus",
218
+ dnsResolverId: mockDnsResolverId,
219
+ subnetId: mockSubnetId,
220
+ });
221
+ endpoint.addTag("newKey", "newValue");
222
+ expect(endpoint.props.tags).toHaveProperty("newKey", "newValue");
223
+ });
224
+ });
225
+ describe("Outputs", () => {
226
+ it("should create all required outputs", () => {
227
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
228
+ name: "my-inbound-endpoint",
229
+ location: "eastus",
230
+ dnsResolverId: mockDnsResolverId,
231
+ subnetId: mockSubnetId,
232
+ });
233
+ expect(endpoint.idOutput).toBeDefined();
234
+ expect(endpoint.nameOutput).toBeDefined();
235
+ expect(endpoint.locationOutput).toBeDefined();
236
+ expect(endpoint.tagsOutput).toBeDefined();
237
+ expect(endpoint.provisioningStateOutput).toBeDefined();
238
+ });
239
+ it("should have correct logical IDs for outputs", () => {
240
+ new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
241
+ name: "my-inbound-endpoint",
242
+ location: "eastus",
243
+ dnsResolverId: mockDnsResolverId,
244
+ subnetId: mockSubnetId,
245
+ });
246
+ const synthesized = cdktf_1.Testing.synth(stack);
247
+ expect(synthesized).toContain('"id"');
248
+ expect(synthesized).toContain('"name"');
249
+ expect(synthesized).toContain('"location"');
250
+ expect(synthesized).toContain('"tags"');
251
+ expect(synthesized).toContain('"provisioning_state"');
252
+ });
253
+ });
254
+ describe("Ignore Changes Configuration", () => {
255
+ it("should apply ignore changes lifecycle rules", () => {
256
+ new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
257
+ name: "my-inbound-endpoint",
258
+ location: "eastus",
259
+ dnsResolverId: mockDnsResolverId,
260
+ subnetId: mockSubnetId,
261
+ ignoreChanges: ["tags"],
262
+ });
263
+ const synthesized = cdktf_1.Testing.synth(stack);
264
+ expect(synthesized).toContain("ignore_changes");
265
+ });
266
+ it("should handle multiple ignore changes properties", () => {
267
+ new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
268
+ name: "my-inbound-endpoint",
269
+ location: "eastus",
270
+ dnsResolverId: mockDnsResolverId,
271
+ subnetId: mockSubnetId,
272
+ ignoreChanges: ["tags", "location"],
273
+ });
274
+ const synthesized = cdktf_1.Testing.synth(stack);
275
+ expect(synthesized).toBeDefined();
276
+ });
277
+ });
278
+ describe("CDK Terraform Integration", () => {
279
+ it("should synthesize to valid Terraform configuration", () => {
280
+ new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "SynthTest", {
281
+ name: "my-inbound-endpoint",
282
+ location: "eastus",
283
+ dnsResolverId: mockDnsResolverId,
284
+ subnetId: mockSubnetId,
285
+ tags: { test: "synthesis" },
286
+ });
287
+ const synthesized = cdktf_1.Testing.synth(stack);
288
+ expect(synthesized).toBeDefined();
289
+ const stackConfig = JSON.parse(synthesized);
290
+ expect(stackConfig.resource).toBeDefined();
291
+ });
292
+ it("should generate correct resource type in Terraform", () => {
293
+ new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "SynthTest", {
294
+ name: "my-inbound-endpoint",
295
+ location: "eastus",
296
+ dnsResolverId: mockDnsResolverId,
297
+ subnetId: mockSubnetId,
298
+ });
299
+ const synthesized = cdktf_1.Testing.synth(stack);
300
+ expect(synthesized).toContain("inboundEndpoints");
301
+ expect(synthesized).toContain("2022-07-01");
302
+ });
303
+ it("should include all properties in Terraform body", () => {
304
+ new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "SynthTest", {
305
+ name: "my-inbound-endpoint",
306
+ location: "eastus",
307
+ dnsResolverId: mockDnsResolverId,
308
+ subnetId: mockSubnetId,
309
+ privateIpAddress: "10.0.1.4",
310
+ privateIpAllocationMethod: "Static",
311
+ tags: { env: "test" },
312
+ });
313
+ const synthesized = cdktf_1.Testing.synth(stack);
314
+ expect(synthesized).toContain("eastus");
315
+ expect(synthesized).toContain("env");
316
+ expect(synthesized).toContain(mockSubnetId);
317
+ });
318
+ });
319
+ describe("Resource Identification", () => {
320
+ it("should provide resource ID", () => {
321
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
322
+ name: "my-inbound-endpoint",
323
+ location: "eastus",
324
+ dnsResolverId: mockDnsResolverId,
325
+ subnetId: mockSubnetId,
326
+ });
327
+ expect(endpoint.id).toBeDefined();
328
+ expect(typeof endpoint.id).toBe("string");
329
+ });
330
+ it("should provide resource name from construct id when name not in props", () => {
331
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
332
+ location: "eastus",
333
+ dnsResolverId: mockDnsResolverId,
334
+ subnetId: mockSubnetId,
335
+ });
336
+ expect(endpoint.name).toBe("TestEndpoint");
337
+ });
338
+ it("should provide resource name from props when specified", () => {
339
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
340
+ name: "my-inbound-endpoint",
341
+ location: "eastus",
342
+ dnsResolverId: mockDnsResolverId,
343
+ subnetId: mockSubnetId,
344
+ });
345
+ expect(endpoint.name).toBe("my-inbound-endpoint");
346
+ });
347
+ });
348
+ describe("JSII Compliance", () => {
349
+ it("should have proper return types for all public methods", () => {
350
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
351
+ name: "my-inbound-endpoint",
352
+ location: "eastus",
353
+ dnsResolverId: mockDnsResolverId,
354
+ subnetId: mockSubnetId,
355
+ });
356
+ // All getter methods should return strings for Terraform interpolations
357
+ expect(typeof endpoint.subnetId).toBe("string");
358
+ expect(typeof endpoint.privateIpAddress).toBe("string");
359
+ expect(typeof endpoint.provisioningState).toBe("string");
360
+ });
361
+ it("should not use function types in public interface", () => {
362
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
363
+ name: "my-inbound-endpoint",
364
+ location: "eastus",
365
+ dnsResolverId: mockDnsResolverId,
366
+ subnetId: mockSubnetId,
367
+ });
368
+ // Verify methods exist and are callable
369
+ expect(typeof endpoint.addTag).toBe("function");
370
+ expect(typeof endpoint.removeTag).toBe("function");
371
+ // Test that they work correctly
372
+ endpoint.addTag("test", "value");
373
+ expect(endpoint.props.tags).toHaveProperty("test", "value");
374
+ });
375
+ });
376
+ describe("Schema Registration", () => {
377
+ it("should register schemas successfully", () => {
378
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
379
+ name: "my-inbound-endpoint",
380
+ location: "eastus",
381
+ dnsResolverId: mockDnsResolverId,
382
+ subnetId: mockSubnetId,
383
+ });
384
+ // If the endpoint was created successfully, schemas were registered
385
+ expect(endpoint).toBeDefined();
386
+ expect(endpoint.resolvedApiVersion).toBe("2022-07-01");
387
+ });
388
+ it("should handle multiple instantiations without errors", () => {
389
+ new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint1", {
390
+ name: "my-inbound-endpoint-1",
391
+ location: "eastus",
392
+ dnsResolverId: mockDnsResolverId,
393
+ subnetId: mockSubnetId,
394
+ });
395
+ // Second instantiation should not throw an error even if schemas are already registered
396
+ const endpoint2 = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint2", {
397
+ name: "my-inbound-endpoint-2",
398
+ location: "eastus",
399
+ dnsResolverId: mockDnsResolverId,
400
+ subnetId: mockSubnetId,
401
+ });
402
+ expect(endpoint2).toBeDefined();
403
+ });
404
+ });
405
+ describe("Property Validation", () => {
406
+ it("should handle static IP allocation correctly", () => {
407
+ const endpointStatic = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpointStatic", {
408
+ name: "my-inbound-endpoint-static",
409
+ location: "eastus",
410
+ dnsResolverId: mockDnsResolverId,
411
+ subnetId: mockSubnetId,
412
+ privateIpAddress: "10.0.1.4",
413
+ privateIpAllocationMethod: "Static",
414
+ });
415
+ expect(endpointStatic.props.privateIpAddress).toBe("10.0.1.4");
416
+ expect(endpointStatic.props.privateIpAllocationMethod).toBe("Static");
417
+ });
418
+ it("should handle dynamic IP allocation correctly", () => {
419
+ const endpointDynamic = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpointDynamic", {
420
+ name: "my-inbound-endpoint-dynamic",
421
+ location: "eastus",
422
+ dnsResolverId: mockDnsResolverId,
423
+ subnetId: mockSubnetId,
424
+ privateIpAllocationMethod: "Dynamic",
425
+ });
426
+ expect(endpointDynamic.props.privateIpAllocationMethod).toBe("Dynamic");
427
+ expect(endpointDynamic.props.privateIpAddress).toBeUndefined();
428
+ });
429
+ it("should handle IP allocation without explicit method", () => {
430
+ const endpoint = new inbound_endpoint_1.DnsResolverInboundEndpoint(stack, "TestEndpoint", {
431
+ name: "my-inbound-endpoint",
432
+ location: "eastus",
433
+ dnsResolverId: mockDnsResolverId,
434
+ subnetId: mockSubnetId,
435
+ });
436
+ // Should default to dynamic when not specified
437
+ expect(endpoint.props.privateIpAllocationMethod).toBeUndefined();
438
+ });
439
+ });
440
+ });
441
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inbound-endpoint.spec.js","sourceRoot":"","sources":["../../../src/azure-dnsresolver/test/inbound-endpoint.spec.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Comprehensive tests for the DnsResolverInboundEndpoint implementation\n *\n * This test suite validates the DnsResolverInboundEndpoint class using the\n * AzapiResource framework. Tests cover automatic version resolution,\n * explicit version pinning, schema validation, property transformation,\n * parent-child resource relationships, 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  DnsResolverInboundEndpoint,\n  DnsResolverInboundEndpointProps,\n} from \"../lib/inbound-endpoint\";\nimport {\n  ALL_DNS_RESOLVER_INBOUND_ENDPOINT_VERSIONS,\n  DNS_RESOLVER_INBOUND_ENDPOINT_TYPE,\n} from \"../lib/inbound-endpoint-schemas\";\n\ndescribe(\"DnsResolverInboundEndpoint - Implementation\", () => {\n  let app: cdktf.App;\n  let stack: cdktf.TerraformStack;\n  let manager: ApiVersionManager;\n\n  const mockDnsResolverId =\n    \"/subscriptions/12345678-1234-1234-1234-123456789012/resourceGroups/test-rg/providers/Microsoft.Network/dnsResolvers/test-resolver\";\n  const mockSubnetId =\n    \"/subscriptions/12345678-1234-1234-1234-123456789012/resourceGroups/test-rg/providers/Microsoft.Network/virtualNetworks/test-vnet/subnets/inbound-subnet\";\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_RESOLVER_INBOUND_ENDPOINT_TYPE,\n        ALL_DNS_RESOLVER_INBOUND_ENDPOINT_VERSIONS,\n      );\n    } catch (error) {\n      // Ignore if already registered\n    }\n  });\n\n  describe(\"Constructor and Basic Properties\", () => {\n    it(\"should create Inbound Endpoint with automatic latest version resolution\", () => {\n      const props: DnsResolverInboundEndpointProps = {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      };\n\n      const endpoint = new DnsResolverInboundEndpoint(\n        stack,\n        \"TestEndpoint\",\n        props,\n      );\n\n      expect(endpoint).toBeInstanceOf(DnsResolverInboundEndpoint);\n      expect(endpoint.resolvedApiVersion).toBe(\"2022-07-01\");\n      expect(endpoint.props).toBe(props);\n    });\n\n    it(\"should create Inbound Endpoint with explicit version pinning\", () => {\n      const props: DnsResolverInboundEndpointProps = {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n        apiVersion: \"2022-07-01\",\n        tags: { environment: \"test\" },\n      };\n\n      const endpoint = new DnsResolverInboundEndpoint(\n        stack,\n        \"TestEndpoint\",\n        props,\n      );\n\n      expect(endpoint.resolvedApiVersion).toBe(\"2022-07-01\");\n      expect(endpoint.tags).toEqual({ environment: \"test\" });\n    });\n\n    it(\"should use location from props\", () => {\n      const props: DnsResolverInboundEndpointProps = {\n        name: \"my-inbound-endpoint\",\n        location: \"westus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      };\n\n      const endpoint = new DnsResolverInboundEndpoint(\n        stack,\n        \"TestEndpoint\",\n        props,\n      );\n\n      expect(endpoint.location).toBe(\"westus\");\n    });\n\n    it(\"should create Inbound Endpoint with static IP address\", () => {\n      const props: DnsResolverInboundEndpointProps = {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n        privateIpAddress: \"10.0.1.4\",\n        privateIpAllocationMethod: \"Static\",\n      };\n\n      const endpoint = new DnsResolverInboundEndpoint(\n        stack,\n        \"TestEndpoint\",\n        props,\n      );\n\n      expect(endpoint).toBeDefined();\n      expect(endpoint.props.privateIpAddress).toBe(\"10.0.1.4\");\n      expect(endpoint.props.privateIpAllocationMethod).toBe(\"Static\");\n    });\n\n    it(\"should create Inbound Endpoint with dynamic IP allocation\", () => {\n      const props: DnsResolverInboundEndpointProps = {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n        privateIpAllocationMethod: \"Dynamic\",\n      };\n\n      const endpoint = new DnsResolverInboundEndpoint(\n        stack,\n        \"TestEndpoint\",\n        props,\n      );\n\n      expect(endpoint).toBeDefined();\n      expect(endpoint.props.privateIpAllocationMethod).toBe(\"Dynamic\");\n    });\n  });\n\n  describe(\"Framework Integration\", () => {\n    it(\"should resolve latest API version automatically\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      expect(endpoint.resolvedApiVersion).toBe(\"2022-07-01\");\n      expect(endpoint.latestVersion()).toBe(\"2022-07-01\");\n    });\n\n    it(\"should provide version configuration\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      expect(endpoint.versionConfig).toBeDefined();\n      expect(endpoint.versionConfig.version).toBe(\"2022-07-01\");\n      expect(endpoint.versionConfig.supportLevel).toBe(\n        VersionSupportLevel.ACTIVE,\n      );\n    });\n\n    it(\"should provide supported versions\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      const versions = endpoint.supportedVersions();\n      expect(versions).toContain(\"2022-07-01\");\n      expect(versions.length).toBeGreaterThan(0);\n    });\n  });\n\n  describe(\"Parent-Child Resource Relationship\", () => {\n    it(\"should use dnsResolverId as parent ID\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      // Verify the endpoint was created successfully with proper parent\n      expect(endpoint).toBeDefined();\n      expect(endpoint.props.dnsResolverId).toBe(mockDnsResolverId);\n    });\n\n    it(\"should correctly handle child resource in Terraform synthesis\", () => {\n      new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toContain(\"inboundEndpoints\");\n      expect(synthesized).toContain(mockDnsResolverId);\n    });\n  });\n\n  describe(\"Public Methods - Inbound Endpoint Properties\", () => {\n    it(\"should provide subnet ID\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      expect(endpoint.subnetId).toBeDefined();\n      expect(typeof endpoint.subnetId).toBe(\"string\");\n    });\n\n    it(\"should provide private IP address\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n        privateIpAddress: \"10.0.1.4\",\n      });\n\n      expect(endpoint.privateIpAddress).toBeDefined();\n      expect(typeof endpoint.privateIpAddress).toBe(\"string\");\n    });\n\n    it(\"should provide provisioning state\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      expect(endpoint.provisioningState).toBeDefined();\n      expect(typeof endpoint.provisioningState).toBe(\"string\");\n    });\n  });\n\n  describe(\"Tag Management\", () => {\n    it(\"should allow adding tags\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n        tags: { initial: \"tag\" },\n      });\n\n      endpoint.addTag(\"newKey\", \"newValue\");\n      expect(endpoint.props.tags).toHaveProperty(\"newKey\", \"newValue\");\n      expect(endpoint.props.tags).toHaveProperty(\"initial\", \"tag\");\n    });\n\n    it(\"should allow removing tags\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n        tags: { key1: \"value1\", key2: \"value2\" },\n      });\n\n      endpoint.removeTag(\"key1\");\n      expect(endpoint.props.tags).not.toHaveProperty(\"key1\");\n      expect(endpoint.props.tags).toHaveProperty(\"key2\", \"value2\");\n    });\n\n    it(\"should handle adding tags when no initial tags exist\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      endpoint.addTag(\"newKey\", \"newValue\");\n      expect(endpoint.props.tags).toHaveProperty(\"newKey\", \"newValue\");\n    });\n  });\n\n  describe(\"Outputs\", () => {\n    it(\"should create all required outputs\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      expect(endpoint.idOutput).toBeDefined();\n      expect(endpoint.nameOutput).toBeDefined();\n      expect(endpoint.locationOutput).toBeDefined();\n      expect(endpoint.tagsOutput).toBeDefined();\n      expect(endpoint.provisioningStateOutput).toBeDefined();\n    });\n\n    it(\"should have correct logical IDs for outputs\", () => {\n      new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\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    });\n  });\n\n  describe(\"Ignore Changes Configuration\", () => {\n    it(\"should apply ignore changes lifecycle rules\", () => {\n      new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\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 DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\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 DnsResolverInboundEndpoint(stack, \"SynthTest\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\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 DnsResolverInboundEndpoint(stack, \"SynthTest\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toContain(\"inboundEndpoints\");\n      expect(synthesized).toContain(\"2022-07-01\");\n    });\n\n    it(\"should include all properties in Terraform body\", () => {\n      new DnsResolverInboundEndpoint(stack, \"SynthTest\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n        privateIpAddress: \"10.0.1.4\",\n        privateIpAllocationMethod: \"Static\",\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(mockSubnetId);\n    });\n  });\n\n  describe(\"Resource Identification\", () => {\n    it(\"should provide resource ID\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      expect(endpoint.id).toBeDefined();\n      expect(typeof endpoint.id).toBe(\"string\");\n    });\n\n    it(\"should provide resource name from construct id when name not in props\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      expect(endpoint.name).toBe(\"TestEndpoint\");\n    });\n\n    it(\"should provide resource name from props when specified\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      expect(endpoint.name).toBe(\"my-inbound-endpoint\");\n    });\n  });\n\n  describe(\"JSII Compliance\", () => {\n    it(\"should have proper return types for all public methods\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      // All getter methods should return strings for Terraform interpolations\n      expect(typeof endpoint.subnetId).toBe(\"string\");\n      expect(typeof endpoint.privateIpAddress).toBe(\"string\");\n      expect(typeof endpoint.provisioningState).toBe(\"string\");\n    });\n\n    it(\"should not use function types in public interface\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      // Verify methods exist and are callable\n      expect(typeof endpoint.addTag).toBe(\"function\");\n      expect(typeof endpoint.removeTag).toBe(\"function\");\n\n      // Test that they work correctly\n      endpoint.addTag(\"test\", \"value\");\n      expect(endpoint.props.tags).toHaveProperty(\"test\", \"value\");\n    });\n  });\n\n  describe(\"Schema Registration\", () => {\n    it(\"should register schemas successfully\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      // If the endpoint was created successfully, schemas were registered\n      expect(endpoint).toBeDefined();\n      expect(endpoint.resolvedApiVersion).toBe(\"2022-07-01\");\n    });\n\n    it(\"should handle multiple instantiations without errors\", () => {\n      new DnsResolverInboundEndpoint(stack, \"TestEndpoint1\", {\n        name: \"my-inbound-endpoint-1\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      // Second instantiation should not throw an error even if schemas are already registered\n      const endpoint2 = new DnsResolverInboundEndpoint(stack, \"TestEndpoint2\", {\n        name: \"my-inbound-endpoint-2\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      expect(endpoint2).toBeDefined();\n    });\n  });\n\n  describe(\"Property Validation\", () => {\n    it(\"should handle static IP allocation correctly\", () => {\n      const endpointStatic = new DnsResolverInboundEndpoint(\n        stack,\n        \"TestEndpointStatic\",\n        {\n          name: \"my-inbound-endpoint-static\",\n          location: \"eastus\",\n          dnsResolverId: mockDnsResolverId,\n          subnetId: mockSubnetId,\n          privateIpAddress: \"10.0.1.4\",\n          privateIpAllocationMethod: \"Static\",\n        },\n      );\n\n      expect(endpointStatic.props.privateIpAddress).toBe(\"10.0.1.4\");\n      expect(endpointStatic.props.privateIpAllocationMethod).toBe(\"Static\");\n    });\n\n    it(\"should handle dynamic IP allocation correctly\", () => {\n      const endpointDynamic = new DnsResolverInboundEndpoint(\n        stack,\n        \"TestEndpointDynamic\",\n        {\n          name: \"my-inbound-endpoint-dynamic\",\n          location: \"eastus\",\n          dnsResolverId: mockDnsResolverId,\n          subnetId: mockSubnetId,\n          privateIpAllocationMethod: \"Dynamic\",\n        },\n      );\n\n      expect(endpointDynamic.props.privateIpAllocationMethod).toBe(\"Dynamic\");\n      expect(endpointDynamic.props.privateIpAddress).toBeUndefined();\n    });\n\n    it(\"should handle IP allocation without explicit method\", () => {\n      const endpoint = new DnsResolverInboundEndpoint(stack, \"TestEndpoint\", {\n        name: \"my-inbound-endpoint\",\n        location: \"eastus\",\n        dnsResolverId: mockDnsResolverId,\n        subnetId: mockSubnetId,\n      });\n\n      // Should default to dynamic when not specified\n      expect(endpoint.props.privateIpAllocationMethod).toBeUndefined();\n    });\n  });\n});\n"]}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Integration test for Azure DNS Resolver Outbound Endpoint
3
+ *
4
+ * This test demonstrates basic usage of the DnsResolverOutboundEndpoint construct
5
+ * and validates deployment, idempotency, and cleanup for child resources.
6
+ *
7
+ * Run with: npm run integration:nostream
8
+ */
9
+ import "cdktf/lib/testing/adapters/jest";