@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,946 @@
1
+ "use strict";
2
+ /**
3
+ * Comprehensive tests for the unified RoleDefinition implementation
4
+ *
5
+ * This test suite validates the unified RoleDefinition class that uses
6
+ * the VersionedAzapiResource framework. Tests cover automatic version resolution,
7
+ * explicit version pinning, schema validation, property transformation, and
8
+ * role definition-specific functionality.
9
+ */
10
+ Object.defineProperty(exports, "__esModule", { value: true });
11
+ const cdktf_1 = require("cdktf");
12
+ const cdktf = require("cdktf");
13
+ const api_version_manager_1 = require("../../core-azure/lib/version-manager/api-version-manager");
14
+ const version_interfaces_1 = require("../../core-azure/lib/version-manager/interfaces/version-interfaces");
15
+ const role_definition_1 = require("../lib/role-definition");
16
+ const role_definition_schemas_1 = require("../lib/role-definition-schemas");
17
+ describe("RoleDefinition - Unified Implementation", () => {
18
+ let app;
19
+ let stack;
20
+ let manager;
21
+ beforeEach(() => {
22
+ app = cdktf_1.Testing.app();
23
+ stack = new cdktf.TerraformStack(app, "TestStack");
24
+ manager = api_version_manager_1.ApiVersionManager.instance();
25
+ // Ensure Role Definition schemas are registered
26
+ try {
27
+ manager.registerResourceType(role_definition_schemas_1.ROLE_DEFINITION_TYPE, role_definition_schemas_1.ALL_ROLE_DEFINITION_VERSIONS);
28
+ }
29
+ catch (error) {
30
+ // Ignore if already registered
31
+ }
32
+ });
33
+ describe("Constructor and Basic Properties", () => {
34
+ it("should create role definition with automatic latest version resolution", () => {
35
+ const props = {
36
+ name: "test-role",
37
+ roleName: "Test Role",
38
+ permissions: [
39
+ {
40
+ actions: ["Microsoft.Compute/virtualMachines/read"],
41
+ notActions: [],
42
+ dataActions: [],
43
+ notDataActions: [],
44
+ },
45
+ ],
46
+ assignableScopes: [
47
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
48
+ ],
49
+ };
50
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "TestRole", props);
51
+ expect(roleDefinition).toBeInstanceOf(role_definition_1.RoleDefinition);
52
+ expect(roleDefinition.resolvedApiVersion).toBe("2022-04-01"); // Latest version
53
+ expect(roleDefinition.props).toBe(props);
54
+ // Name is a deterministic UUID based on roleName and assignableScopes
55
+ expect(roleDefinition.name).toMatch(/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/);
56
+ });
57
+ it("should create role definition with explicit version pinning", () => {
58
+ const props = {
59
+ name: "test-role-pinned",
60
+ apiVersion: "2022-04-01",
61
+ roleName: "Test Role Pinned",
62
+ permissions: [
63
+ {
64
+ actions: ["Microsoft.Storage/storageAccounts/read"],
65
+ },
66
+ ],
67
+ assignableScopes: [
68
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
69
+ ],
70
+ };
71
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "TestRole", props);
72
+ expect(roleDefinition.resolvedApiVersion).toBe("2022-04-01");
73
+ });
74
+ it("should create role definition with all optional properties", () => {
75
+ const props = {
76
+ name: "test-role-full",
77
+ roleName: "Test Role Full",
78
+ description: "A comprehensive test role for unit testing",
79
+ type: "CustomRole",
80
+ permissions: [
81
+ {
82
+ actions: [
83
+ "Microsoft.Compute/virtualMachines/read",
84
+ "Microsoft.Compute/virtualMachines/start/action",
85
+ ],
86
+ notActions: ["Microsoft.Compute/virtualMachines/delete"],
87
+ dataActions: [
88
+ "Microsoft.Storage/storageAccounts/blobServices/containers/blobs/read",
89
+ ],
90
+ notDataActions: [],
91
+ },
92
+ ],
93
+ assignableScopes: [
94
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
95
+ "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test-rg",
96
+ ],
97
+ ignoreChanges: ["description"],
98
+ enableValidation: true,
99
+ enableMigrationAnalysis: true,
100
+ enableTransformation: true,
101
+ };
102
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "TestRole", props);
103
+ expect(roleDefinition.props.roleName).toBe("Test Role Full");
104
+ expect(roleDefinition.props.description).toBe("A comprehensive test role for unit testing");
105
+ expect(roleDefinition.props.type).toBe("CustomRole");
106
+ expect(roleDefinition.props.permissions).toBeDefined();
107
+ expect(roleDefinition.props.assignableScopes).toHaveLength(2);
108
+ });
109
+ it("should generate deterministic UUID name when name is not provided", () => {
110
+ const props = {
111
+ roleName: "Test Role",
112
+ permissions: [
113
+ {
114
+ actions: ["Microsoft.Resources/subscriptions/read"],
115
+ },
116
+ ],
117
+ assignableScopes: [
118
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
119
+ ],
120
+ };
121
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "TestRole", props);
122
+ // Name is a deterministic UUID, not the construct ID
123
+ expect(roleDefinition.name).toMatch(/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/);
124
+ });
125
+ it("should require roleName to be provided", () => {
126
+ const props = {
127
+ name: "test-role",
128
+ permissions: [
129
+ {
130
+ actions: ["Microsoft.Resources/subscriptions/read"],
131
+ },
132
+ ],
133
+ assignableScopes: [
134
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
135
+ ],
136
+ };
137
+ expect(() => {
138
+ new role_definition_1.RoleDefinition(stack, "TestRole", props);
139
+ }).toThrow("Required property 'roleName' is missing");
140
+ });
141
+ it("should require permissions to be provided", () => {
142
+ const props = {
143
+ name: "test-role",
144
+ roleName: "Test Role",
145
+ assignableScopes: [
146
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
147
+ ],
148
+ };
149
+ expect(() => {
150
+ new role_definition_1.RoleDefinition(stack, "TestRole", props);
151
+ }).toThrow("Required property 'permissions' is missing");
152
+ });
153
+ it("should require assignableScopes to be provided", () => {
154
+ const props = {
155
+ name: "test-role",
156
+ roleName: "Test Role",
157
+ permissions: [
158
+ {
159
+ actions: ["Microsoft.Resources/subscriptions/read"],
160
+ },
161
+ ],
162
+ };
163
+ expect(() => {
164
+ new role_definition_1.RoleDefinition(stack, "TestRole", props);
165
+ }).toThrow("Required property 'assignableScopes' is missing");
166
+ });
167
+ });
168
+ describe("Framework Integration", () => {
169
+ it("should resolve latest API version automatically", () => {
170
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "TestRole", {
171
+ name: "test-role",
172
+ roleName: "Test Role",
173
+ permissions: [
174
+ {
175
+ actions: ["Microsoft.Resources/subscriptions/read"],
176
+ },
177
+ ],
178
+ assignableScopes: [
179
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
180
+ ],
181
+ });
182
+ expect(roleDefinition.resolvedApiVersion).toBe("2022-04-01");
183
+ expect(roleDefinition.latestVersion()).toBe("2022-04-01");
184
+ });
185
+ it("should support all registered API versions", () => {
186
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "TestRole", {
187
+ name: "test-role",
188
+ roleName: "Test Role",
189
+ permissions: [
190
+ {
191
+ actions: ["Microsoft.Resources/subscriptions/read"],
192
+ },
193
+ ],
194
+ assignableScopes: [
195
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
196
+ ],
197
+ });
198
+ const supportedVersions = roleDefinition.supportedVersions();
199
+ expect(supportedVersions).toContain("2022-04-01");
200
+ });
201
+ it("should validate version support", () => {
202
+ // Valid version
203
+ expect(() => {
204
+ new role_definition_1.RoleDefinition(stack, "ValidVersion", {
205
+ name: "test-role",
206
+ roleName: "Test Role",
207
+ permissions: [
208
+ {
209
+ actions: ["Microsoft.Resources/subscriptions/read"],
210
+ },
211
+ ],
212
+ assignableScopes: [
213
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
214
+ ],
215
+ apiVersion: "2022-04-01",
216
+ });
217
+ }).not.toThrow();
218
+ // Invalid version
219
+ expect(() => {
220
+ new role_definition_1.RoleDefinition(stack, "InvalidVersion", {
221
+ name: "test-role",
222
+ roleName: "Test Role",
223
+ permissions: [
224
+ {
225
+ actions: ["Microsoft.Resources/subscriptions/read"],
226
+ },
227
+ ],
228
+ assignableScopes: [
229
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
230
+ ],
231
+ apiVersion: "2020-01-01",
232
+ });
233
+ }).toThrow("Unsupported API version '2020-01-01'");
234
+ });
235
+ it("should load correct schema for resolved version", () => {
236
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "TestRole", {
237
+ name: "test-role",
238
+ roleName: "Test Role",
239
+ permissions: [
240
+ {
241
+ actions: ["Microsoft.Resources/subscriptions/read"],
242
+ },
243
+ ],
244
+ assignableScopes: [
245
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
246
+ ],
247
+ apiVersion: "2022-04-01",
248
+ });
249
+ expect(roleDefinition.schema).toBeDefined();
250
+ expect(roleDefinition.schema.resourceType).toBe(role_definition_schemas_1.ROLE_DEFINITION_TYPE);
251
+ expect(roleDefinition.schema.version).toBe("2022-04-01");
252
+ expect(roleDefinition.schema.properties).toBeDefined();
253
+ });
254
+ it("should load version configuration correctly", () => {
255
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "TestRole", {
256
+ name: "test-role",
257
+ roleName: "Test Role",
258
+ permissions: [
259
+ {
260
+ actions: ["Microsoft.Resources/subscriptions/read"],
261
+ },
262
+ ],
263
+ assignableScopes: [
264
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
265
+ ],
266
+ });
267
+ expect(roleDefinition.versionConfig).toBeDefined();
268
+ expect(roleDefinition.versionConfig.version).toBe("2022-04-01");
269
+ expect(roleDefinition.versionConfig.supportLevel).toBe(version_interfaces_1.VersionSupportLevel.ACTIVE);
270
+ });
271
+ });
272
+ describe("Property Validation", () => {
273
+ it("should validate properties when validation is enabled", () => {
274
+ const props = {
275
+ name: "test-role",
276
+ roleName: "Test Role",
277
+ permissions: [
278
+ {
279
+ actions: ["Microsoft.Resources/subscriptions/read"],
280
+ },
281
+ ],
282
+ assignableScopes: [
283
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
284
+ ],
285
+ enableValidation: true,
286
+ };
287
+ expect(() => {
288
+ new role_definition_1.RoleDefinition(stack, "TestRole", props);
289
+ }).not.toThrow();
290
+ });
291
+ it("should have validation results for valid properties", () => {
292
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "TestRole", {
293
+ name: "valid-role",
294
+ roleName: "Valid Role",
295
+ description: "A valid role definition",
296
+ permissions: [
297
+ {
298
+ actions: ["Microsoft.Resources/subscriptions/read"],
299
+ },
300
+ ],
301
+ assignableScopes: [
302
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
303
+ ],
304
+ enableValidation: true,
305
+ });
306
+ expect(roleDefinition.validationResult).toBeDefined();
307
+ expect(roleDefinition.validationResult.valid).toBe(true);
308
+ expect(roleDefinition.validationResult.errors).toHaveLength(0);
309
+ });
310
+ it("should skip validation when disabled", () => {
311
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "TestRole", {
312
+ name: "test-role",
313
+ roleName: "Test Role",
314
+ permissions: [
315
+ {
316
+ actions: ["Microsoft.Resources/subscriptions/read"],
317
+ },
318
+ ],
319
+ assignableScopes: [
320
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
321
+ ],
322
+ enableValidation: false,
323
+ });
324
+ expect(roleDefinition).toBeDefined();
325
+ });
326
+ });
327
+ describe("Migration Analysis", () => {
328
+ it("should skip migration analysis for single version", () => {
329
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "TestRole", {
330
+ name: "test-role",
331
+ roleName: "Test Role",
332
+ permissions: [
333
+ {
334
+ actions: ["Microsoft.Resources/subscriptions/read"],
335
+ },
336
+ ],
337
+ assignableScopes: [
338
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
339
+ ],
340
+ apiVersion: "2022-04-01",
341
+ });
342
+ // Since there's only one version, migration analysis should be skipped
343
+ expect(roleDefinition).toBeDefined();
344
+ });
345
+ it("should skip migration analysis when disabled", () => {
346
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "TestRole", {
347
+ name: "test-role",
348
+ roleName: "Test Role",
349
+ permissions: [
350
+ {
351
+ actions: ["Microsoft.Resources/subscriptions/read"],
352
+ },
353
+ ],
354
+ assignableScopes: [
355
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
356
+ ],
357
+ enableMigrationAnalysis: false,
358
+ });
359
+ expect(roleDefinition.migrationAnalysis).toBeUndefined();
360
+ });
361
+ });
362
+ describe("Resource Creation and Body", () => {
363
+ it("should create correct resource body with minimal properties", () => {
364
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "TestRole", {
365
+ name: "test-role",
366
+ roleName: "Test Role",
367
+ permissions: [
368
+ {
369
+ actions: ["Microsoft.Resources/subscriptions/read"],
370
+ },
371
+ ],
372
+ assignableScopes: [
373
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
374
+ ],
375
+ });
376
+ expect(roleDefinition).toBeDefined();
377
+ expect(roleDefinition.props.roleName).toBeDefined();
378
+ expect(roleDefinition.props.permissions).toBeDefined();
379
+ expect(roleDefinition.props.assignableScopes).toBeDefined();
380
+ });
381
+ it("should create correct resource body with all properties", () => {
382
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "TestRole", {
383
+ name: "test-role",
384
+ roleName: "Test Role",
385
+ description: "A test role definition",
386
+ type: "CustomRole",
387
+ permissions: [
388
+ {
389
+ actions: ["Microsoft.Compute/virtualMachines/read"],
390
+ notActions: ["Microsoft.Compute/virtualMachines/delete"],
391
+ dataActions: [
392
+ "Microsoft.Storage/storageAccounts/blobServices/containers/blobs/read",
393
+ ],
394
+ notDataActions: [],
395
+ },
396
+ ],
397
+ assignableScopes: [
398
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
399
+ "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test-rg",
400
+ ],
401
+ });
402
+ expect(roleDefinition).toBeDefined();
403
+ expect(roleDefinition.props.roleName).toBe("Test Role");
404
+ expect(roleDefinition.props.description).toBe("A test role definition");
405
+ expect(roleDefinition.props.type).toBe("CustomRole");
406
+ });
407
+ it("should create Terraform outputs", () => {
408
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "TestRole", {
409
+ name: "test-role-outputs",
410
+ roleName: "Test Role",
411
+ permissions: [
412
+ {
413
+ actions: ["Microsoft.Resources/subscriptions/read"],
414
+ },
415
+ ],
416
+ assignableScopes: [
417
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
418
+ ],
419
+ });
420
+ expect(roleDefinition.idOutput).toBeInstanceOf(cdktf.TerraformOutput);
421
+ expect(roleDefinition.nameOutput).toBeInstanceOf(cdktf.TerraformOutput);
422
+ });
423
+ });
424
+ describe("Permissions Configuration", () => {
425
+ it("should support control plane actions", () => {
426
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "ControlPlaneRole", {
427
+ name: "control-plane-role",
428
+ roleName: "Control Plane Role",
429
+ permissions: [
430
+ {
431
+ actions: [
432
+ "Microsoft.Compute/virtualMachines/read",
433
+ "Microsoft.Compute/virtualMachines/start/action",
434
+ "Microsoft.Compute/virtualMachines/restart/action",
435
+ ],
436
+ },
437
+ ],
438
+ assignableScopes: [
439
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
440
+ ],
441
+ });
442
+ expect(roleDefinition.props.permissions[0].actions).toHaveLength(3);
443
+ });
444
+ it("should support control plane notActions", () => {
445
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "NotActionsRole", {
446
+ name: "not-actions-role",
447
+ roleName: "Not Actions Role",
448
+ permissions: [
449
+ {
450
+ actions: ["Microsoft.Compute/virtualMachines/*"],
451
+ notActions: [
452
+ "Microsoft.Compute/virtualMachines/delete",
453
+ "Microsoft.Compute/virtualMachines/write",
454
+ ],
455
+ },
456
+ ],
457
+ assignableScopes: [
458
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
459
+ ],
460
+ });
461
+ expect(roleDefinition.props.permissions[0].notActions).toHaveLength(2);
462
+ });
463
+ it("should support data plane actions", () => {
464
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "DataPlaneRole", {
465
+ name: "data-plane-role",
466
+ roleName: "Data Plane Role",
467
+ permissions: [
468
+ {
469
+ actions: ["Microsoft.Storage/storageAccounts/read"],
470
+ dataActions: [
471
+ "Microsoft.Storage/storageAccounts/blobServices/containers/blobs/read",
472
+ "Microsoft.Storage/storageAccounts/blobServices/containers/blobs/write",
473
+ ],
474
+ },
475
+ ],
476
+ assignableScopes: [
477
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
478
+ ],
479
+ });
480
+ expect(roleDefinition.props.permissions[0].dataActions).toHaveLength(2);
481
+ });
482
+ it("should support data plane notDataActions", () => {
483
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "NotDataActionsRole", {
484
+ name: "not-data-actions-role",
485
+ roleName: "Not Data Actions Role",
486
+ permissions: [
487
+ {
488
+ dataActions: [
489
+ "Microsoft.Storage/storageAccounts/blobServices/containers/blobs/*",
490
+ ],
491
+ notDataActions: [
492
+ "Microsoft.Storage/storageAccounts/blobServices/containers/blobs/delete",
493
+ ],
494
+ },
495
+ ],
496
+ assignableScopes: [
497
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
498
+ ],
499
+ });
500
+ expect(roleDefinition.props.permissions[0].notDataActions).toHaveLength(1);
501
+ });
502
+ it("should support complex permission combinations", () => {
503
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "ComplexPermissions", {
504
+ name: "complex-permissions",
505
+ roleName: "Complex Permissions Role",
506
+ permissions: [
507
+ {
508
+ actions: ["Microsoft.Compute/virtualMachines/*"],
509
+ notActions: ["Microsoft.Compute/virtualMachines/delete"],
510
+ dataActions: [
511
+ "Microsoft.Storage/storageAccounts/blobServices/containers/blobs/*",
512
+ ],
513
+ notDataActions: [
514
+ "Microsoft.Storage/storageAccounts/blobServices/containers/blobs/delete",
515
+ ],
516
+ },
517
+ ],
518
+ assignableScopes: [
519
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
520
+ ],
521
+ });
522
+ expect(roleDefinition.props.permissions[0].actions).toBeDefined();
523
+ expect(roleDefinition.props.permissions[0].notActions).toBeDefined();
524
+ expect(roleDefinition.props.permissions[0].dataActions).toBeDefined();
525
+ expect(roleDefinition.props.permissions[0].notDataActions).toBeDefined();
526
+ });
527
+ it("should support multiple permission objects", () => {
528
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "MultiplePermissions", {
529
+ name: "multiple-permissions",
530
+ roleName: "Multiple Permissions Role",
531
+ permissions: [
532
+ {
533
+ actions: ["Microsoft.Compute/virtualMachines/read"],
534
+ },
535
+ {
536
+ actions: ["Microsoft.Storage/storageAccounts/read"],
537
+ },
538
+ {
539
+ dataActions: [
540
+ "Microsoft.Storage/storageAccounts/blobServices/containers/blobs/read",
541
+ ],
542
+ },
543
+ ],
544
+ assignableScopes: [
545
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
546
+ ],
547
+ });
548
+ expect(roleDefinition.props.permissions).toHaveLength(3);
549
+ });
550
+ });
551
+ describe("Assignable Scopes Configuration", () => {
552
+ it("should support subscription scope", () => {
553
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "SubscriptionScope", {
554
+ name: "subscription-role",
555
+ roleName: "Subscription Role",
556
+ permissions: [
557
+ {
558
+ actions: ["Microsoft.Resources/subscriptions/read"],
559
+ },
560
+ ],
561
+ assignableScopes: [
562
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
563
+ ],
564
+ });
565
+ expect(roleDefinition.props.assignableScopes[0]).toContain("/subscriptions/");
566
+ });
567
+ it("should support resource group scope", () => {
568
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "ResourceGroupScope", {
569
+ name: "rg-role",
570
+ roleName: "Resource Group Role",
571
+ permissions: [
572
+ {
573
+ actions: ["Microsoft.Resources/subscriptions/resourceGroups/read"],
574
+ },
575
+ ],
576
+ assignableScopes: [
577
+ "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test-rg",
578
+ ],
579
+ });
580
+ expect(roleDefinition.props.assignableScopes[0]).toContain("/resourceGroups/");
581
+ });
582
+ it("should support management group scope", () => {
583
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "ManagementGroupScope", {
584
+ name: "mg-role",
585
+ roleName: "Management Group Role",
586
+ permissions: [
587
+ {
588
+ actions: ["Microsoft.Resources/subscriptions/read"],
589
+ },
590
+ ],
591
+ assignableScopes: [
592
+ "/providers/Microsoft.Management/managementGroups/test-mg",
593
+ ],
594
+ });
595
+ expect(roleDefinition.props.assignableScopes[0]).toContain("/managementGroups/");
596
+ });
597
+ it("should support multiple assignable scopes", () => {
598
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "MultipleScopes", {
599
+ name: "multiple-scopes-role",
600
+ roleName: "Multiple Scopes Role",
601
+ permissions: [
602
+ {
603
+ actions: ["Microsoft.Resources/subscriptions/read"],
604
+ },
605
+ ],
606
+ assignableScopes: [
607
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
608
+ "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg1",
609
+ "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg2",
610
+ ],
611
+ });
612
+ expect(roleDefinition.props.assignableScopes).toHaveLength(3);
613
+ });
614
+ });
615
+ describe("Role Types", () => {
616
+ it("should default to CustomRole type", () => {
617
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "DefaultType", {
618
+ name: "default-type-role",
619
+ roleName: "Default Type Role",
620
+ permissions: [
621
+ {
622
+ actions: ["Microsoft.Resources/subscriptions/read"],
623
+ },
624
+ ],
625
+ assignableScopes: [
626
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
627
+ ],
628
+ });
629
+ expect(roleDefinition.roleType).toBe("CustomRole");
630
+ });
631
+ it("should support explicit CustomRole type", () => {
632
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "CustomType", {
633
+ name: "custom-type-role",
634
+ roleName: "Custom Type Role",
635
+ type: "CustomRole",
636
+ permissions: [
637
+ {
638
+ actions: ["Microsoft.Resources/subscriptions/read"],
639
+ },
640
+ ],
641
+ assignableScopes: [
642
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
643
+ ],
644
+ });
645
+ expect(roleDefinition.roleType).toBe("CustomRole");
646
+ });
647
+ it("should support BuiltInRole type", () => {
648
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "BuiltInType", {
649
+ name: "builtin-type-role",
650
+ roleName: "Built-In Type Role",
651
+ type: "BuiltInRole",
652
+ permissions: [
653
+ {
654
+ actions: ["Microsoft.Resources/subscriptions/read"],
655
+ },
656
+ ],
657
+ assignableScopes: [
658
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
659
+ ],
660
+ });
661
+ expect(roleDefinition.roleType).toBe("BuiltInRole");
662
+ });
663
+ });
664
+ describe("Public Methods and Properties", () => {
665
+ let roleDefinition;
666
+ beforeEach(() => {
667
+ roleDefinition = new role_definition_1.RoleDefinition(stack, "TestRole", {
668
+ name: "test-role",
669
+ roleName: "Test Role",
670
+ description: "A test role",
671
+ permissions: [
672
+ {
673
+ actions: ["Microsoft.Compute/virtualMachines/read"],
674
+ },
675
+ ],
676
+ assignableScopes: [
677
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
678
+ ],
679
+ });
680
+ });
681
+ it("should have correct id format", () => {
682
+ expect(roleDefinition.id).toMatch(/^\$\{.*\.id\}$/);
683
+ });
684
+ it("should have resourceId property matching id", () => {
685
+ expect(roleDefinition.resourceId).toBe(roleDefinition.id);
686
+ });
687
+ it("should return correct roleName", () => {
688
+ expect(roleDefinition.roleName).toBe("Test Role");
689
+ });
690
+ it("should return correct roleType", () => {
691
+ expect(roleDefinition.roleType).toBe("CustomRole");
692
+ });
693
+ });
694
+ describe("Ignore Changes Configuration", () => {
695
+ it("should apply ignore changes lifecycle rules", () => {
696
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "IgnoreChanges", {
697
+ name: "ignore-changes-role",
698
+ roleName: "Ignore Changes Role",
699
+ permissions: [
700
+ {
701
+ actions: ["Microsoft.Resources/subscriptions/read"],
702
+ },
703
+ ],
704
+ assignableScopes: [
705
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
706
+ ],
707
+ ignoreChanges: ["description"],
708
+ });
709
+ expect(roleDefinition).toBeInstanceOf(role_definition_1.RoleDefinition);
710
+ });
711
+ it("should handle empty ignore changes array", () => {
712
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "EmptyIgnore", {
713
+ name: "empty-ignore-role",
714
+ roleName: "Empty Ignore Role",
715
+ permissions: [
716
+ {
717
+ actions: ["Microsoft.Resources/subscriptions/read"],
718
+ },
719
+ ],
720
+ assignableScopes: [
721
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
722
+ ],
723
+ ignoreChanges: [],
724
+ });
725
+ expect(roleDefinition).toBeInstanceOf(role_definition_1.RoleDefinition);
726
+ });
727
+ });
728
+ describe("Error Handling", () => {
729
+ it("should handle invalid API versions gracefully", () => {
730
+ expect(() => {
731
+ new role_definition_1.RoleDefinition(stack, "InvalidAPI", {
732
+ name: "invalid-api-role",
733
+ roleName: "Invalid API Role",
734
+ permissions: [
735
+ {
736
+ actions: ["Microsoft.Resources/subscriptions/read"],
737
+ },
738
+ ],
739
+ assignableScopes: [
740
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
741
+ ],
742
+ apiVersion: "invalid-version",
743
+ });
744
+ }).toThrow("Unsupported API version 'invalid-version'");
745
+ });
746
+ it("should validate properties when validation is enabled", () => {
747
+ // Role definitions generate deterministic UUIDs for names, so name validation
748
+ // doesn't apply the same way. Test that valid role definitions pass validation.
749
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "ValidationTest", {
750
+ name: "test-role", // This is ignored in favor of generated UUID
751
+ roleName: "Test Role",
752
+ permissions: [
753
+ {
754
+ actions: ["Microsoft.Resources/subscriptions/read"],
755
+ },
756
+ ],
757
+ assignableScopes: [
758
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
759
+ ],
760
+ enableValidation: true,
761
+ });
762
+ expect(roleDefinition.validationResult).toBeDefined();
763
+ expect(roleDefinition.validationResult.valid).toBe(true);
764
+ });
765
+ it("should handle schema registration errors gracefully", () => {
766
+ expect(() => {
767
+ new role_definition_1.RoleDefinition(stack, "SchemaTest", {
768
+ name: "schema-test-role",
769
+ roleName: "Schema Test Role",
770
+ permissions: [
771
+ {
772
+ actions: ["Microsoft.Resources/subscriptions/read"],
773
+ },
774
+ ],
775
+ assignableScopes: [
776
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
777
+ ],
778
+ });
779
+ }).not.toThrow();
780
+ });
781
+ });
782
+ describe("JSII Compliance", () => {
783
+ it("should have JSII-compliant constructor", () => {
784
+ expect(() => {
785
+ new role_definition_1.RoleDefinition(stack, "JsiiTest", {
786
+ name: "jsii-test",
787
+ roleName: "JSII Test Role",
788
+ permissions: [
789
+ {
790
+ actions: ["Microsoft.Resources/subscriptions/read"],
791
+ },
792
+ ],
793
+ assignableScopes: [
794
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
795
+ ],
796
+ });
797
+ }).not.toThrow();
798
+ });
799
+ it("should have JSII-compliant properties", () => {
800
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "JsiiProps", {
801
+ name: "jsii-props",
802
+ roleName: "JSII Props Role",
803
+ permissions: [
804
+ {
805
+ actions: ["Microsoft.Resources/subscriptions/read"],
806
+ },
807
+ ],
808
+ assignableScopes: [
809
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
810
+ ],
811
+ });
812
+ expect(typeof roleDefinition.id).toBe("string");
813
+ expect(typeof roleDefinition.name).toBe("string");
814
+ expect(typeof roleDefinition.resolvedApiVersion).toBe("string");
815
+ expect(typeof roleDefinition.roleName).toBe("string");
816
+ expect(typeof roleDefinition.roleType).toBe("string");
817
+ });
818
+ it("should have JSII-compliant methods", () => {
819
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "JsiiMethods", {
820
+ name: "jsii-methods",
821
+ roleName: "JSII Methods Role",
822
+ permissions: [
823
+ {
824
+ actions: ["Microsoft.Resources/subscriptions/read"],
825
+ },
826
+ ],
827
+ assignableScopes: [
828
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
829
+ ],
830
+ });
831
+ expect(typeof roleDefinition.latestVersion).toBe("function");
832
+ expect(typeof roleDefinition.supportedVersions).toBe("function");
833
+ });
834
+ it("should serialize complex objects correctly", () => {
835
+ const roleDefinition = new role_definition_1.RoleDefinition(stack, "JsiiSerialization", {
836
+ name: "jsii-serialization",
837
+ roleName: "JSII Serialization Role",
838
+ permissions: [
839
+ {
840
+ actions: ["Microsoft.Compute/virtualMachines/read"],
841
+ notActions: ["Microsoft.Compute/virtualMachines/delete"],
842
+ },
843
+ ],
844
+ assignableScopes: [
845
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
846
+ ],
847
+ });
848
+ expect(() => JSON.stringify(roleDefinition.validationResult)).not.toThrow();
849
+ expect(() => JSON.stringify(roleDefinition.schema)).not.toThrow();
850
+ expect(() => JSON.stringify(roleDefinition.versionConfig)).not.toThrow();
851
+ });
852
+ });
853
+ describe("CDK Terraform Integration", () => {
854
+ it("should synthesize to valid Terraform configuration", () => {
855
+ new role_definition_1.RoleDefinition(stack, "SynthTest", {
856
+ name: "synth-test",
857
+ roleName: "Synth Test Role",
858
+ permissions: [
859
+ {
860
+ actions: ["Microsoft.Resources/subscriptions/read"],
861
+ },
862
+ ],
863
+ assignableScopes: [
864
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
865
+ ],
866
+ });
867
+ const synthesized = cdktf_1.Testing.synth(stack);
868
+ expect(synthesized).toBeDefined();
869
+ const stackConfig = JSON.parse(synthesized);
870
+ expect(stackConfig.resource).toBeDefined();
871
+ });
872
+ it("should work in complex CDK constructs", () => {
873
+ class ComplexConstruct extends cdktf.TerraformStack {
874
+ constructor(scope, id) {
875
+ super(scope, id);
876
+ const role1 = new role_definition_1.RoleDefinition(this, "Role1", {
877
+ name: "role-1",
878
+ roleName: "First Role",
879
+ permissions: [
880
+ {
881
+ actions: ["Microsoft.Compute/virtualMachines/read"],
882
+ },
883
+ ],
884
+ assignableScopes: [
885
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
886
+ ],
887
+ });
888
+ const role2 = new role_definition_1.RoleDefinition(this, "Role2", {
889
+ name: "role-2",
890
+ roleName: "Second Role",
891
+ permissions: [
892
+ {
893
+ actions: ["Microsoft.Storage/storageAccounts/read"],
894
+ },
895
+ ],
896
+ assignableScopes: [
897
+ "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test-rg",
898
+ ],
899
+ apiVersion: "2022-04-01",
900
+ });
901
+ new cdktf.TerraformOutput(this, "Role1Id", {
902
+ value: role1.id,
903
+ });
904
+ new cdktf.TerraformOutput(this, "Role2Id", {
905
+ value: role2.id,
906
+ });
907
+ }
908
+ }
909
+ expect(() => {
910
+ new ComplexConstruct(app, "ComplexStack");
911
+ }).not.toThrow();
912
+ });
913
+ it("should handle multiple role definitions in the same stack", () => {
914
+ const role1 = new role_definition_1.RoleDefinition(stack, "Role1", {
915
+ name: "role-1",
916
+ roleName: "First Role",
917
+ permissions: [
918
+ {
919
+ actions: ["Microsoft.Compute/virtualMachines/read"],
920
+ },
921
+ ],
922
+ assignableScopes: [
923
+ "/subscriptions/00000000-0000-0000-0000-000000000000",
924
+ ],
925
+ });
926
+ const role2 = new role_definition_1.RoleDefinition(stack, "Role2", {
927
+ name: "role-2",
928
+ roleName: "Second Role",
929
+ permissions: [
930
+ {
931
+ actions: ["Microsoft.Storage/storageAccounts/read"],
932
+ },
933
+ ],
934
+ assignableScopes: [
935
+ "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test-rg",
936
+ ],
937
+ apiVersion: "2022-04-01",
938
+ });
939
+ expect(role1.resolvedApiVersion).toBe("2022-04-01");
940
+ expect(role2.resolvedApiVersion).toBe("2022-04-01");
941
+ const synthesized = cdktf_1.Testing.synth(stack);
942
+ expect(synthesized).toBeDefined();
943
+ });
944
+ });
945
+ });
946
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role-definition.spec.js","sourceRoot":"","sources":["../../../src/azure-roledefinition/test/role-definition.spec.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Comprehensive tests for the unified RoleDefinition implementation\n *\n * This test suite validates the unified RoleDefinition class that uses\n * the VersionedAzapiResource framework. Tests cover automatic version resolution,\n * explicit version pinning, schema validation, property transformation, and\n * role definition-specific functionality.\n */\n\nimport { Testing } from \"cdktf\";\nimport * as cdktf from \"cdktf\";\nimport { ApiVersionManager } from \"../../core-azure/lib/version-manager/api-version-manager\";\nimport { VersionSupportLevel } from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\nimport { RoleDefinition, RoleDefinitionProps } from \"../lib/role-definition\";\nimport {\n  ALL_ROLE_DEFINITION_VERSIONS,\n  ROLE_DEFINITION_TYPE,\n} from \"../lib/role-definition-schemas\";\n\ndescribe(\"RoleDefinition - Unified Implementation\", () => {\n  let app: cdktf.App;\n  let stack: cdktf.TerraformStack;\n  let manager: ApiVersionManager;\n\n  beforeEach(() => {\n    app = Testing.app();\n    stack = new cdktf.TerraformStack(app, \"TestStack\");\n    manager = ApiVersionManager.instance();\n\n    // Ensure Role Definition schemas are registered\n    try {\n      manager.registerResourceType(\n        ROLE_DEFINITION_TYPE,\n        ALL_ROLE_DEFINITION_VERSIONS,\n      );\n    } catch (error) {\n      // Ignore if already registered\n    }\n  });\n\n  describe(\"Constructor and Basic Properties\", () => {\n    it(\"should create role definition with automatic latest version resolution\", () => {\n      const props: RoleDefinitionProps = {\n        name: \"test-role\",\n        roleName: \"Test Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Compute/virtualMachines/read\"],\n            notActions: [],\n            dataActions: [],\n            notDataActions: [],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      };\n\n      const roleDefinition = new RoleDefinition(stack, \"TestRole\", props);\n\n      expect(roleDefinition).toBeInstanceOf(RoleDefinition);\n      expect(roleDefinition.resolvedApiVersion).toBe(\"2022-04-01\"); // Latest version\n      expect(roleDefinition.props).toBe(props);\n      // Name is a deterministic UUID based on roleName and assignableScopes\n      expect(roleDefinition.name).toMatch(\n        /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/,\n      );\n    });\n\n    it(\"should create role definition with explicit version pinning\", () => {\n      const props: RoleDefinitionProps = {\n        name: \"test-role-pinned\",\n        apiVersion: \"2022-04-01\",\n        roleName: \"Test Role Pinned\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Storage/storageAccounts/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      };\n\n      const roleDefinition = new RoleDefinition(stack, \"TestRole\", props);\n\n      expect(roleDefinition.resolvedApiVersion).toBe(\"2022-04-01\");\n    });\n\n    it(\"should create role definition with all optional properties\", () => {\n      const props: RoleDefinitionProps = {\n        name: \"test-role-full\",\n        roleName: \"Test Role Full\",\n        description: \"A comprehensive test role for unit testing\",\n        type: \"CustomRole\",\n        permissions: [\n          {\n            actions: [\n              \"Microsoft.Compute/virtualMachines/read\",\n              \"Microsoft.Compute/virtualMachines/start/action\",\n            ],\n            notActions: [\"Microsoft.Compute/virtualMachines/delete\"],\n            dataActions: [\n              \"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/read\",\n            ],\n            notDataActions: [],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n          \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test-rg\",\n        ],\n        ignoreChanges: [\"description\"],\n        enableValidation: true,\n        enableMigrationAnalysis: true,\n        enableTransformation: true,\n      };\n\n      const roleDefinition = new RoleDefinition(stack, \"TestRole\", props);\n\n      expect(roleDefinition.props.roleName).toBe(\"Test Role Full\");\n      expect(roleDefinition.props.description).toBe(\n        \"A comprehensive test role for unit testing\",\n      );\n      expect(roleDefinition.props.type).toBe(\"CustomRole\");\n      expect(roleDefinition.props.permissions).toBeDefined();\n      expect(roleDefinition.props.assignableScopes).toHaveLength(2);\n    });\n\n    it(\"should generate deterministic UUID name when name is not provided\", () => {\n      const props: RoleDefinitionProps = {\n        roleName: \"Test Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      };\n\n      const roleDefinition = new RoleDefinition(stack, \"TestRole\", props);\n\n      // Name is a deterministic UUID, not the construct ID\n      expect(roleDefinition.name).toMatch(\n        /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/,\n      );\n    });\n\n    it(\"should require roleName to be provided\", () => {\n      const props: any = {\n        name: \"test-role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      };\n\n      expect(() => {\n        new RoleDefinition(stack, \"TestRole\", props);\n      }).toThrow(\"Required property 'roleName' is missing\");\n    });\n\n    it(\"should require permissions to be provided\", () => {\n      const props: any = {\n        name: \"test-role\",\n        roleName: \"Test Role\",\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      };\n\n      expect(() => {\n        new RoleDefinition(stack, \"TestRole\", props);\n      }).toThrow(\"Required property 'permissions' is missing\");\n    });\n\n    it(\"should require assignableScopes to be provided\", () => {\n      const props: any = {\n        name: \"test-role\",\n        roleName: \"Test Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n      };\n\n      expect(() => {\n        new RoleDefinition(stack, \"TestRole\", props);\n      }).toThrow(\"Required property 'assignableScopes' is missing\");\n    });\n  });\n\n  describe(\"Framework Integration\", () => {\n    it(\"should resolve latest API version automatically\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"TestRole\", {\n        name: \"test-role\",\n        roleName: \"Test Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(roleDefinition.resolvedApiVersion).toBe(\"2022-04-01\");\n      expect(roleDefinition.latestVersion()).toBe(\"2022-04-01\");\n    });\n\n    it(\"should support all registered API versions\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"TestRole\", {\n        name: \"test-role\",\n        roleName: \"Test Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      const supportedVersions = roleDefinition.supportedVersions();\n      expect(supportedVersions).toContain(\"2022-04-01\");\n    });\n\n    it(\"should validate version support\", () => {\n      // Valid version\n      expect(() => {\n        new RoleDefinition(stack, \"ValidVersion\", {\n          name: \"test-role\",\n          roleName: \"Test Role\",\n          permissions: [\n            {\n              actions: [\"Microsoft.Resources/subscriptions/read\"],\n            },\n          ],\n          assignableScopes: [\n            \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n          ],\n          apiVersion: \"2022-04-01\",\n        });\n      }).not.toThrow();\n\n      // Invalid version\n      expect(() => {\n        new RoleDefinition(stack, \"InvalidVersion\", {\n          name: \"test-role\",\n          roleName: \"Test Role\",\n          permissions: [\n            {\n              actions: [\"Microsoft.Resources/subscriptions/read\"],\n            },\n          ],\n          assignableScopes: [\n            \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n          ],\n          apiVersion: \"2020-01-01\",\n        });\n      }).toThrow(\"Unsupported API version '2020-01-01'\");\n    });\n\n    it(\"should load correct schema for resolved version\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"TestRole\", {\n        name: \"test-role\",\n        roleName: \"Test Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n        apiVersion: \"2022-04-01\",\n      });\n\n      expect(roleDefinition.schema).toBeDefined();\n      expect(roleDefinition.schema.resourceType).toBe(ROLE_DEFINITION_TYPE);\n      expect(roleDefinition.schema.version).toBe(\"2022-04-01\");\n      expect(roleDefinition.schema.properties).toBeDefined();\n    });\n\n    it(\"should load version configuration correctly\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"TestRole\", {\n        name: \"test-role\",\n        roleName: \"Test Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(roleDefinition.versionConfig).toBeDefined();\n      expect(roleDefinition.versionConfig.version).toBe(\"2022-04-01\");\n      expect(roleDefinition.versionConfig.supportLevel).toBe(\n        VersionSupportLevel.ACTIVE,\n      );\n    });\n  });\n\n  describe(\"Property Validation\", () => {\n    it(\"should validate properties when validation is enabled\", () => {\n      const props: RoleDefinitionProps = {\n        name: \"test-role\",\n        roleName: \"Test Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n        enableValidation: true,\n      };\n\n      expect(() => {\n        new RoleDefinition(stack, \"TestRole\", props);\n      }).not.toThrow();\n    });\n\n    it(\"should have validation results for valid properties\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"TestRole\", {\n        name: \"valid-role\",\n        roleName: \"Valid Role\",\n        description: \"A valid role definition\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n        enableValidation: true,\n      });\n\n      expect(roleDefinition.validationResult).toBeDefined();\n      expect(roleDefinition.validationResult!.valid).toBe(true);\n      expect(roleDefinition.validationResult!.errors).toHaveLength(0);\n    });\n\n    it(\"should skip validation when disabled\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"TestRole\", {\n        name: \"test-role\",\n        roleName: \"Test Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n        enableValidation: false,\n      });\n\n      expect(roleDefinition).toBeDefined();\n    });\n  });\n\n  describe(\"Migration Analysis\", () => {\n    it(\"should skip migration analysis for single version\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"TestRole\", {\n        name: \"test-role\",\n        roleName: \"Test Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n        apiVersion: \"2022-04-01\",\n      });\n\n      // Since there's only one version, migration analysis should be skipped\n      expect(roleDefinition).toBeDefined();\n    });\n\n    it(\"should skip migration analysis when disabled\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"TestRole\", {\n        name: \"test-role\",\n        roleName: \"Test Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n        enableMigrationAnalysis: false,\n      });\n\n      expect(roleDefinition.migrationAnalysis).toBeUndefined();\n    });\n  });\n\n  describe(\"Resource Creation and Body\", () => {\n    it(\"should create correct resource body with minimal properties\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"TestRole\", {\n        name: \"test-role\",\n        roleName: \"Test Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(roleDefinition).toBeDefined();\n      expect(roleDefinition.props.roleName).toBeDefined();\n      expect(roleDefinition.props.permissions).toBeDefined();\n      expect(roleDefinition.props.assignableScopes).toBeDefined();\n    });\n\n    it(\"should create correct resource body with all properties\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"TestRole\", {\n        name: \"test-role\",\n        roleName: \"Test Role\",\n        description: \"A test role definition\",\n        type: \"CustomRole\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Compute/virtualMachines/read\"],\n            notActions: [\"Microsoft.Compute/virtualMachines/delete\"],\n            dataActions: [\n              \"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/read\",\n            ],\n            notDataActions: [],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n          \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test-rg\",\n        ],\n      });\n\n      expect(roleDefinition).toBeDefined();\n      expect(roleDefinition.props.roleName).toBe(\"Test Role\");\n      expect(roleDefinition.props.description).toBe(\"A test role definition\");\n      expect(roleDefinition.props.type).toBe(\"CustomRole\");\n    });\n\n    it(\"should create Terraform outputs\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"TestRole\", {\n        name: \"test-role-outputs\",\n        roleName: \"Test Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(roleDefinition.idOutput).toBeInstanceOf(cdktf.TerraformOutput);\n      expect(roleDefinition.nameOutput).toBeInstanceOf(cdktf.TerraformOutput);\n    });\n  });\n\n  describe(\"Permissions Configuration\", () => {\n    it(\"should support control plane actions\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"ControlPlaneRole\", {\n        name: \"control-plane-role\",\n        roleName: \"Control Plane Role\",\n        permissions: [\n          {\n            actions: [\n              \"Microsoft.Compute/virtualMachines/read\",\n              \"Microsoft.Compute/virtualMachines/start/action\",\n              \"Microsoft.Compute/virtualMachines/restart/action\",\n            ],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(roleDefinition.props.permissions[0].actions).toHaveLength(3);\n    });\n\n    it(\"should support control plane notActions\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"NotActionsRole\", {\n        name: \"not-actions-role\",\n        roleName: \"Not Actions Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Compute/virtualMachines/*\"],\n            notActions: [\n              \"Microsoft.Compute/virtualMachines/delete\",\n              \"Microsoft.Compute/virtualMachines/write\",\n            ],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(roleDefinition.props.permissions[0].notActions).toHaveLength(2);\n    });\n\n    it(\"should support data plane actions\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"DataPlaneRole\", {\n        name: \"data-plane-role\",\n        roleName: \"Data Plane Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Storage/storageAccounts/read\"],\n            dataActions: [\n              \"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/read\",\n              \"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/write\",\n            ],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(roleDefinition.props.permissions[0].dataActions).toHaveLength(2);\n    });\n\n    it(\"should support data plane notDataActions\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"NotDataActionsRole\", {\n        name: \"not-data-actions-role\",\n        roleName: \"Not Data Actions Role\",\n        permissions: [\n          {\n            dataActions: [\n              \"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/*\",\n            ],\n            notDataActions: [\n              \"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/delete\",\n            ],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(roleDefinition.props.permissions[0].notDataActions).toHaveLength(\n        1,\n      );\n    });\n\n    it(\"should support complex permission combinations\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"ComplexPermissions\", {\n        name: \"complex-permissions\",\n        roleName: \"Complex Permissions Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Compute/virtualMachines/*\"],\n            notActions: [\"Microsoft.Compute/virtualMachines/delete\"],\n            dataActions: [\n              \"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/*\",\n            ],\n            notDataActions: [\n              \"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/delete\",\n            ],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(roleDefinition.props.permissions[0].actions).toBeDefined();\n      expect(roleDefinition.props.permissions[0].notActions).toBeDefined();\n      expect(roleDefinition.props.permissions[0].dataActions).toBeDefined();\n      expect(roleDefinition.props.permissions[0].notDataActions).toBeDefined();\n    });\n\n    it(\"should support multiple permission objects\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"MultiplePermissions\", {\n        name: \"multiple-permissions\",\n        roleName: \"Multiple Permissions Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Compute/virtualMachines/read\"],\n          },\n          {\n            actions: [\"Microsoft.Storage/storageAccounts/read\"],\n          },\n          {\n            dataActions: [\n              \"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/read\",\n            ],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(roleDefinition.props.permissions).toHaveLength(3);\n    });\n  });\n\n  describe(\"Assignable Scopes Configuration\", () => {\n    it(\"should support subscription scope\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"SubscriptionScope\", {\n        name: \"subscription-role\",\n        roleName: \"Subscription Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(roleDefinition.props.assignableScopes[0]).toContain(\n        \"/subscriptions/\",\n      );\n    });\n\n    it(\"should support resource group scope\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"ResourceGroupScope\", {\n        name: \"rg-role\",\n        roleName: \"Resource Group Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/resourceGroups/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test-rg\",\n        ],\n      });\n\n      expect(roleDefinition.props.assignableScopes[0]).toContain(\n        \"/resourceGroups/\",\n      );\n    });\n\n    it(\"should support management group scope\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"ManagementGroupScope\", {\n        name: \"mg-role\",\n        roleName: \"Management Group Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/providers/Microsoft.Management/managementGroups/test-mg\",\n        ],\n      });\n\n      expect(roleDefinition.props.assignableScopes[0]).toContain(\n        \"/managementGroups/\",\n      );\n    });\n\n    it(\"should support multiple assignable scopes\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"MultipleScopes\", {\n        name: \"multiple-scopes-role\",\n        roleName: \"Multiple Scopes Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n          \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg1\",\n          \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg2\",\n        ],\n      });\n\n      expect(roleDefinition.props.assignableScopes).toHaveLength(3);\n    });\n  });\n\n  describe(\"Role Types\", () => {\n    it(\"should default to CustomRole type\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"DefaultType\", {\n        name: \"default-type-role\",\n        roleName: \"Default Type Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(roleDefinition.roleType).toBe(\"CustomRole\");\n    });\n\n    it(\"should support explicit CustomRole type\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"CustomType\", {\n        name: \"custom-type-role\",\n        roleName: \"Custom Type Role\",\n        type: \"CustomRole\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(roleDefinition.roleType).toBe(\"CustomRole\");\n    });\n\n    it(\"should support BuiltInRole type\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"BuiltInType\", {\n        name: \"builtin-type-role\",\n        roleName: \"Built-In Type Role\",\n        type: \"BuiltInRole\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(roleDefinition.roleType).toBe(\"BuiltInRole\");\n    });\n  });\n\n  describe(\"Public Methods and Properties\", () => {\n    let roleDefinition: RoleDefinition;\n\n    beforeEach(() => {\n      roleDefinition = new RoleDefinition(stack, \"TestRole\", {\n        name: \"test-role\",\n        roleName: \"Test Role\",\n        description: \"A test role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Compute/virtualMachines/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n    });\n\n    it(\"should have correct id format\", () => {\n      expect(roleDefinition.id).toMatch(/^\\$\\{.*\\.id\\}$/);\n    });\n\n    it(\"should have resourceId property matching id\", () => {\n      expect(roleDefinition.resourceId).toBe(roleDefinition.id);\n    });\n\n    it(\"should return correct roleName\", () => {\n      expect(roleDefinition.roleName).toBe(\"Test Role\");\n    });\n\n    it(\"should return correct roleType\", () => {\n      expect(roleDefinition.roleType).toBe(\"CustomRole\");\n    });\n  });\n\n  describe(\"Ignore Changes Configuration\", () => {\n    it(\"should apply ignore changes lifecycle rules\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"IgnoreChanges\", {\n        name: \"ignore-changes-role\",\n        roleName: \"Ignore Changes Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n        ignoreChanges: [\"description\"],\n      });\n\n      expect(roleDefinition).toBeInstanceOf(RoleDefinition);\n    });\n\n    it(\"should handle empty ignore changes array\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"EmptyIgnore\", {\n        name: \"empty-ignore-role\",\n        roleName: \"Empty Ignore Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n        ignoreChanges: [],\n      });\n\n      expect(roleDefinition).toBeInstanceOf(RoleDefinition);\n    });\n  });\n\n  describe(\"Error Handling\", () => {\n    it(\"should handle invalid API versions gracefully\", () => {\n      expect(() => {\n        new RoleDefinition(stack, \"InvalidAPI\", {\n          name: \"invalid-api-role\",\n          roleName: \"Invalid API Role\",\n          permissions: [\n            {\n              actions: [\"Microsoft.Resources/subscriptions/read\"],\n            },\n          ],\n          assignableScopes: [\n            \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n          ],\n          apiVersion: \"invalid-version\",\n        });\n      }).toThrow(\"Unsupported API version 'invalid-version'\");\n    });\n\n    it(\"should validate properties when validation is enabled\", () => {\n      // Role definitions generate deterministic UUIDs for names, so name validation\n      // doesn't apply the same way. Test that valid role definitions pass validation.\n      const roleDefinition = new RoleDefinition(stack, \"ValidationTest\", {\n        name: \"test-role\", // This is ignored in favor of generated UUID\n        roleName: \"Test Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n        enableValidation: true,\n      });\n\n      expect(roleDefinition.validationResult).toBeDefined();\n      expect(roleDefinition.validationResult!.valid).toBe(true);\n    });\n\n    it(\"should handle schema registration errors gracefully\", () => {\n      expect(() => {\n        new RoleDefinition(stack, \"SchemaTest\", {\n          name: \"schema-test-role\",\n          roleName: \"Schema Test Role\",\n          permissions: [\n            {\n              actions: [\"Microsoft.Resources/subscriptions/read\"],\n            },\n          ],\n          assignableScopes: [\n            \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n          ],\n        });\n      }).not.toThrow();\n    });\n  });\n\n  describe(\"JSII Compliance\", () => {\n    it(\"should have JSII-compliant constructor\", () => {\n      expect(() => {\n        new RoleDefinition(stack, \"JsiiTest\", {\n          name: \"jsii-test\",\n          roleName: \"JSII Test Role\",\n          permissions: [\n            {\n              actions: [\"Microsoft.Resources/subscriptions/read\"],\n            },\n          ],\n          assignableScopes: [\n            \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n          ],\n        });\n      }).not.toThrow();\n    });\n\n    it(\"should have JSII-compliant properties\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"JsiiProps\", {\n        name: \"jsii-props\",\n        roleName: \"JSII Props Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(typeof roleDefinition.id).toBe(\"string\");\n      expect(typeof roleDefinition.name).toBe(\"string\");\n      expect(typeof roleDefinition.resolvedApiVersion).toBe(\"string\");\n      expect(typeof roleDefinition.roleName).toBe(\"string\");\n      expect(typeof roleDefinition.roleType).toBe(\"string\");\n    });\n\n    it(\"should have JSII-compliant methods\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"JsiiMethods\", {\n        name: \"jsii-methods\",\n        roleName: \"JSII Methods Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(typeof roleDefinition.latestVersion).toBe(\"function\");\n      expect(typeof roleDefinition.supportedVersions).toBe(\"function\");\n    });\n\n    it(\"should serialize complex objects correctly\", () => {\n      const roleDefinition = new RoleDefinition(stack, \"JsiiSerialization\", {\n        name: \"jsii-serialization\",\n        roleName: \"JSII Serialization Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Compute/virtualMachines/read\"],\n            notActions: [\"Microsoft.Compute/virtualMachines/delete\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      expect(() =>\n        JSON.stringify(roleDefinition.validationResult),\n      ).not.toThrow();\n      expect(() => JSON.stringify(roleDefinition.schema)).not.toThrow();\n      expect(() => JSON.stringify(roleDefinition.versionConfig)).not.toThrow();\n    });\n  });\n\n  describe(\"CDK Terraform Integration\", () => {\n    it(\"should synthesize to valid Terraform configuration\", () => {\n      new RoleDefinition(stack, \"SynthTest\", {\n        name: \"synth-test\",\n        roleName: \"Synth Test Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Resources/subscriptions/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toBeDefined();\n\n      const stackConfig = JSON.parse(synthesized);\n      expect(stackConfig.resource).toBeDefined();\n    });\n\n    it(\"should work in complex CDK constructs\", () => {\n      class ComplexConstruct extends cdktf.TerraformStack {\n        constructor(scope: cdktf.App, id: string) {\n          super(scope, id);\n\n          const role1 = new RoleDefinition(this, \"Role1\", {\n            name: \"role-1\",\n            roleName: \"First Role\",\n            permissions: [\n              {\n                actions: [\"Microsoft.Compute/virtualMachines/read\"],\n              },\n            ],\n            assignableScopes: [\n              \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n            ],\n          });\n\n          const role2 = new RoleDefinition(this, \"Role2\", {\n            name: \"role-2\",\n            roleName: \"Second Role\",\n            permissions: [\n              {\n                actions: [\"Microsoft.Storage/storageAccounts/read\"],\n              },\n            ],\n            assignableScopes: [\n              \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test-rg\",\n            ],\n            apiVersion: \"2022-04-01\",\n          });\n\n          new cdktf.TerraformOutput(this, \"Role1Id\", {\n            value: role1.id,\n          });\n\n          new cdktf.TerraformOutput(this, \"Role2Id\", {\n            value: role2.id,\n          });\n        }\n      }\n\n      expect(() => {\n        new ComplexConstruct(app, \"ComplexStack\");\n      }).not.toThrow();\n    });\n\n    it(\"should handle multiple role definitions in the same stack\", () => {\n      const role1 = new RoleDefinition(stack, \"Role1\", {\n        name: \"role-1\",\n        roleName: \"First Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Compute/virtualMachines/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n        ],\n      });\n\n      const role2 = new RoleDefinition(stack, \"Role2\", {\n        name: \"role-2\",\n        roleName: \"Second Role\",\n        permissions: [\n          {\n            actions: [\"Microsoft.Storage/storageAccounts/read\"],\n          },\n        ],\n        assignableScopes: [\n          \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test-rg\",\n        ],\n        apiVersion: \"2022-04-01\",\n      });\n\n      expect(role1.resolvedApiVersion).toBe(\"2022-04-01\");\n      expect(role2.resolvedApiVersion).toBe(\"2022-04-01\");\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toBeDefined();\n    });\n  });\n});\n"]}