@microsoft/terraform-cdk-constructs 1.0.0 → 1.2.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 (385) hide show
  1. package/.jsii +60999 -15780
  2. package/API.md +54947 -10610
  3. package/README.md +72 -36
  4. package/docs/monitoring-guide.md +206 -0
  5. package/docs/testing.md +84 -1
  6. package/lib/azure-actiongroup/index.d.ts +11 -0
  7. package/lib/azure-actiongroup/index.js +28 -0
  8. package/lib/azure-actiongroup/lib/action-group-schemas.d.ts +24 -0
  9. package/lib/azure-actiongroup/lib/action-group-schemas.js +201 -0
  10. package/lib/azure-actiongroup/lib/action-group.d.ts +312 -0
  11. package/lib/azure-actiongroup/lib/action-group.js +201 -0
  12. package/lib/azure-actiongroup/lib/index.d.ts +5 -0
  13. package/lib/azure-actiongroup/lib/index.js +22 -0
  14. package/lib/azure-actiongroup/test/action-group.integ.d.ts +9 -0
  15. package/lib/azure-actiongroup/test/action-group.integ.js +79 -0
  16. package/lib/azure-actiongroup/test/action-group.spec.d.ts +8 -0
  17. package/lib/azure-actiongroup/test/action-group.spec.js +602 -0
  18. package/lib/azure-activitylogalert/index.d.ts +11 -0
  19. package/lib/azure-activitylogalert/index.js +28 -0
  20. package/lib/azure-activitylogalert/lib/activity-log-alert-schemas.d.ts +24 -0
  21. package/lib/azure-activitylogalert/lib/activity-log-alert-schemas.js +182 -0
  22. package/lib/azure-activitylogalert/lib/activity-log-alert.d.ts +236 -0
  23. package/lib/azure-activitylogalert/lib/activity-log-alert.js +212 -0
  24. package/lib/azure-activitylogalert/lib/index.d.ts +5 -0
  25. package/lib/azure-activitylogalert/lib/index.js +22 -0
  26. package/lib/azure-activitylogalert/test/activity-log-alert.integ.d.ts +9 -0
  27. package/lib/azure-activitylogalert/test/activity-log-alert.integ.js +98 -0
  28. package/lib/azure-activitylogalert/test/activity-log-alert.spec.d.ts +9 -0
  29. package/lib/azure-activitylogalert/test/activity-log-alert.spec.js +1101 -0
  30. package/lib/azure-aks/index.d.ts +9 -0
  31. package/lib/azure-aks/index.js +28 -0
  32. package/lib/azure-aks/lib/aks-cluster-schemas.d.ts +505 -0
  33. package/lib/azure-aks/lib/aks-cluster-schemas.js +572 -0
  34. package/lib/azure-aks/lib/aks-cluster.d.ts +395 -0
  35. package/lib/azure-aks/lib/aks-cluster.js +489 -0
  36. package/lib/azure-aks/lib/index.d.ts +11 -0
  37. package/lib/azure-aks/lib/index.js +38 -0
  38. package/lib/azure-aks/test/aks-cluster.integ.d.ts +9 -0
  39. package/lib/azure-aks/test/aks-cluster.integ.js +260 -0
  40. package/lib/azure-aks/test/aks-cluster.spec.d.ts +8 -0
  41. package/lib/azure-aks/test/aks-cluster.spec.js +1396 -0
  42. package/lib/azure-diagnosticsettings/index.d.ts +7 -0
  43. package/lib/azure-diagnosticsettings/index.js +24 -0
  44. package/lib/azure-diagnosticsettings/lib/diagnostic-settings-schemas.d.ts +50 -0
  45. package/lib/azure-diagnosticsettings/lib/diagnostic-settings-schemas.js +207 -0
  46. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.d.ts +193 -0
  47. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +200 -0
  48. package/lib/azure-diagnosticsettings/lib/index.d.ts +8 -0
  49. package/lib/azure-diagnosticsettings/lib/index.js +25 -0
  50. package/lib/azure-diagnosticsettings/test/diagnostic-settings.spec.d.ts +8 -0
  51. package/lib/azure-diagnosticsettings/test/diagnostic-settings.spec.js +432 -0
  52. package/lib/azure-metricalert/index.d.ts +11 -0
  53. package/lib/azure-metricalert/index.js +28 -0
  54. package/lib/azure-metricalert/lib/index.d.ts +5 -0
  55. package/lib/azure-metricalert/lib/index.js +22 -0
  56. package/lib/azure-metricalert/lib/metric-alert-schemas.d.ts +24 -0
  57. package/lib/azure-metricalert/lib/metric-alert-schemas.js +242 -0
  58. package/lib/azure-metricalert/lib/metric-alert.d.ts +344 -0
  59. package/lib/azure-metricalert/lib/metric-alert.js +252 -0
  60. package/lib/azure-metricalert/test/metric-alert.integ.d.ts +9 -0
  61. package/lib/azure-metricalert/test/metric-alert.integ.js +123 -0
  62. package/lib/azure-metricalert/test/metric-alert.spec.d.ts +9 -0
  63. package/lib/azure-metricalert/test/metric-alert.spec.js +1266 -0
  64. package/lib/azure-networkinterface/index.d.ts +4 -0
  65. package/lib/azure-networkinterface/index.js +21 -0
  66. package/lib/azure-networkinterface/lib/index.d.ts +6 -0
  67. package/lib/azure-networkinterface/lib/index.js +22 -0
  68. package/lib/azure-networkinterface/lib/network-interface-schemas.d.ts +32 -0
  69. package/lib/azure-networkinterface/lib/network-interface-schemas.js +222 -0
  70. package/lib/azure-networkinterface/lib/network-interface.d.ts +265 -0
  71. package/lib/azure-networkinterface/lib/network-interface.js +228 -0
  72. package/lib/azure-networkinterface/test/network-interface.integ.d.ts +9 -0
  73. package/lib/azure-networkinterface/test/network-interface.integ.js +102 -0
  74. package/lib/azure-networkinterface/test/network-interface.spec.d.ts +8 -0
  75. package/lib/azure-networkinterface/test/network-interface.spec.js +655 -0
  76. package/lib/azure-networksecuritygroup/index.d.ts +6 -0
  77. package/lib/azure-networksecuritygroup/index.js +23 -0
  78. package/lib/azure-networksecuritygroup/lib/index.d.ts +5 -0
  79. package/lib/azure-networksecuritygroup/lib/index.js +16 -0
  80. package/lib/azure-networksecuritygroup/lib/network-security-group-schemas.d.ts +32 -0
  81. package/lib/azure-networksecuritygroup/lib/network-security-group-schemas.js +198 -0
  82. package/lib/azure-networksecuritygroup/lib/network-security-group.d.ts +268 -0
  83. package/lib/azure-networksecuritygroup/lib/network-security-group.js +248 -0
  84. package/lib/azure-networksecuritygroup/test/network-security-group.integ.d.ts +9 -0
  85. package/lib/azure-networksecuritygroup/test/network-security-group.integ.js +151 -0
  86. package/lib/azure-networksecuritygroup/test/network-security-group.spec.d.ts +8 -0
  87. package/lib/azure-networksecuritygroup/test/network-security-group.spec.js +652 -0
  88. package/lib/azure-publicipaddress/index.d.ts +6 -0
  89. package/lib/azure-publicipaddress/index.js +23 -0
  90. package/lib/azure-publicipaddress/lib/index.d.ts +9 -0
  91. package/lib/azure-publicipaddress/lib/index.js +19 -0
  92. package/lib/azure-publicipaddress/lib/public-ip-address-schemas.d.ts +32 -0
  93. package/lib/azure-publicipaddress/lib/public-ip-address-schemas.js +227 -0
  94. package/lib/azure-publicipaddress/lib/public-ip-address.d.ts +256 -0
  95. package/lib/azure-publicipaddress/lib/public-ip-address.js +267 -0
  96. package/lib/azure-publicipaddress/test/public-ip-address.integ.d.ts +9 -0
  97. package/lib/azure-publicipaddress/test/public-ip-address.integ.js +75 -0
  98. package/lib/azure-publicipaddress/test/public-ip-address.spec.d.ts +15 -0
  99. package/lib/azure-publicipaddress/test/public-ip-address.spec.js +498 -0
  100. package/lib/azure-resourcegroup/lib/resource-group.js +1 -1
  101. package/lib/azure-resourcegroup/test/resource-group.integ.js +23 -11
  102. package/lib/azure-storageaccount/lib/storage-account-schemas.d.ts +98 -0
  103. package/lib/azure-storageaccount/lib/storage-account-schemas.js +1 -1
  104. package/lib/azure-storageaccount/lib/storage-account.d.ts +38 -1
  105. package/lib/azure-storageaccount/lib/storage-account.js +138 -2
  106. package/lib/azure-storageaccount/test/storage-account.integ.js +91 -12
  107. package/lib/azure-subnet/index.d.ts +4 -0
  108. package/lib/azure-subnet/index.js +21 -0
  109. package/lib/azure-subnet/lib/index.d.ts +5 -0
  110. package/lib/azure-subnet/lib/index.js +22 -0
  111. package/lib/azure-subnet/lib/subnet-schemas.d.ts +32 -0
  112. package/lib/azure-subnet/lib/subnet-schemas.js +237 -0
  113. package/lib/azure-subnet/lib/subnet.d.ts +285 -0
  114. package/lib/azure-subnet/lib/subnet.js +254 -0
  115. package/lib/azure-subnet/test/subnet.integ.d.ts +11 -0
  116. package/lib/azure-subnet/test/subnet.integ.js +80 -0
  117. package/lib/azure-subnet/test/subnet.spec.d.ts +8 -0
  118. package/lib/azure-subnet/test/subnet.spec.js +396 -0
  119. package/lib/azure-virtualmachine/index.d.ts +7 -0
  120. package/lib/azure-virtualmachine/index.js +24 -0
  121. package/lib/azure-virtualmachine/lib/index.d.ts +11 -0
  122. package/lib/azure-virtualmachine/lib/index.js +38 -0
  123. package/lib/azure-virtualmachine/lib/virtual-machine-schemas.d.ts +327 -0
  124. package/lib/azure-virtualmachine/lib/virtual-machine-schemas.js +544 -0
  125. package/lib/azure-virtualmachine/lib/virtual-machine.d.ts +377 -0
  126. package/lib/azure-virtualmachine/lib/virtual-machine.js +462 -0
  127. package/lib/azure-virtualmachine/test/virtual-machine.integ.d.ts +9 -0
  128. package/lib/azure-virtualmachine/test/virtual-machine.integ.js +220 -0
  129. package/lib/azure-virtualmachine/test/virtual-machine.spec.d.ts +9 -0
  130. package/lib/azure-virtualmachine/test/virtual-machine.spec.js +1032 -0
  131. package/lib/azure-virtualnetwork/index.d.ts +10 -0
  132. package/lib/azure-virtualnetwork/index.js +28 -0
  133. package/lib/azure-virtualnetwork/lib/index.d.ts +9 -0
  134. package/lib/azure-virtualnetwork/lib/index.js +22 -0
  135. package/lib/azure-virtualnetwork/lib/virtual-network-schemas.d.ts +32 -0
  136. package/lib/azure-virtualnetwork/lib/virtual-network-schemas.js +236 -0
  137. package/lib/azure-virtualnetwork/lib/virtual-network.d.ts +213 -0
  138. package/lib/azure-virtualnetwork/lib/virtual-network.js +245 -0
  139. package/lib/azure-virtualnetwork/test/virtual-network.integ.d.ts +9 -0
  140. package/lib/azure-virtualnetwork/test/virtual-network.integ.js +91 -0
  141. package/lib/azure-virtualnetwork/test/virtual-network.spec.d.ts +8 -0
  142. package/lib/azure-virtualnetwork/test/virtual-network.spec.js +398 -0
  143. package/lib/azure-vmss/index.d.ts +6 -0
  144. package/lib/azure-vmss/index.js +23 -0
  145. package/lib/azure-vmss/lib/index.d.ts +9 -0
  146. package/lib/azure-vmss/lib/index.js +39 -0
  147. package/lib/azure-vmss/lib/virtual-machine-scale-set.d.ts +258 -0
  148. package/lib/azure-vmss/lib/virtual-machine-scale-set.js +503 -0
  149. package/lib/azure-vmss/lib/vmss-schemas.d.ts +472 -0
  150. package/lib/azure-vmss/lib/vmss-schemas.js +444 -0
  151. package/lib/azure-vmss/test/virtual-machine-scale-set.integ.d.ts +15 -0
  152. package/lib/azure-vmss/test/virtual-machine-scale-set.integ.js +261 -0
  153. package/lib/azure-vmss/test/virtual-machine-scale-set.spec.d.ts +8 -0
  154. package/lib/azure-vmss/test/virtual-machine-scale-set.spec.js +997 -0
  155. package/lib/core-azure/lib/azapi/azapi-resource.d.ts +95 -27
  156. package/lib/core-azure/lib/azapi/azapi-resource.js +95 -58
  157. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.d.ts +33 -21
  158. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +69 -27
  159. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.d.ts +134 -120
  160. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +209 -59
  161. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-action/index.d.ts +141 -128
  162. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-action/index.js +183 -36
  163. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-id/index.d.ts +55 -43
  164. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-id/index.js +94 -26
  165. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-list/index.d.ts +129 -116
  166. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-list/index.js +155 -32
  167. package/lib/core-azure/lib/azapi/providers-azapi/data-plane-resource/index.d.ts +187 -174
  168. package/lib/core-azure/lib/azapi/providers-azapi/data-plane-resource/index.js +267 -48
  169. package/lib/core-azure/lib/azapi/providers-azapi/index.d.ts +10 -10
  170. package/lib/core-azure/lib/azapi/providers-azapi/index.js +1 -1
  171. package/lib/core-azure/lib/azapi/providers-azapi/lazy-index.d.ts +0 -0
  172. package/lib/core-azure/lib/azapi/providers-azapi/lazy-index.js +13 -0
  173. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.d.ts +174 -162
  174. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +274 -14
  175. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.d.ts +239 -225
  176. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +360 -76
  177. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.d.ts +163 -150
  178. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +221 -46
  179. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.d.ts +162 -149
  180. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +249 -50
  181. package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +4 -2
  182. package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
  183. package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
  184. package/lib/index.d.ts +37 -0
  185. package/lib/index.js +40 -2
  186. package/lib/testing/index.d.ts +92 -2
  187. package/lib/testing/index.js +258 -18
  188. package/lib/testing/lib/cleanup.d.ts +229 -0
  189. package/lib/testing/lib/cleanup.js +331 -0
  190. package/lib/testing/lib/metadata.d.ts +151 -0
  191. package/lib/testing/lib/metadata.js +180 -0
  192. package/lib/testing/lib/naming.d.ts +96 -0
  193. package/lib/testing/lib/naming.js +336 -0
  194. package/node_modules/uuid/LICENSE.md +9 -0
  195. package/node_modules/uuid/README.md +510 -0
  196. package/node_modules/uuid/dist/cjs/index.d.ts +15 -0
  197. package/node_modules/uuid/dist/cjs/index.js +31 -0
  198. package/node_modules/uuid/dist/cjs/max.d.ts +2 -0
  199. package/node_modules/uuid/dist/cjs/max.js +3 -0
  200. package/node_modules/uuid/dist/cjs/md5.d.ts +4 -0
  201. package/node_modules/uuid/dist/cjs/md5.js +13 -0
  202. package/node_modules/uuid/dist/cjs/native.d.ts +6 -0
  203. package/node_modules/uuid/dist/cjs/native.js +4 -0
  204. package/node_modules/uuid/dist/cjs/nil.d.ts +2 -0
  205. package/node_modules/uuid/dist/cjs/nil.js +3 -0
  206. package/node_modules/uuid/dist/cjs/package.json +1 -0
  207. package/node_modules/uuid/dist/cjs/parse.d.ts +2 -0
  208. package/node_modules/uuid/dist/cjs/parse.js +11 -0
  209. package/node_modules/uuid/dist/cjs/regex.d.ts +2 -0
  210. package/node_modules/uuid/dist/cjs/regex.js +3 -0
  211. package/node_modules/uuid/dist/cjs/rng.d.ts +1 -0
  212. package/node_modules/uuid/dist/cjs/rng.js +13 -0
  213. package/node_modules/uuid/dist/cjs/sha1.d.ts +4 -0
  214. package/node_modules/uuid/dist/cjs/sha1.js +13 -0
  215. package/node_modules/uuid/dist/cjs/stringify.d.ts +3 -0
  216. package/node_modules/uuid/dist/cjs/stringify.js +39 -0
  217. package/node_modules/uuid/dist/cjs/types.d.ts +21 -0
  218. package/node_modules/uuid/dist/cjs/types.js +2 -0
  219. package/node_modules/uuid/dist/cjs/uuid-bin.d.ts +1 -0
  220. package/node_modules/uuid/dist/cjs/uuid-bin.js +72 -0
  221. package/node_modules/uuid/dist/cjs/v1.d.ts +11 -0
  222. package/node_modules/uuid/dist/cjs/v1.js +87 -0
  223. package/node_modules/uuid/dist/cjs/v1ToV6.d.ts +2 -0
  224. package/node_modules/uuid/dist/cjs/v1ToV6.js +13 -0
  225. package/node_modules/uuid/dist/cjs/v3.d.ts +9 -0
  226. package/node_modules/uuid/dist/cjs/v3.js +14 -0
  227. package/node_modules/uuid/dist/cjs/v35.d.ts +7 -0
  228. package/node_modules/uuid/dist/cjs/v35.js +41 -0
  229. package/node_modules/uuid/dist/cjs/v4.d.ts +4 -0
  230. package/node_modules/uuid/dist/cjs/v4.js +29 -0
  231. package/node_modules/uuid/dist/cjs/v5.d.ts +9 -0
  232. package/node_modules/uuid/dist/cjs/v5.js +14 -0
  233. package/node_modules/uuid/dist/cjs/v6.d.ts +4 -0
  234. package/node_modules/uuid/dist/cjs/v6.js +19 -0
  235. package/node_modules/uuid/dist/cjs/v6ToV1.d.ts +2 -0
  236. package/node_modules/uuid/dist/cjs/v6ToV1.js +13 -0
  237. package/node_modules/uuid/dist/cjs/v7.d.ts +9 -0
  238. package/node_modules/uuid/dist/cjs/v7.js +69 -0
  239. package/node_modules/uuid/dist/cjs/validate.d.ts +2 -0
  240. package/node_modules/uuid/dist/cjs/validate.js +7 -0
  241. package/node_modules/uuid/dist/cjs/version.d.ts +2 -0
  242. package/node_modules/uuid/dist/cjs/version.js +10 -0
  243. package/node_modules/uuid/dist/cjs-browser/index.d.ts +15 -0
  244. package/node_modules/uuid/dist/cjs-browser/index.js +31 -0
  245. package/node_modules/uuid/dist/cjs-browser/max.d.ts +2 -0
  246. package/node_modules/uuid/dist/cjs-browser/max.js +3 -0
  247. package/node_modules/uuid/dist/cjs-browser/md5.d.ts +2 -0
  248. package/node_modules/uuid/dist/cjs-browser/md5.js +137 -0
  249. package/node_modules/uuid/dist/cjs-browser/native.d.ts +4 -0
  250. package/node_modules/uuid/dist/cjs-browser/native.js +4 -0
  251. package/node_modules/uuid/dist/cjs-browser/nil.d.ts +2 -0
  252. package/node_modules/uuid/dist/cjs-browser/nil.js +3 -0
  253. package/node_modules/uuid/dist/cjs-browser/package.json +1 -0
  254. package/node_modules/uuid/dist/cjs-browser/parse.d.ts +2 -0
  255. package/node_modules/uuid/dist/cjs-browser/parse.js +11 -0
  256. package/node_modules/uuid/dist/cjs-browser/regex.d.ts +2 -0
  257. package/node_modules/uuid/dist/cjs-browser/regex.js +3 -0
  258. package/node_modules/uuid/dist/cjs-browser/rng.d.ts +1 -0
  259. package/node_modules/uuid/dist/cjs-browser/rng.js +14 -0
  260. package/node_modules/uuid/dist/cjs-browser/sha1.d.ts +2 -0
  261. package/node_modules/uuid/dist/cjs-browser/sha1.js +72 -0
  262. package/node_modules/uuid/dist/cjs-browser/stringify.d.ts +3 -0
  263. package/node_modules/uuid/dist/cjs-browser/stringify.js +39 -0
  264. package/node_modules/uuid/dist/cjs-browser/types.d.ts +21 -0
  265. package/node_modules/uuid/dist/cjs-browser/types.js +2 -0
  266. package/node_modules/uuid/dist/cjs-browser/uuid-bin.d.ts +1 -0
  267. package/node_modules/uuid/dist/cjs-browser/uuid-bin.js +72 -0
  268. package/node_modules/uuid/dist/cjs-browser/v1.d.ts +11 -0
  269. package/node_modules/uuid/dist/cjs-browser/v1.js +87 -0
  270. package/node_modules/uuid/dist/cjs-browser/v1ToV6.d.ts +2 -0
  271. package/node_modules/uuid/dist/cjs-browser/v1ToV6.js +13 -0
  272. package/node_modules/uuid/dist/cjs-browser/v3.d.ts +9 -0
  273. package/node_modules/uuid/dist/cjs-browser/v3.js +14 -0
  274. package/node_modules/uuid/dist/cjs-browser/v35.d.ts +7 -0
  275. package/node_modules/uuid/dist/cjs-browser/v35.js +41 -0
  276. package/node_modules/uuid/dist/cjs-browser/v4.d.ts +4 -0
  277. package/node_modules/uuid/dist/cjs-browser/v4.js +29 -0
  278. package/node_modules/uuid/dist/cjs-browser/v5.d.ts +9 -0
  279. package/node_modules/uuid/dist/cjs-browser/v5.js +14 -0
  280. package/node_modules/uuid/dist/cjs-browser/v6.d.ts +4 -0
  281. package/node_modules/uuid/dist/cjs-browser/v6.js +19 -0
  282. package/node_modules/uuid/dist/cjs-browser/v6ToV1.d.ts +2 -0
  283. package/node_modules/uuid/dist/cjs-browser/v6ToV1.js +13 -0
  284. package/node_modules/uuid/dist/cjs-browser/v7.d.ts +9 -0
  285. package/node_modules/uuid/dist/cjs-browser/v7.js +69 -0
  286. package/node_modules/uuid/dist/cjs-browser/validate.d.ts +2 -0
  287. package/node_modules/uuid/dist/cjs-browser/validate.js +7 -0
  288. package/node_modules/uuid/dist/cjs-browser/version.d.ts +2 -0
  289. package/node_modules/uuid/dist/cjs-browser/version.js +10 -0
  290. package/node_modules/uuid/dist/esm/bin/uuid +2 -0
  291. package/node_modules/uuid/dist/esm/index.d.ts +15 -0
  292. package/node_modules/uuid/dist/esm/index.js +14 -0
  293. package/node_modules/uuid/dist/esm/max.d.ts +2 -0
  294. package/node_modules/uuid/dist/esm/max.js +1 -0
  295. package/node_modules/uuid/dist/esm/md5.d.ts +4 -0
  296. package/node_modules/uuid/dist/esm/md5.js +11 -0
  297. package/node_modules/uuid/dist/esm/native.d.ts +6 -0
  298. package/node_modules/uuid/dist/esm/native.js +2 -0
  299. package/node_modules/uuid/dist/esm/nil.d.ts +2 -0
  300. package/node_modules/uuid/dist/esm/nil.js +1 -0
  301. package/node_modules/uuid/dist/esm/parse.d.ts +2 -0
  302. package/node_modules/uuid/dist/esm/parse.js +9 -0
  303. package/node_modules/uuid/dist/esm/regex.d.ts +2 -0
  304. package/node_modules/uuid/dist/esm/regex.js +1 -0
  305. package/node_modules/uuid/dist/esm/rng.d.ts +1 -0
  306. package/node_modules/uuid/dist/esm/rng.js +10 -0
  307. package/node_modules/uuid/dist/esm/sha1.d.ts +4 -0
  308. package/node_modules/uuid/dist/esm/sha1.js +11 -0
  309. package/node_modules/uuid/dist/esm/stringify.d.ts +3 -0
  310. package/node_modules/uuid/dist/esm/stringify.js +35 -0
  311. package/node_modules/uuid/dist/esm/types.d.ts +21 -0
  312. package/node_modules/uuid/dist/esm/types.js +1 -0
  313. package/node_modules/uuid/dist/esm/uuid-bin.d.ts +1 -0
  314. package/node_modules/uuid/dist/esm/uuid-bin.js +70 -0
  315. package/node_modules/uuid/dist/esm/v1.d.ts +11 -0
  316. package/node_modules/uuid/dist/esm/v1.js +83 -0
  317. package/node_modules/uuid/dist/esm/v1ToV6.d.ts +2 -0
  318. package/node_modules/uuid/dist/esm/v1ToV6.js +10 -0
  319. package/node_modules/uuid/dist/esm/v3.d.ts +9 -0
  320. package/node_modules/uuid/dist/esm/v3.js +9 -0
  321. package/node_modules/uuid/dist/esm/v35.d.ts +7 -0
  322. package/node_modules/uuid/dist/esm/v35.js +36 -0
  323. package/node_modules/uuid/dist/esm/v4.d.ts +4 -0
  324. package/node_modules/uuid/dist/esm/v4.js +27 -0
  325. package/node_modules/uuid/dist/esm/v5.d.ts +9 -0
  326. package/node_modules/uuid/dist/esm/v5.js +9 -0
  327. package/node_modules/uuid/dist/esm/v6.d.ts +4 -0
  328. package/node_modules/uuid/dist/esm/v6.js +17 -0
  329. package/node_modules/uuid/dist/esm/v6ToV1.d.ts +2 -0
  330. package/node_modules/uuid/dist/esm/v6ToV1.js +10 -0
  331. package/node_modules/uuid/dist/esm/v7.d.ts +9 -0
  332. package/node_modules/uuid/dist/esm/v7.js +65 -0
  333. package/node_modules/uuid/dist/esm/validate.d.ts +2 -0
  334. package/node_modules/uuid/dist/esm/validate.js +5 -0
  335. package/node_modules/uuid/dist/esm/version.d.ts +2 -0
  336. package/node_modules/uuid/dist/esm/version.js +8 -0
  337. package/node_modules/uuid/dist/esm-browser/index.d.ts +15 -0
  338. package/node_modules/uuid/dist/esm-browser/index.js +14 -0
  339. package/node_modules/uuid/dist/esm-browser/max.d.ts +2 -0
  340. package/node_modules/uuid/dist/esm-browser/max.js +1 -0
  341. package/node_modules/uuid/dist/esm-browser/md5.d.ts +2 -0
  342. package/node_modules/uuid/dist/esm-browser/md5.js +135 -0
  343. package/node_modules/uuid/dist/esm-browser/native.d.ts +4 -0
  344. package/node_modules/uuid/dist/esm-browser/native.js +2 -0
  345. package/node_modules/uuid/dist/esm-browser/nil.d.ts +2 -0
  346. package/node_modules/uuid/dist/esm-browser/nil.js +1 -0
  347. package/node_modules/uuid/dist/esm-browser/parse.d.ts +2 -0
  348. package/node_modules/uuid/dist/esm-browser/parse.js +9 -0
  349. package/node_modules/uuid/dist/esm-browser/regex.d.ts +2 -0
  350. package/node_modules/uuid/dist/esm-browser/regex.js +1 -0
  351. package/node_modules/uuid/dist/esm-browser/rng.d.ts +1 -0
  352. package/node_modules/uuid/dist/esm-browser/rng.js +11 -0
  353. package/node_modules/uuid/dist/esm-browser/sha1.d.ts +2 -0
  354. package/node_modules/uuid/dist/esm-browser/sha1.js +70 -0
  355. package/node_modules/uuid/dist/esm-browser/stringify.d.ts +3 -0
  356. package/node_modules/uuid/dist/esm-browser/stringify.js +35 -0
  357. package/node_modules/uuid/dist/esm-browser/types.d.ts +21 -0
  358. package/node_modules/uuid/dist/esm-browser/types.js +1 -0
  359. package/node_modules/uuid/dist/esm-browser/uuid-bin.d.ts +1 -0
  360. package/node_modules/uuid/dist/esm-browser/uuid-bin.js +70 -0
  361. package/node_modules/uuid/dist/esm-browser/v1.d.ts +11 -0
  362. package/node_modules/uuid/dist/esm-browser/v1.js +83 -0
  363. package/node_modules/uuid/dist/esm-browser/v1ToV6.d.ts +2 -0
  364. package/node_modules/uuid/dist/esm-browser/v1ToV6.js +10 -0
  365. package/node_modules/uuid/dist/esm-browser/v3.d.ts +9 -0
  366. package/node_modules/uuid/dist/esm-browser/v3.js +9 -0
  367. package/node_modules/uuid/dist/esm-browser/v35.d.ts +7 -0
  368. package/node_modules/uuid/dist/esm-browser/v35.js +36 -0
  369. package/node_modules/uuid/dist/esm-browser/v4.d.ts +4 -0
  370. package/node_modules/uuid/dist/esm-browser/v4.js +27 -0
  371. package/node_modules/uuid/dist/esm-browser/v5.d.ts +9 -0
  372. package/node_modules/uuid/dist/esm-browser/v5.js +9 -0
  373. package/node_modules/uuid/dist/esm-browser/v6.d.ts +4 -0
  374. package/node_modules/uuid/dist/esm-browser/v6.js +17 -0
  375. package/node_modules/uuid/dist/esm-browser/v6ToV1.d.ts +2 -0
  376. package/node_modules/uuid/dist/esm-browser/v6ToV1.js +10 -0
  377. package/node_modules/uuid/dist/esm-browser/v7.d.ts +9 -0
  378. package/node_modules/uuid/dist/esm-browser/v7.js +65 -0
  379. package/node_modules/uuid/dist/esm-browser/validate.d.ts +2 -0
  380. package/node_modules/uuid/dist/esm-browser/validate.js +5 -0
  381. package/node_modules/uuid/dist/esm-browser/version.d.ts +2 -0
  382. package/node_modules/uuid/dist/esm-browser/version.js +8 -0
  383. package/node_modules/uuid/package.json +132 -0
  384. package/package.json +17 -12
  385. package/scripts/cleanup-test-resources.ts +369 -0
@@ -0,0 +1,1101 @@
1
+ "use strict";
2
+ /**
3
+ * Comprehensive tests for the ActivityLogAlert implementation
4
+ *
5
+ * This test suite validates the ActivityLogAlert class using the AzapiResource framework.
6
+ * Tests cover automatic version resolution, explicit version pinning, schema validation,
7
+ * condition filtering, category types, scope configurations, action group integration,
8
+ * property transformation, and resource creation.
9
+ */
10
+ Object.defineProperty(exports, "__esModule", { value: true });
11
+ const cdktf_1 = require("cdktf");
12
+ const cdktf = require("cdktf");
13
+ const activity_log_alert_1 = require("../lib/activity-log-alert");
14
+ describe("ActivityLogAlert - Implementation", () => {
15
+ let app;
16
+ let stack;
17
+ beforeEach(() => {
18
+ app = cdktf_1.Testing.app();
19
+ stack = new cdktf.TerraformStack(app, "TestStack");
20
+ });
21
+ // =============================================================================
22
+ // Constructor and Basic Properties
23
+ // =============================================================================
24
+ describe("Constructor and Basic Properties", () => {
25
+ it("should create activity log alert with minimal required properties", () => {
26
+ const condition = {
27
+ allOf: [
28
+ { field: "category", equalsValue: "Administrative" },
29
+ {
30
+ field: "operationName",
31
+ equalsValue: "Microsoft.Compute/virtualMachines/delete",
32
+ },
33
+ ],
34
+ };
35
+ const props = {
36
+ name: "test-activity-log-alert",
37
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
38
+ scopes: ["/subscriptions/test-sub"],
39
+ condition,
40
+ };
41
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "TestActivityLogAlert", props);
42
+ expect(activityLogAlert).toBeInstanceOf(activity_log_alert_1.ActivityLogAlert);
43
+ expect(activityLogAlert.props).toBe(props);
44
+ expect(activityLogAlert.props.name).toBe("test-activity-log-alert");
45
+ expect(activityLogAlert.props.scopes).toHaveLength(1);
46
+ });
47
+ it("should apply default values correctly", () => {
48
+ const condition = {
49
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
50
+ };
51
+ const props = {
52
+ name: "default-activity-log-alert",
53
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
54
+ scopes: ["/subscriptions/test-sub"],
55
+ condition,
56
+ };
57
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "DefaultActivityLogAlert", props);
58
+ expect(activityLogAlert).toBeInstanceOf(activity_log_alert_1.ActivityLogAlert);
59
+ expect(activityLogAlert.props.enabled).toBeUndefined(); // Should use default in createResourceBody
60
+ });
61
+ it("should assign all properties correctly", () => {
62
+ const condition = {
63
+ allOf: [
64
+ { field: "category", equalsValue: "Security" },
65
+ {
66
+ field: "operationName",
67
+ equalsValue: "Microsoft.Security/locations/alerts/activate/action",
68
+ },
69
+ ],
70
+ };
71
+ const actions = {
72
+ actionGroups: [
73
+ {
74
+ actionGroupId: "/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/test-ag",
75
+ },
76
+ ],
77
+ };
78
+ const props = {
79
+ name: "full-activity-log-alert",
80
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
81
+ description: "Alert for security events",
82
+ enabled: false,
83
+ scopes: ["/subscriptions/test-sub"],
84
+ condition,
85
+ actions,
86
+ tags: {
87
+ environment: "test",
88
+ team: "security",
89
+ },
90
+ };
91
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "FullActivityLogAlert", props);
92
+ expect(activityLogAlert.props.name).toBe("full-activity-log-alert");
93
+ expect(activityLogAlert.props.description).toBe("Alert for security events");
94
+ expect(activityLogAlert.props.enabled).toBe(false);
95
+ expect(activityLogAlert.props.condition).toEqual(condition);
96
+ expect(activityLogAlert.props.actions).toEqual(actions);
97
+ expect(activityLogAlert.props.tags).toEqual({
98
+ environment: "test",
99
+ team: "security",
100
+ });
101
+ });
102
+ it("should verify schema registration occurs", () => {
103
+ const condition = {
104
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
105
+ };
106
+ // Create first activity log alert to trigger schema registration
107
+ new activity_log_alert_1.ActivityLogAlert(stack, "FirstActivityLogAlert", {
108
+ name: "first-alert",
109
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
110
+ scopes: ["/subscriptions/test-sub"],
111
+ condition,
112
+ });
113
+ // Create second activity log alert to verify schemas are already registered
114
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "SecondActivityLogAlert", {
115
+ name: "second-alert",
116
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
117
+ scopes: ["/subscriptions/test-sub"],
118
+ condition,
119
+ });
120
+ expect(activityLogAlert).toBeInstanceOf(activity_log_alert_1.ActivityLogAlert);
121
+ });
122
+ });
123
+ // =============================================================================
124
+ // Version Resolution
125
+ // =============================================================================
126
+ describe("Version Resolution", () => {
127
+ it("should use default version 2020-10-01 when no version specified", () => {
128
+ const condition = {
129
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
130
+ };
131
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "DefaultVersion", {
132
+ name: "default-version-alert",
133
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
134
+ scopes: ["/subscriptions/test-sub"],
135
+ condition,
136
+ });
137
+ expect(activityLogAlert.resolvedApiVersion).toBe("2020-10-01");
138
+ });
139
+ it("should use explicit version when specified", () => {
140
+ const condition = {
141
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
142
+ };
143
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "PinnedVersion", {
144
+ name: "pinned-version-alert",
145
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
146
+ scopes: ["/subscriptions/test-sub"],
147
+ condition,
148
+ apiVersion: "2020-10-01",
149
+ });
150
+ expect(activityLogAlert.resolvedApiVersion).toBe("2020-10-01");
151
+ });
152
+ it("should apply version configuration correctly", () => {
153
+ const condition = {
154
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
155
+ };
156
+ const props = {
157
+ name: "versioned-alert",
158
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
159
+ scopes: ["/subscriptions/test-sub"],
160
+ condition,
161
+ apiVersion: "2020-10-01",
162
+ };
163
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "VersionedAlert", props);
164
+ expect(activityLogAlert.resolvedApiVersion).toBe("2020-10-01");
165
+ expect(activityLogAlert).toBeInstanceOf(activity_log_alert_1.ActivityLogAlert);
166
+ });
167
+ });
168
+ // =============================================================================
169
+ // Category Types
170
+ // =============================================================================
171
+ describe("Category Types", () => {
172
+ it("should configure alert for Administrative category", () => {
173
+ const condition = {
174
+ allOf: [
175
+ { field: "category", equalsValue: "Administrative" },
176
+ {
177
+ field: "operationName",
178
+ equalsValue: "Microsoft.Compute/virtualMachines/delete",
179
+ },
180
+ ],
181
+ };
182
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "AdministrativeAlert", {
183
+ name: "administrative-alert",
184
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
185
+ scopes: ["/subscriptions/test-sub"],
186
+ condition,
187
+ });
188
+ expect(activityLogAlert.props.condition.allOf[0].equalsValue).toBe("Administrative");
189
+ });
190
+ it("should configure alert for ServiceHealth category", () => {
191
+ const condition = {
192
+ allOf: [
193
+ { field: "category", equalsValue: "ServiceHealth" },
194
+ { field: "properties.incidentType", equalsValue: "Incident" },
195
+ ],
196
+ };
197
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "ServiceHealthAlert", {
198
+ name: "service-health-alert",
199
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
200
+ scopes: ["/subscriptions/test-sub"],
201
+ condition,
202
+ });
203
+ expect(activityLogAlert.props.condition.allOf[0].equalsValue).toBe("ServiceHealth");
204
+ });
205
+ it("should configure alert for ResourceHealth category", () => {
206
+ const condition = {
207
+ allOf: [
208
+ { field: "category", equalsValue: "ResourceHealth" },
209
+ {
210
+ field: "properties.currentHealthStatus",
211
+ equalsValue: "Unavailable",
212
+ },
213
+ ],
214
+ };
215
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "ResourceHealthAlert", {
216
+ name: "resource-health-alert",
217
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
218
+ scopes: ["/subscriptions/test-sub"],
219
+ condition,
220
+ });
221
+ expect(activityLogAlert.props.condition.allOf[0].equalsValue).toBe("ResourceHealth");
222
+ });
223
+ it("should configure alert for Security category", () => {
224
+ const condition = {
225
+ allOf: [
226
+ { field: "category", equalsValue: "Security" },
227
+ {
228
+ field: "operationName",
229
+ equalsValue: "Microsoft.Security/locations/alerts/activate/action",
230
+ },
231
+ ],
232
+ };
233
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "SecurityAlert", {
234
+ name: "security-alert",
235
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
236
+ scopes: ["/subscriptions/test-sub"],
237
+ condition,
238
+ });
239
+ expect(activityLogAlert.props.condition.allOf[0].equalsValue).toBe("Security");
240
+ });
241
+ it("should configure alert for Alert category", () => {
242
+ const condition = {
243
+ allOf: [
244
+ { field: "category", equalsValue: "Alert" },
245
+ {
246
+ field: "operationName",
247
+ equalsValue: "Microsoft.Insights/metricAlerts/write",
248
+ },
249
+ ],
250
+ };
251
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "AlertCategoryAlert", {
252
+ name: "alert-category-alert",
253
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
254
+ scopes: ["/subscriptions/test-sub"],
255
+ condition,
256
+ });
257
+ expect(activityLogAlert.props.condition.allOf[0].equalsValue).toBe("Alert");
258
+ });
259
+ it("should configure alert for Autoscale category", () => {
260
+ const condition = {
261
+ allOf: [
262
+ { field: "category", equalsValue: "Autoscale" },
263
+ {
264
+ field: "operationName",
265
+ equalsValue: "Microsoft.Insights/AutoscaleSettings/ScaleUpAction",
266
+ },
267
+ ],
268
+ };
269
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "AutoscaleAlert", {
270
+ name: "autoscale-alert",
271
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
272
+ scopes: ["/subscriptions/test-sub"],
273
+ condition,
274
+ });
275
+ expect(activityLogAlert.props.condition.allOf[0].equalsValue).toBe("Autoscale");
276
+ });
277
+ });
278
+ // =============================================================================
279
+ // Condition Filtering
280
+ // =============================================================================
281
+ describe("Condition Filtering", () => {
282
+ it("should configure single condition", () => {
283
+ const condition = {
284
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
285
+ };
286
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "SingleCondition", {
287
+ name: "single-condition-alert",
288
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
289
+ scopes: ["/subscriptions/test-sub"],
290
+ condition,
291
+ });
292
+ expect(activityLogAlert.props.condition.allOf).toHaveLength(1);
293
+ expect(activityLogAlert.props.condition.allOf[0].field).toBe("category");
294
+ });
295
+ it("should configure multiple conditions with AND logic", () => {
296
+ const condition = {
297
+ allOf: [
298
+ { field: "category", equalsValue: "Administrative" },
299
+ {
300
+ field: "operationName",
301
+ equalsValue: "Microsoft.Storage/storageAccounts/write",
302
+ },
303
+ { field: "status", equalsValue: "Succeeded" },
304
+ ],
305
+ };
306
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "MultipleConditions", {
307
+ name: "multi-condition-alert",
308
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
309
+ scopes: ["/subscriptions/test-sub"],
310
+ condition,
311
+ });
312
+ expect(activityLogAlert.props.condition.allOf).toHaveLength(3);
313
+ expect(activityLogAlert.props.condition.allOf[1].field).toBe("operationName");
314
+ expect(activityLogAlert.props.condition.allOf[2].field).toBe("status");
315
+ });
316
+ it("should filter by operation name", () => {
317
+ const condition = {
318
+ allOf: [
319
+ { field: "category", equalsValue: "Administrative" },
320
+ {
321
+ field: "operationName",
322
+ equalsValue: "Microsoft.Compute/virtualMachines/write",
323
+ },
324
+ ],
325
+ };
326
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "OperationNameFilter", {
327
+ name: "operation-name-alert",
328
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
329
+ scopes: ["/subscriptions/test-sub"],
330
+ condition,
331
+ });
332
+ expect(activityLogAlert.props.condition.allOf[1].equalsValue).toBe("Microsoft.Compute/virtualMachines/write");
333
+ });
334
+ it("should filter by resource type", () => {
335
+ const condition = {
336
+ allOf: [
337
+ { field: "category", equalsValue: "Administrative" },
338
+ {
339
+ field: "resourceType",
340
+ equalsValue: "Microsoft.Compute/virtualMachines",
341
+ },
342
+ ],
343
+ };
344
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "ResourceTypeFilter", {
345
+ name: "resource-type-alert",
346
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
347
+ scopes: ["/subscriptions/test-sub"],
348
+ condition,
349
+ });
350
+ const resourceTypeCondition = activityLogAlert.props.condition.allOf.find((c) => c.field === "resourceType");
351
+ expect(resourceTypeCondition?.equalsValue).toBe("Microsoft.Compute/virtualMachines");
352
+ });
353
+ it("should filter by status Succeeded", () => {
354
+ const condition = {
355
+ allOf: [
356
+ { field: "category", equalsValue: "Administrative" },
357
+ { field: "status", equalsValue: "Succeeded" },
358
+ ],
359
+ };
360
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "StatusSucceededFilter", {
361
+ name: "status-succeeded-alert",
362
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
363
+ scopes: ["/subscriptions/test-sub"],
364
+ condition,
365
+ });
366
+ const statusCondition = activityLogAlert.props.condition.allOf.find((c) => c.field === "status");
367
+ expect(statusCondition?.equalsValue).toBe("Succeeded");
368
+ });
369
+ it("should filter by status Failed", () => {
370
+ const condition = {
371
+ allOf: [
372
+ { field: "category", equalsValue: "Administrative" },
373
+ {
374
+ field: "operationName",
375
+ equalsValue: "Microsoft.Network/networkSecurityGroups/delete",
376
+ },
377
+ { field: "status", equalsValue: "Failed" },
378
+ ],
379
+ };
380
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "StatusFailedFilter", {
381
+ name: "status-failed-alert",
382
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
383
+ scopes: ["/subscriptions/test-sub"],
384
+ condition,
385
+ });
386
+ const statusCondition = activityLogAlert.props.condition.allOf.find((c) => c.field === "status");
387
+ expect(statusCondition?.equalsValue).toBe("Failed");
388
+ });
389
+ it("should filter by status Started", () => {
390
+ const condition = {
391
+ allOf: [
392
+ { field: "category", equalsValue: "Administrative" },
393
+ { field: "status", equalsValue: "Started" },
394
+ ],
395
+ };
396
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "StatusStartedFilter", {
397
+ name: "status-started-alert",
398
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
399
+ scopes: ["/subscriptions/test-sub"],
400
+ condition,
401
+ });
402
+ const statusCondition = activityLogAlert.props.condition.allOf.find((c) => c.field === "status");
403
+ expect(statusCondition?.equalsValue).toBe("Started");
404
+ });
405
+ it("should filter by resource group", () => {
406
+ const condition = {
407
+ allOf: [
408
+ { field: "category", equalsValue: "Administrative" },
409
+ { field: "resourceGroup", equalsValue: "production-rg" },
410
+ ],
411
+ };
412
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "ResourceGroupFilter", {
413
+ name: "resource-group-alert",
414
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
415
+ scopes: ["/subscriptions/test-sub"],
416
+ condition,
417
+ });
418
+ const rgCondition = activityLogAlert.props.condition.allOf.find((c) => c.field === "resourceGroup");
419
+ expect(rgCondition?.equalsValue).toBe("production-rg");
420
+ });
421
+ it("should filter by subStatus", () => {
422
+ const condition = {
423
+ allOf: [
424
+ { field: "category", equalsValue: "Administrative" },
425
+ { field: "subStatus", equalsValue: "Created" },
426
+ ],
427
+ };
428
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "SubStatusFilter", {
429
+ name: "substatus-alert",
430
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
431
+ scopes: ["/subscriptions/test-sub"],
432
+ condition,
433
+ });
434
+ const subStatusCondition = activityLogAlert.props.condition.allOf.find((c) => c.field === "subStatus");
435
+ expect(subStatusCondition?.equalsValue).toBe("Created");
436
+ });
437
+ });
438
+ // =============================================================================
439
+ // Scope Configuration
440
+ // =============================================================================
441
+ describe("Scope Configuration", () => {
442
+ it("should configure subscription-level scope", () => {
443
+ const condition = {
444
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
445
+ };
446
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "SubscriptionScope", {
447
+ name: "subscription-scope-alert",
448
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
449
+ scopes: ["/subscriptions/00000000-0000-0000-0000-000000000000"],
450
+ condition,
451
+ });
452
+ expect(activityLogAlert.props.scopes).toHaveLength(1);
453
+ expect(activityLogAlert.props.scopes[0]).toContain("/subscriptions/");
454
+ });
455
+ it("should configure resource group scope", () => {
456
+ const condition = {
457
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
458
+ };
459
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "ResourceGroupScope", {
460
+ name: "rg-scope-alert",
461
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
462
+ scopes: ["/subscriptions/test-sub/resourceGroups/production-rg"],
463
+ condition,
464
+ });
465
+ expect(activityLogAlert.props.scopes[0]).toContain("/resourceGroups/");
466
+ });
467
+ it("should configure specific resource scope", () => {
468
+ const condition = {
469
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
470
+ };
471
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "ResourceScope", {
472
+ name: "resource-scope-alert",
473
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
474
+ scopes: [
475
+ "/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Storage/storageAccounts/myaccount",
476
+ ],
477
+ condition,
478
+ });
479
+ expect(activityLogAlert.props.scopes[0]).toContain("/providers/Microsoft.Storage/");
480
+ });
481
+ it("should configure multiple scopes", () => {
482
+ const condition = {
483
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
484
+ };
485
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "MultipleScopes", {
486
+ name: "multi-scope-alert",
487
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
488
+ scopes: [
489
+ "/subscriptions/test-sub/resourceGroups/rg1",
490
+ "/subscriptions/test-sub/resourceGroups/rg2",
491
+ "/subscriptions/test-sub/resourceGroups/rg3",
492
+ ],
493
+ condition,
494
+ });
495
+ expect(activityLogAlert.props.scopes).toHaveLength(3);
496
+ });
497
+ });
498
+ // =============================================================================
499
+ // Operation Name Filtering
500
+ // =============================================================================
501
+ describe("Operation Name Filtering", () => {
502
+ it("should filter storage account operations", () => {
503
+ const condition = {
504
+ allOf: [
505
+ { field: "category", equalsValue: "Administrative" },
506
+ {
507
+ field: "operationName",
508
+ equalsValue: "Microsoft.Storage/storageAccounts/write",
509
+ },
510
+ ],
511
+ };
512
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "StorageOperation", {
513
+ name: "storage-operation-alert",
514
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
515
+ scopes: ["/subscriptions/test-sub"],
516
+ condition,
517
+ });
518
+ expect(activityLogAlert.props.condition.allOf[1].equalsValue).toBe("Microsoft.Storage/storageAccounts/write");
519
+ });
520
+ it("should filter virtual machine operations", () => {
521
+ const condition = {
522
+ allOf: [
523
+ { field: "category", equalsValue: "Administrative" },
524
+ {
525
+ field: "operationName",
526
+ equalsValue: "Microsoft.Compute/virtualMachines/delete",
527
+ },
528
+ ],
529
+ };
530
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "VMOperation", {
531
+ name: "vm-operation-alert",
532
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
533
+ scopes: ["/subscriptions/test-sub"],
534
+ condition,
535
+ });
536
+ expect(activityLogAlert.props.condition.allOf[1].equalsValue).toBe("Microsoft.Compute/virtualMachines/delete");
537
+ });
538
+ it("should filter network security group operations", () => {
539
+ const condition = {
540
+ allOf: [
541
+ { field: "category", equalsValue: "Administrative" },
542
+ {
543
+ field: "operationName",
544
+ equalsValue: "Microsoft.Network/networkSecurityGroups/securityRules/write",
545
+ },
546
+ ],
547
+ };
548
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "NSGOperation", {
549
+ name: "nsg-operation-alert",
550
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
551
+ scopes: ["/subscriptions/test-sub"],
552
+ condition,
553
+ });
554
+ expect(activityLogAlert.props.condition.allOf[1].equalsValue).toBe("Microsoft.Network/networkSecurityGroups/securityRules/write");
555
+ });
556
+ it("should filter SQL database operations", () => {
557
+ const condition = {
558
+ allOf: [
559
+ { field: "category", equalsValue: "Administrative" },
560
+ {
561
+ field: "operationName",
562
+ equalsValue: "Microsoft.Sql/servers/databases/write",
563
+ },
564
+ ],
565
+ };
566
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "SQLOperation", {
567
+ name: "sql-operation-alert",
568
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
569
+ scopes: ["/subscriptions/test-sub"],
570
+ condition,
571
+ });
572
+ expect(activityLogAlert.props.condition.allOf[1].equalsValue).toBe("Microsoft.Sql/servers/databases/write");
573
+ });
574
+ it("should filter key vault operations", () => {
575
+ const condition = {
576
+ allOf: [
577
+ { field: "category", equalsValue: "Administrative" },
578
+ {
579
+ field: "operationName",
580
+ equalsValue: "Microsoft.KeyVault/vaults/delete",
581
+ },
582
+ ],
583
+ };
584
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "KeyVaultOperation", {
585
+ name: "keyvault-operation-alert",
586
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
587
+ scopes: ["/subscriptions/test-sub"],
588
+ condition,
589
+ });
590
+ expect(activityLogAlert.props.condition.allOf[1].equalsValue).toBe("Microsoft.KeyVault/vaults/delete");
591
+ });
592
+ });
593
+ // =============================================================================
594
+ // Action Group Integration
595
+ // =============================================================================
596
+ describe("Action Group Integration", () => {
597
+ it("should configure single action group", () => {
598
+ const condition = {
599
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
600
+ };
601
+ const actions = {
602
+ actionGroups: [
603
+ {
604
+ actionGroupId: "/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/ops-ag",
605
+ },
606
+ ],
607
+ };
608
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "SingleAction", {
609
+ name: "single-action-alert",
610
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
611
+ scopes: ["/subscriptions/test-sub"],
612
+ condition,
613
+ actions,
614
+ });
615
+ expect(activityLogAlert.props.actions?.actionGroups).toHaveLength(1);
616
+ expect(activityLogAlert.props.actions?.actionGroups[0].actionGroupId).toContain("ops-ag");
617
+ });
618
+ it("should configure multiple action groups", () => {
619
+ const condition = {
620
+ allOf: [{ field: "category", equalsValue: "Security" }],
621
+ };
622
+ const actions = {
623
+ actionGroups: [
624
+ {
625
+ actionGroupId: "/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/ops-ag",
626
+ },
627
+ {
628
+ actionGroupId: "/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/security-ag",
629
+ },
630
+ ],
631
+ };
632
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "MultipleActions", {
633
+ name: "multi-action-alert",
634
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
635
+ scopes: ["/subscriptions/test-sub"],
636
+ condition,
637
+ actions,
638
+ });
639
+ expect(activityLogAlert.props.actions?.actionGroups).toHaveLength(2);
640
+ });
641
+ it("should configure action with webhook properties", () => {
642
+ const condition = {
643
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
644
+ };
645
+ const actions = {
646
+ actionGroups: [
647
+ {
648
+ actionGroupId: "/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/webhook-ag",
649
+ webhookProperties: {
650
+ customProperty1: "value1",
651
+ customProperty2: "value2",
652
+ },
653
+ },
654
+ ],
655
+ };
656
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "WebhookAction", {
657
+ name: "webhook-action-alert",
658
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
659
+ scopes: ["/subscriptions/test-sub"],
660
+ condition,
661
+ actions,
662
+ });
663
+ expect(activityLogAlert.props.actions?.actionGroups[0].webhookProperties).toEqual({
664
+ customProperty1: "value1",
665
+ customProperty2: "value2",
666
+ });
667
+ });
668
+ it("should handle alert without actions", () => {
669
+ const condition = {
670
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
671
+ };
672
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "NoActions", {
673
+ name: "no-actions-alert",
674
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
675
+ scopes: ["/subscriptions/test-sub"],
676
+ condition,
677
+ });
678
+ expect(activityLogAlert.props.actions).toBeUndefined();
679
+ });
680
+ });
681
+ // =============================================================================
682
+ // Property Transformation
683
+ // =============================================================================
684
+ describe("Property Transformation", () => {
685
+ it("should generate correct Azure API format via createResourceBody", () => {
686
+ const condition = {
687
+ allOf: [
688
+ { field: "category", equalsValue: "Administrative" },
689
+ {
690
+ field: "operationName",
691
+ equalsValue: "Microsoft.Compute/virtualMachines/delete",
692
+ },
693
+ ],
694
+ };
695
+ const props = {
696
+ name: "transform-test",
697
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
698
+ scopes: ["/subscriptions/test-sub"],
699
+ condition,
700
+ tags: {
701
+ environment: "production",
702
+ },
703
+ };
704
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "TransformTest", props);
705
+ // Access the protected createResourceBody method via the instance
706
+ const resourceBody = activityLogAlert.createResourceBody(props);
707
+ expect(resourceBody).toHaveProperty("location");
708
+ expect(resourceBody).toHaveProperty("tags");
709
+ expect(resourceBody).toHaveProperty("properties");
710
+ expect(resourceBody.properties).toHaveProperty("scopes");
711
+ expect(resourceBody.properties).toHaveProperty("condition");
712
+ expect(resourceBody.properties).toHaveProperty("enabled");
713
+ });
714
+ it("should set location to global", () => {
715
+ const condition = {
716
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
717
+ };
718
+ const props = {
719
+ name: "location-test",
720
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
721
+ scopes: ["/subscriptions/test-sub"],
722
+ condition,
723
+ };
724
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "LocationTest", props);
725
+ const resourceBody = activityLogAlert.createResourceBody(props);
726
+ expect(resourceBody.location).toBe("global");
727
+ });
728
+ it("should transform tags correctly", () => {
729
+ const condition = {
730
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
731
+ };
732
+ const props = {
733
+ name: "tags-test",
734
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
735
+ scopes: ["/subscriptions/test-sub"],
736
+ condition,
737
+ tags: {
738
+ environment: "dev",
739
+ owner: "platform-team",
740
+ cost_center: "engineering",
741
+ },
742
+ };
743
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "TagsTest", props);
744
+ const resourceBody = activityLogAlert.createResourceBody(props);
745
+ expect(resourceBody.tags).toEqual({
746
+ environment: "dev",
747
+ owner: "platform-team",
748
+ cost_center: "engineering",
749
+ });
750
+ });
751
+ it("should format condition object properly", () => {
752
+ const condition = {
753
+ allOf: [
754
+ { field: "category", equalsValue: "Administrative" },
755
+ {
756
+ field: "operationName",
757
+ equalsValue: "Microsoft.Storage/storageAccounts/write",
758
+ },
759
+ { field: "status", equalsValue: "Succeeded" },
760
+ ],
761
+ };
762
+ const props = {
763
+ name: "condition-test",
764
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
765
+ scopes: ["/subscriptions/test-sub"],
766
+ condition,
767
+ };
768
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "ConditionTest", props);
769
+ const resourceBody = activityLogAlert.createResourceBody(props);
770
+ expect(resourceBody.properties.condition).toHaveProperty("allOf");
771
+ expect(resourceBody.properties.condition.allOf).toHaveLength(3);
772
+ expect(resourceBody.properties.condition.allOf[0]).toHaveProperty("field");
773
+ expect(resourceBody.properties.condition.allOf[0]).toHaveProperty("equals");
774
+ });
775
+ it("should apply default enabled value", () => {
776
+ const condition = {
777
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
778
+ };
779
+ const props = {
780
+ name: "default-enabled-test",
781
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
782
+ scopes: ["/subscriptions/test-sub"],
783
+ condition,
784
+ };
785
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "DefaultEnabledTest", props);
786
+ const resourceBody = activityLogAlert.createResourceBody(props);
787
+ expect(resourceBody.properties.enabled).toBe(true);
788
+ });
789
+ it("should respect explicit enabled value", () => {
790
+ const condition = {
791
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
792
+ };
793
+ const props = {
794
+ name: "explicit-enabled-test",
795
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
796
+ scopes: ["/subscriptions/test-sub"],
797
+ condition,
798
+ enabled: false,
799
+ };
800
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "ExplicitEnabledTest", props);
801
+ const resourceBody = activityLogAlert.createResourceBody(props);
802
+ expect(resourceBody.properties.enabled).toBe(false);
803
+ });
804
+ });
805
+ // =============================================================================
806
+ // Integration with Base Class
807
+ // =============================================================================
808
+ describe("Integration with Base Class", () => {
809
+ it("should inherit from AzapiResource", () => {
810
+ const condition = {
811
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
812
+ };
813
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "InheritanceTest", {
814
+ name: "inheritance-test",
815
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
816
+ scopes: ["/subscriptions/test-sub"],
817
+ condition,
818
+ });
819
+ // Verify it has AzapiResource properties
820
+ expect(activityLogAlert).toHaveProperty("terraformResource");
821
+ expect(activityLogAlert).toHaveProperty("resolvedApiVersion");
822
+ });
823
+ it("should have correct azapiResourceType", () => {
824
+ const condition = {
825
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
826
+ };
827
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "ResourceTypeTest", {
828
+ name: "resource-type-test",
829
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
830
+ scopes: ["/subscriptions/test-sub"],
831
+ condition,
832
+ });
833
+ // Access the protected resourceType method
834
+ const resourceType = activityLogAlert.resourceType();
835
+ expect(resourceType).toBe("Microsoft.Insights/activityLogAlerts");
836
+ });
837
+ it("should generate resource outputs", () => {
838
+ const condition = {
839
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
840
+ };
841
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "OutputsTest", {
842
+ name: "outputs-test",
843
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
844
+ scopes: ["/subscriptions/test-sub"],
845
+ condition,
846
+ });
847
+ expect(activityLogAlert.idOutput).toBeInstanceOf(cdktf.TerraformOutput);
848
+ expect(activityLogAlert.nameOutput).toBeInstanceOf(cdktf.TerraformOutput);
849
+ expect(activityLogAlert.id).toMatch(/^\$\{.*\.id\}$/);
850
+ });
851
+ });
852
+ // =============================================================================
853
+ // Tag Management
854
+ // =============================================================================
855
+ describe("Tag Management", () => {
856
+ it("should add tags using addTag method", () => {
857
+ const condition = {
858
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
859
+ };
860
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "AddTagTest", {
861
+ name: "add-tag-test",
862
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
863
+ scopes: ["/subscriptions/test-sub"],
864
+ condition,
865
+ tags: {
866
+ initial: "value",
867
+ },
868
+ });
869
+ activityLogAlert.addTag("newTag", "newValue");
870
+ expect(activityLogAlert.props.tags).toHaveProperty("newTag", "newValue");
871
+ expect(activityLogAlert.props.tags).toHaveProperty("initial", "value");
872
+ });
873
+ it("should remove tags using removeTag method", () => {
874
+ const condition = {
875
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
876
+ };
877
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "RemoveTagTest", {
878
+ name: "remove-tag-test",
879
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
880
+ scopes: ["/subscriptions/test-sub"],
881
+ condition,
882
+ tags: {
883
+ toRemove: "value",
884
+ toKeep: "value",
885
+ },
886
+ });
887
+ activityLogAlert.removeTag("toRemove");
888
+ expect(activityLogAlert.props.tags).not.toHaveProperty("toRemove");
889
+ expect(activityLogAlert.props.tags).toHaveProperty("toKeep", "value");
890
+ });
891
+ it("should initialize tags object when adding to undefined tags", () => {
892
+ const condition = {
893
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
894
+ };
895
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "InitTagTest", {
896
+ name: "init-tag-test",
897
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
898
+ scopes: ["/subscriptions/test-sub"],
899
+ condition,
900
+ });
901
+ activityLogAlert.addTag("firstTag", "firstValue");
902
+ expect(activityLogAlert.props.tags).toHaveProperty("firstTag", "firstValue");
903
+ });
904
+ });
905
+ // =============================================================================
906
+ // CDK Terraform Integration
907
+ // =============================================================================
908
+ describe("CDK Terraform Integration", () => {
909
+ it("should synthesize to valid Terraform configuration", () => {
910
+ const condition = {
911
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
912
+ };
913
+ new activity_log_alert_1.ActivityLogAlert(stack, "SynthTest", {
914
+ name: "synth-test",
915
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
916
+ scopes: ["/subscriptions/test-sub"],
917
+ condition,
918
+ });
919
+ const synthesized = cdktf_1.Testing.synth(stack);
920
+ expect(synthesized).toBeDefined();
921
+ const stackConfig = JSON.parse(synthesized);
922
+ expect(stackConfig.resource).toBeDefined();
923
+ });
924
+ it("should handle multiple activity log alerts in the same stack", () => {
925
+ const condition1 = {
926
+ allOf: [{ field: "category", equalsValue: "Administrative" }],
927
+ };
928
+ const condition2 = {
929
+ allOf: [{ field: "category", equalsValue: "ServiceHealth" }],
930
+ };
931
+ const alert1 = new activity_log_alert_1.ActivityLogAlert(stack, "ActivityLogAlert1", {
932
+ name: "alert-1",
933
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
934
+ scopes: ["/subscriptions/test-sub"],
935
+ condition: condition1,
936
+ });
937
+ const alert2 = new activity_log_alert_1.ActivityLogAlert(stack, "ActivityLogAlert2", {
938
+ name: "alert-2",
939
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
940
+ scopes: ["/subscriptions/test-sub"],
941
+ condition: condition2,
942
+ apiVersion: "2020-10-01",
943
+ });
944
+ expect(alert1.resolvedApiVersion).toBe("2020-10-01");
945
+ expect(alert2.resolvedApiVersion).toBe("2020-10-01");
946
+ const synthesized = cdktf_1.Testing.synth(stack);
947
+ expect(synthesized).toBeDefined();
948
+ });
949
+ });
950
+ // =============================================================================
951
+ // Complex Scenarios
952
+ // =============================================================================
953
+ describe("Complex Scenarios", () => {
954
+ it("should handle comprehensive VM deletion alert", () => {
955
+ const condition = {
956
+ allOf: [
957
+ { field: "category", equalsValue: "Administrative" },
958
+ {
959
+ field: "operationName",
960
+ equalsValue: "Microsoft.Compute/virtualMachines/delete",
961
+ },
962
+ { field: "status", equalsValue: "Succeeded" },
963
+ { field: "resourceGroup", equalsValue: "production-rg" },
964
+ ],
965
+ };
966
+ const actions = {
967
+ actionGroups: [
968
+ {
969
+ actionGroupId: "/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/critical-ag",
970
+ webhookProperties: {
971
+ severity: "critical",
972
+ alertType: "vm-deletion",
973
+ },
974
+ },
975
+ {
976
+ actionGroupId: "/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/audit-ag",
977
+ },
978
+ ],
979
+ };
980
+ const props = {
981
+ name: "comprehensive-vm-deletion-alert",
982
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
983
+ description: "Alert when production VMs are deleted",
984
+ enabled: true,
985
+ scopes: ["/subscriptions/test-sub"],
986
+ condition,
987
+ actions,
988
+ tags: {
989
+ environment: "production",
990
+ criticality: "high",
991
+ team: "ops",
992
+ alertCategory: "security",
993
+ },
994
+ };
995
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "ComprehensiveAlert", props);
996
+ const resourceBody = activityLogAlert.createResourceBody(props);
997
+ expect(resourceBody.properties.condition.allOf).toHaveLength(4);
998
+ expect(resourceBody.properties.actions.actionGroups).toHaveLength(2);
999
+ expect(resourceBody.properties.enabled).toBe(true);
1000
+ expect(resourceBody.tags).toHaveProperty("alertCategory", "security");
1001
+ });
1002
+ it("should handle service health incident alert", () => {
1003
+ const condition = {
1004
+ allOf: [
1005
+ { field: "category", equalsValue: "ServiceHealth" },
1006
+ { field: "properties.incidentType", equalsValue: "Incident" },
1007
+ {
1008
+ field: "properties.impactedServices[*].ServiceName",
1009
+ equalsValue: "Virtual Machines",
1010
+ },
1011
+ ],
1012
+ };
1013
+ const actions = {
1014
+ actionGroups: [
1015
+ {
1016
+ actionGroupId: "/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/oncall-ag",
1017
+ },
1018
+ ],
1019
+ };
1020
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "ServiceHealthAlert", {
1021
+ name: "service-health-incident",
1022
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
1023
+ description: "Alert on Azure service health incidents affecting VMs",
1024
+ scopes: ["/subscriptions/test-sub"],
1025
+ condition,
1026
+ actions,
1027
+ });
1028
+ expect(activityLogAlert.props.condition.allOf).toHaveLength(3);
1029
+ expect(activityLogAlert.props.condition.allOf[0].equalsValue).toBe("ServiceHealth");
1030
+ });
1031
+ it("should handle resource health degraded alert", () => {
1032
+ const condition = {
1033
+ allOf: [
1034
+ { field: "category", equalsValue: "ResourceHealth" },
1035
+ { field: "properties.currentHealthStatus", equalsValue: "Degraded" },
1036
+ { field: "properties.cause", equalsValue: "PlatformInitiated" },
1037
+ {
1038
+ field: "resourceType",
1039
+ equalsValue: "Microsoft.Compute/virtualMachines",
1040
+ },
1041
+ ],
1042
+ };
1043
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "ResourceHealthAlert", {
1044
+ name: "resource-health-degraded",
1045
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
1046
+ description: "Alert when VM health is degraded",
1047
+ scopes: ["/subscriptions/test-sub/resourceGroups/production-rg"],
1048
+ condition,
1049
+ actions: {
1050
+ actionGroups: [
1051
+ {
1052
+ actionGroupId: "/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/ops-ag",
1053
+ },
1054
+ ],
1055
+ },
1056
+ });
1057
+ expect(activityLogAlert.props.condition.allOf).toHaveLength(4);
1058
+ });
1059
+ it("should handle security alert with multiple conditions", () => {
1060
+ const condition = {
1061
+ allOf: [
1062
+ { field: "category", equalsValue: "Security" },
1063
+ {
1064
+ field: "operationName",
1065
+ equalsValue: "Microsoft.Security/locations/alerts/activate/action",
1066
+ },
1067
+ { field: "properties.severity", equalsValue: "High" },
1068
+ ],
1069
+ };
1070
+ const actions = {
1071
+ actionGroups: [
1072
+ {
1073
+ actionGroupId: "/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/security-ag",
1074
+ webhookProperties: {
1075
+ priority: "high",
1076
+ escalate: "true",
1077
+ },
1078
+ },
1079
+ ],
1080
+ };
1081
+ const activityLogAlert = new activity_log_alert_1.ActivityLogAlert(stack, "SecurityAlert", {
1082
+ name: "high-severity-security-alert",
1083
+ resourceGroupId: "/subscriptions/test-sub/resourceGroups/test-rg",
1084
+ description: "Alert on high-severity security events",
1085
+ enabled: true,
1086
+ scopes: ["/subscriptions/test-sub"],
1087
+ condition,
1088
+ actions,
1089
+ tags: {
1090
+ environment: "production",
1091
+ alertType: "security",
1092
+ severity: "high",
1093
+ },
1094
+ });
1095
+ const resourceBody = activityLogAlert.createResourceBody(activityLogAlert.props);
1096
+ expect(resourceBody.properties.condition.allOf).toHaveLength(3);
1097
+ expect(resourceBody.properties.actions.actionGroups[0].webhookProperties).toHaveProperty("escalate", "true");
1098
+ });
1099
+ });
1100
+ });
1101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity-log-alert.spec.js","sourceRoot":"","sources":["../../../src/azure-activitylogalert/test/activity-log-alert.spec.ts"],"names":[],"mappings":";AAAA;;;;;;;GAOG;;AAEH,iCAAgC;AAChC,+BAA+B;AAC/B,kEAImC;AAEnC,QAAQ,CAAC,mCAAmC,EAAE,GAAG,EAAE;IACjD,IAAI,GAAc,CAAC;IACnB,IAAI,KAA2B,CAAC;IAEhC,UAAU,CAAC,GAAG,EAAE;QACd,GAAG,GAAG,eAAO,CAAC,GAAG,EAAE,CAAC;QACpB,KAAK,GAAG,IAAI,KAAK,CAAC,cAAc,CAAC,GAAG,EAAE,WAAW,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;IAEH,gFAAgF;IAChF,mCAAmC;IACnC,gFAAgF;IAEhF,QAAQ,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAChD,EAAE,CAAC,mEAAmE,EAAE,GAAG,EAAE;YAC3E,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,0CAA0C;qBACxD;iBACF;aACF,CAAC;YAEF,MAAM,KAAK,GAA0B;gBACnC,IAAI,EAAE,yBAAyB;gBAC/B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,sBAAsB,EACtB,KAAK,CACN,CAAC;YAEF,MAAM,CAAC,gBAAgB,CAAC,CAAC,cAAc,CAAC,qCAAgB,CAAC,CAAC;YAC1D,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC3C,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;YACpE,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACxD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,uCAAuC,EAAE,GAAG,EAAE;YAC/C,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,KAAK,GAA0B;gBACnC,IAAI,EAAE,4BAA4B;gBAClC,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,yBAAyB,EACzB,KAAK,CACN,CAAC;YAEF,MAAM,CAAC,gBAAgB,CAAC,CAAC,cAAc,CAAC,qCAAgB,CAAC,CAAC;YAC1D,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,aAAa,EAAE,CAAC,CAAC,2CAA2C;QACrG,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,wCAAwC,EAAE,GAAG,EAAE;YAChD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,UAAU,EAAE;oBAC9C;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,qDAAqD;qBACnE;iBACF;aACF,CAAC;YAEF,MAAM,OAAO,GAAG;gBACd,YAAY,EAAE;oBACZ;wBACE,aAAa,EACX,kGAAkG;qBACrG;iBACF;aACF,CAAC;YAEF,MAAM,KAAK,GAA0B;gBACnC,IAAI,EAAE,yBAAyB;gBAC/B,eAAe,EAAE,gDAAgD;gBACjE,WAAW,EAAE,2BAA2B;gBACxC,OAAO,EAAE,KAAK;gBACd,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;gBACT,OAAO;gBACP,IAAI,EAAE;oBACJ,WAAW,EAAE,MAAM;oBACnB,IAAI,EAAE,UAAU;iBACjB;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,sBAAsB,EACtB,KAAK,CACN,CAAC;YAEF,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;YACpE,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,IAAI,CAC7C,2BAA2B,CAC5B,CAAC;YACF,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACnD,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YAC5D,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YACxD,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC;gBAC1C,WAAW,EAAE,MAAM;gBACnB,IAAI,EAAE,UAAU;aACjB,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;YAClD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,iEAAiE;YACjE,IAAI,qCAAgB,CAAC,KAAK,EAAE,uBAAuB,EAAE;gBACnD,IAAI,EAAE,aAAa;gBACnB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC,CAAC;YAEH,4EAA4E;YAC5E,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,wBAAwB,EACxB;gBACE,IAAI,EAAE,cAAc;gBACpB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CACF,CAAC;YAEF,MAAM,CAAC,gBAAgB,CAAC,CAAC,cAAc,CAAC,qCAAgB,CAAC,CAAC;QAC5D,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,gFAAgF;IAChF,qBAAqB;IACrB,gFAAgF;IAEhF,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;QAClC,EAAE,CAAC,iEAAiE,EAAE,GAAG,EAAE;YACzE,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,gBAAgB,EAAE;gBACrE,IAAI,EAAE,uBAAuB;gBAC7B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC,CAAC;YAEH,MAAM,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACjE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4CAA4C,EAAE,GAAG,EAAE;YACpD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,eAAe,EAAE;gBACpE,IAAI,EAAE,sBAAsB;gBAC5B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;gBACT,UAAU,EAAE,YAAY;aACzB,CAAC,CAAC;YAEH,MAAM,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACjE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,8CAA8C,EAAE,GAAG,EAAE;YACtD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,KAAK,GAA0B;gBACnC,IAAI,EAAE,iBAAiB;gBACvB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;gBACT,UAAU,EAAE,YAAY;aACzB,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,gBAAgB,EAChB,KAAK,CACN,CAAC;YAEF,MAAM,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAC/D,MAAM,CAAC,gBAAgB,CAAC,CAAC,cAAc,CAAC,qCAAgB,CAAC,CAAC;QAC5D,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,gFAAgF;IAChF,iBAAiB;IACjB,gFAAgF;IAEhF,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;QAC9B,EAAE,CAAC,oDAAoD,EAAE,GAAG,EAAE;YAC5D,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,0CAA0C;qBACxD;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,qBAAqB,EACrB;gBACE,IAAI,EAAE,sBAAsB;gBAC5B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CACF,CAAC;YAEF,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,IAAI,CAChE,gBAAgB,CACjB,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;YAC3D,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,eAAe,EAAE;oBACnD,EAAE,KAAK,EAAE,yBAAyB,EAAE,WAAW,EAAE,UAAU,EAAE;iBAC9D;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,oBAAoB,EACpB;gBACE,IAAI,EAAE,sBAAsB;gBAC5B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CACF,CAAC;YAEF,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,IAAI,CAChE,eAAe,CAChB,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,oDAAoD,EAAE,GAAG,EAAE;YAC5D,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD;wBACE,KAAK,EAAE,gCAAgC;wBACvC,WAAW,EAAE,aAAa;qBAC3B;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,qBAAqB,EACrB;gBACE,IAAI,EAAE,uBAAuB;gBAC7B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CACF,CAAC;YAEF,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,IAAI,CAChE,gBAAgB,CACjB,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,8CAA8C,EAAE,GAAG,EAAE;YACtD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,UAAU,EAAE;oBAC9C;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,qDAAqD;qBACnE;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,eAAe,EAAE;gBACpE,IAAI,EAAE,gBAAgB;gBACtB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC,CAAC;YAEH,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,IAAI,CAChE,UAAU,CACX,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;YACnD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,OAAO,EAAE;oBAC3C;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,uCAAuC;qBACrD;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,oBAAoB,EACpB;gBACE,IAAI,EAAE,sBAAsB;gBAC5B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CACF,CAAC;YAEF,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,IAAI,CAChE,OAAO,CACR,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,+CAA+C,EAAE,GAAG,EAAE;YACvD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,WAAW,EAAE;oBAC/C;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,oDAAoD;qBAClE;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,gBAAgB,EAAE;gBACrE,IAAI,EAAE,iBAAiB;gBACvB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC,CAAC;YAEH,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,IAAI,CAChE,WAAW,CACZ,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,gFAAgF;IAChF,sBAAsB;IACtB,gFAAgF;IAEhF,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;QACnC,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;YAC3C,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBACtE,IAAI,EAAE,wBAAwB;gBAC9B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC,CAAC;YAEH,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YAC/D,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC3E,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,qDAAqD,EAAE,GAAG,EAAE;YAC7D,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,yCAAyC;qBACvD;oBACD,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,WAAW,EAAE;iBAC9C;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,oBAAoB,EACpB;gBACE,IAAI,EAAE,uBAAuB;gBAC7B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CACF,CAAC;YAEF,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YAC/D,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI,CAC1D,eAAe,CAChB,CAAC;YACF,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACzE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;YACzC,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,yCAAyC;qBACvD;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,qBAAqB,EACrB;gBACE,IAAI,EAAE,sBAAsB;gBAC5B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CACF,CAAC;YAEF,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,IAAI,CAChE,yCAAyC,CAC1C,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;YACxC,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD;wBACE,KAAK,EAAE,cAAc;wBACrB,WAAW,EAAE,mCAAmC;qBACjD;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,oBAAoB,EACpB;gBACE,IAAI,EAAE,qBAAqB;gBAC3B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CACF,CAAC;YAEF,MAAM,qBAAqB,GAAG,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CACvE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,cAAc,CAClC,CAAC;YACF,MAAM,CAAC,qBAAqB,EAAE,WAAW,CAAC,CAAC,IAAI,CAC7C,mCAAmC,CACpC,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;YAC3C,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,WAAW,EAAE;iBAC9C;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,uBAAuB,EACvB;gBACE,IAAI,EAAE,wBAAwB;gBAC9B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CACF,CAAC;YAEF,MAAM,eAAe,GAAG,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CACjE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,QAAQ,CAC5B,CAAC;YACF,MAAM,CAAC,eAAe,EAAE,WAAW,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACzD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;YACxC,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,gDAAgD;qBAC9D;oBACD,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,QAAQ,EAAE;iBAC3C;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,oBAAoB,EACpB;gBACE,IAAI,EAAE,qBAAqB;gBAC3B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CACF,CAAC;YAEF,MAAM,eAAe,GAAG,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CACjE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,QAAQ,CAC5B,CAAC;YACF,MAAM,CAAC,eAAe,EAAE,WAAW,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACtD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;YACzC,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE;iBAC5C;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,qBAAqB,EACrB;gBACE,IAAI,EAAE,sBAAsB;gBAC5B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CACF,CAAC;YAEF,MAAM,eAAe,GAAG,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CACjE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,QAAQ,CAC5B,CAAC;YACF,MAAM,CAAC,eAAe,EAAE,WAAW,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACvD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;YACzC,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD,EAAE,KAAK,EAAE,eAAe,EAAE,WAAW,EAAE,eAAe,EAAE;iBACzD;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,qBAAqB,EACrB;gBACE,IAAI,EAAE,sBAAsB;gBAC5B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CACF,CAAC;YAEF,MAAM,WAAW,GAAG,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAC7D,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,eAAe,CACnC,CAAC;YACF,MAAM,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QACzD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;YACpC,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD,EAAE,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,SAAS,EAAE;iBAC/C;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBACtE,IAAI,EAAE,iBAAiB;gBACvB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC,CAAC;YAEH,MAAM,kBAAkB,GAAG,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CACpE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,WAAW,CAC/B,CAAC;YACF,MAAM,CAAC,kBAAkB,EAAE,WAAW,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,gFAAgF;IAChF,sBAAsB;IACtB,gFAAgF;IAEhF,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;QACnC,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;YACnD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,mBAAmB,EACnB;gBACE,IAAI,EAAE,0BAA0B;gBAChC,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,qDAAqD,CAAC;gBAC/D,SAAS;aACV,CACF,CAAC;YAEF,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YACtD,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,iBAAiB,CAAC,CAAC;QACxE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,uCAAuC,EAAE,GAAG,EAAE;YAC/C,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,oBAAoB,EACpB;gBACE,IAAI,EAAE,gBAAgB;gBACtB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,sDAAsD,CAAC;gBAChE,SAAS;aACV,CACF,CAAC;YAEF,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,kBAAkB,CAAC,CAAC;QACzE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;YAClD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,eAAe,EAAE;gBACpE,IAAI,EAAE,sBAAsB;gBAC5B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE;oBACN,sGAAsG;iBACvG;gBACD,SAAS;aACV,CAAC,CAAC;YAEH,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAChD,+BAA+B,CAChC,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;YAC1C,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,gBAAgB,EAAE;gBACrE,IAAI,EAAE,mBAAmB;gBACzB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE;oBACN,4CAA4C;oBAC5C,4CAA4C;oBAC5C,4CAA4C;iBAC7C;gBACD,SAAS;aACV,CAAC,CAAC;YAEH,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACxD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,gFAAgF;IAChF,2BAA2B;IAC3B,gFAAgF;IAEhF,QAAQ,CAAC,0BAA0B,EAAE,GAAG,EAAE;QACxC,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;YAClD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,yCAAyC;qBACvD;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,kBAAkB,EAAE;gBACvE,IAAI,EAAE,yBAAyB;gBAC/B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC,CAAC;YAEH,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,IAAI,CAChE,yCAAyC,CAC1C,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;YAClD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,0CAA0C;qBACxD;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAClE,IAAI,EAAE,oBAAoB;gBAC1B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC,CAAC;YAEH,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,IAAI,CAChE,0CAA0C,CAC3C,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;YACzD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EACT,6DAA6D;qBAChE;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,cAAc,EAAE;gBACnE,IAAI,EAAE,qBAAqB;gBAC3B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC,CAAC;YAEH,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,IAAI,CAChE,6DAA6D,CAC9D,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,uCAAuC,EAAE,GAAG,EAAE;YAC/C,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,uCAAuC;qBACrD;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,cAAc,EAAE;gBACnE,IAAI,EAAE,qBAAqB;gBAC3B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC,CAAC;YAEH,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,IAAI,CAChE,uCAAuC,CACxC,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;YAC5C,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,kCAAkC;qBAChD;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,mBAAmB,EACnB;gBACE,IAAI,EAAE,0BAA0B;gBAChC,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CACF,CAAC;YAEF,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,IAAI,CAChE,kCAAkC,CACnC,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,gFAAgF;IAChF,2BAA2B;IAC3B,gFAAgF;IAEhF,QAAQ,CAAC,0BAA0B,EAAE,GAAG,EAAE;QACxC,EAAE,CAAC,sCAAsC,EAAE,GAAG,EAAE;YAC9C,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,OAAO,GAAG;gBACd,YAAY,EAAE;oBACZ;wBACE,aAAa,EACX,iGAAiG;qBACpG;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,cAAc,EAAE;gBACnE,IAAI,EAAE,qBAAqB;gBAC3B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;gBACT,OAAO;aACR,CAAC,CAAC;YAEH,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YACrE,MAAM,CACJ,gBAAgB,CAAC,KAAK,CAAC,OAAO,EAAE,YAAa,CAAC,CAAC,CAAC,CAAC,aAAa,CAC/D,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACxB,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;YACjD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,UAAU,EAAE,CAAC;aACxD,CAAC;YAEF,MAAM,OAAO,GAAG;gBACd,YAAY,EAAE;oBACZ;wBACE,aAAa,EACX,iGAAiG;qBACpG;oBACD;wBACE,aAAa,EACX,sGAAsG;qBACzG;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBACtE,IAAI,EAAE,oBAAoB;gBAC1B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;gBACT,OAAO;aACR,CAAC,CAAC;YAEH,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACvE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;YACzD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,OAAO,GAAG;gBACd,YAAY,EAAE;oBACZ;wBACE,aAAa,EACX,qGAAqG;wBACvG,iBAAiB,EAAE;4BACjB,eAAe,EAAE,QAAQ;4BACzB,eAAe,EAAE,QAAQ;yBAC1B;qBACF;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,eAAe,EAAE;gBACpE,IAAI,EAAE,sBAAsB;gBAC5B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;gBACT,OAAO;aACR,CAAC,CAAC;YAEH,MAAM,CACJ,gBAAgB,CAAC,KAAK,CAAC,OAAO,EAAE,YAAa,CAAC,CAAC,CAAC,CAAC,iBAAiB,CACnE,CAAC,OAAO,CAAC;gBACR,eAAe,EAAE,QAAQ;gBACzB,eAAe,EAAE,QAAQ;aAC1B,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,qCAAqC,EAAE,GAAG,EAAE;YAC7C,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,WAAW,EAAE;gBAChE,IAAI,EAAE,kBAAkB;gBACxB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC,CAAC;YAEH,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,aAAa,EAAE,CAAC;QACzD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,gFAAgF;IAChF,0BAA0B;IAC1B,gFAAgF;IAEhF,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;QACvC,EAAE,CAAC,iEAAiE,EAAE,GAAG,EAAE;YACzE,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,0CAA0C;qBACxD;iBACF;aACF,CAAC;YAEF,MAAM,KAAK,GAA0B;gBACnC,IAAI,EAAE,gBAAgB;gBACtB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;gBACT,IAAI,EAAE;oBACJ,WAAW,EAAE,YAAY;iBAC1B;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,eAAe,EACf,KAAK,CACN,CAAC;YAEF,kEAAkE;YAClE,MAAM,YAAY,GAAI,gBAAwB,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;YAEzE,MAAM,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;YAChD,MAAM,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;YAC5C,MAAM,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC;YAClD,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;YACzD,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;YAC5D,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QAC5D,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,+BAA+B,EAAE,GAAG,EAAE;YACvC,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,KAAK,GAA0B;gBACnC,IAAI,EAAE,eAAe;gBACrB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,cAAc,EACd,KAAK,CACN,CAAC;YACF,MAAM,YAAY,GAAI,gBAAwB,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;YAEzE,MAAM,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;YACzC,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,KAAK,GAA0B;gBACnC,IAAI,EAAE,WAAW;gBACjB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;gBACT,IAAI,EAAE;oBACJ,WAAW,EAAE,KAAK;oBAClB,KAAK,EAAE,eAAe;oBACtB,WAAW,EAAE,aAAa;iBAC3B;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;YACxE,MAAM,YAAY,GAAI,gBAAwB,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;YAEzE,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC;gBAChC,WAAW,EAAE,KAAK;gBAClB,KAAK,EAAE,eAAe;gBACtB,WAAW,EAAE,aAAa;aAC3B,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;YACjD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,yCAAyC;qBACvD;oBACD,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,WAAW,EAAE;iBAC9C;aACF,CAAC;YAEF,MAAM,KAAK,GAA0B;gBACnC,IAAI,EAAE,gBAAgB;gBACtB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,eAAe,EACf,KAAK,CACN,CAAC;YACF,MAAM,YAAY,GAAI,gBAAwB,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;YAEzE,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;YAClE,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YAChE,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAC/D,OAAO,CACR,CAAC;YACF,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAC/D,QAAQ,CACT,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;YAC5C,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,KAAK,GAA0B;gBACnC,IAAI,EAAE,sBAAsB;gBAC5B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,oBAAoB,EACpB,KAAK,CACN,CAAC;YACF,MAAM,YAAY,GAAI,gBAAwB,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;YAEzE,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,uCAAuC,EAAE,GAAG,EAAE;YAC/C,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,KAAK,GAA0B;gBACnC,IAAI,EAAE,uBAAuB;gBAC7B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;gBACT,OAAO,EAAE,KAAK;aACf,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,qBAAqB,EACrB,KAAK,CACN,CAAC;YACF,MAAM,YAAY,GAAI,gBAAwB,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;YAEzE,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACtD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,gFAAgF;IAChF,8BAA8B;IAC9B,gFAAgF;IAEhF,QAAQ,CAAC,6BAA6B,EAAE,GAAG,EAAE;QAC3C,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;YAC3C,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,iBAAiB,EAAE;gBACtE,IAAI,EAAE,kBAAkB;gBACxB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC,CAAC;YAEH,yCAAyC;YACzC,MAAM,CAAC,gBAAgB,CAAC,CAAC,cAAc,CAAC,mBAAmB,CAAC,CAAC;YAC7D,MAAM,CAAC,gBAAgB,CAAC,CAAC,cAAc,CAAC,oBAAoB,CAAC,CAAC;QAChE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,uCAAuC,EAAE,GAAG,EAAE;YAC/C,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,kBAAkB,EAAE;gBACvE,IAAI,EAAE,oBAAoB;gBAC1B,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC,CAAC;YAEH,2CAA2C;YAC3C,MAAM,YAAY,GAAI,gBAAwB,CAAC,YAAY,EAAE,CAAC;YAC9D,MAAM,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,sCAAsC,CAAC,CAAC;QACpE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;YAC1C,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAClE,IAAI,EAAE,cAAc;gBACpB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC,CAAC;YAEH,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;YACxE,MAAM,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;YAC1E,MAAM,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;QACxD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,gFAAgF;IAChF,iBAAiB;IACjB,gFAAgF;IAEhF,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;QAC9B,EAAE,CAAC,qCAAqC,EAAE,GAAG,EAAE;YAC7C,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,YAAY,EAAE;gBACjE,IAAI,EAAE,cAAc;gBACpB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;gBACT,IAAI,EAAE;oBACJ,OAAO,EAAE,OAAO;iBACjB;aACF,CAAC,CAAC;YAEH,gBAAgB,CAAC,MAAM,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;YAE9C,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,cAAc,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;YACzE,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,cAAc,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QACzE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;YACnD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,eAAe,EAAE;gBACpE,IAAI,EAAE,iBAAiB;gBACvB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;gBACT,IAAI,EAAE;oBACJ,QAAQ,EAAE,OAAO;oBACjB,MAAM,EAAE,OAAO;iBAChB;aACF,CAAC,CAAC;YAEH,gBAAgB,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;YAEvC,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;YACnE,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,cAAc,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QACxE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,6DAA6D,EAAE,GAAG,EAAE;YACrE,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,aAAa,EAAE;gBAClE,IAAI,EAAE,eAAe;gBACrB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC,CAAC;YAEH,gBAAgB,CAAC,MAAM,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;YAElD,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,cAAc,CAChD,UAAU,EACV,YAAY,CACb,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,gFAAgF;IAChF,4BAA4B;IAC5B,gFAAgF;IAEhF,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;QACzC,EAAE,CAAC,oDAAoD,EAAE,GAAG,EAAE;YAC5D,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,IAAI,qCAAgB,CAAC,KAAK,EAAE,WAAW,EAAE;gBACvC,IAAI,EAAE,YAAY;gBAClB,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;aACV,CAAC,CAAC;YAEH,MAAM,WAAW,GAAG,eAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACzC,MAAM,CAAC,WAAW,CAAC,CAAC,WAAW,EAAE,CAAC;YAElC,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;YAC5C,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;QAC7C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,8DAA8D,EAAE,GAAG,EAAE;YACtE,MAAM,UAAU,GAA8B;gBAC5C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aAC9D,CAAC;YAEF,MAAM,UAAU,GAA8B;gBAC5C,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,eAAe,EAAE,CAAC;aAC7D,CAAC;YAEF,MAAM,MAAM,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,mBAAmB,EAAE;gBAC9D,IAAI,EAAE,SAAS;gBACf,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS,EAAE,UAAU;aACtB,CAAC,CAAC;YAEH,MAAM,MAAM,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,mBAAmB,EAAE;gBAC9D,IAAI,EAAE,SAAS;gBACf,eAAe,EAAE,gDAAgD;gBACjE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS,EAAE,UAAU;gBACrB,UAAU,EAAE,YAAY;aACzB,CAAC,CAAC;YAEH,MAAM,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACrD,MAAM,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAErD,MAAM,WAAW,GAAG,eAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACzC,MAAM,CAAC,WAAW,CAAC,CAAC,WAAW,EAAE,CAAC;QACpC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,gFAAgF;IAChF,oBAAoB;IACpB,gFAAgF;IAEhF,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;QACjC,EAAE,CAAC,+CAA+C,EAAE,GAAG,EAAE;YACvD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,0CAA0C;qBACxD;oBACD,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,WAAW,EAAE;oBAC7C,EAAE,KAAK,EAAE,eAAe,EAAE,WAAW,EAAE,eAAe,EAAE;iBACzD;aACF,CAAC;YAEF,MAAM,OAAO,GAAG;gBACd,YAAY,EAAE;oBACZ;wBACE,aAAa,EACX,sGAAsG;wBACxG,iBAAiB,EAAE;4BACjB,QAAQ,EAAE,UAAU;4BACpB,SAAS,EAAE,aAAa;yBACzB;qBACF;oBACD;wBACE,aAAa,EACX,mGAAmG;qBACtG;iBACF;aACF,CAAC;YAEF,MAAM,KAAK,GAA0B;gBACnC,IAAI,EAAE,iCAAiC;gBACvC,eAAe,EAAE,gDAAgD;gBACjE,WAAW,EAAE,uCAAuC;gBACpD,OAAO,EAAE,IAAI;gBACb,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;gBACT,OAAO;gBACP,IAAI,EAAE;oBACJ,WAAW,EAAE,YAAY;oBACzB,WAAW,EAAE,MAAM;oBACnB,IAAI,EAAE,KAAK;oBACX,aAAa,EAAE,UAAU;iBAC1B;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,oBAAoB,EACpB,KAAK,CACN,CAAC;YACF,MAAM,YAAY,GAAI,gBAAwB,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;YAEzE,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YAChE,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YACrE,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACnD,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,cAAc,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC;QACxE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;YACrD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,eAAe,EAAE;oBACnD,EAAE,KAAK,EAAE,yBAAyB,EAAE,WAAW,EAAE,UAAU,EAAE;oBAC7D;wBACE,KAAK,EAAE,4CAA4C;wBACnD,WAAW,EAAE,kBAAkB;qBAChC;iBACF;aACF,CAAC;YAEF,MAAM,OAAO,GAAG;gBACd,YAAY,EAAE;oBACZ;wBACE,aAAa,EACX,oGAAoG;qBACvG;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,oBAAoB,EACpB;gBACE,IAAI,EAAE,yBAAyB;gBAC/B,eAAe,EAAE,gDAAgD;gBACjE,WAAW,EAAE,uDAAuD;gBACpE,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;gBACT,OAAO;aACR,CACF,CAAC;YAEF,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YAC/D,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,IAAI,CAChE,eAAe,CAChB,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,8CAA8C,EAAE,GAAG,EAAE;YACtD,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE;oBACpD,EAAE,KAAK,EAAE,gCAAgC,EAAE,WAAW,EAAE,UAAU,EAAE;oBACpE,EAAE,KAAK,EAAE,kBAAkB,EAAE,WAAW,EAAE,mBAAmB,EAAE;oBAC/D;wBACE,KAAK,EAAE,cAAc;wBACrB,WAAW,EAAE,mCAAmC;qBACjD;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAC3C,KAAK,EACL,qBAAqB,EACrB;gBACE,IAAI,EAAE,0BAA0B;gBAChC,eAAe,EAAE,gDAAgD;gBACjE,WAAW,EAAE,kCAAkC;gBAC/C,MAAM,EAAE,CAAC,sDAAsD,CAAC;gBAChE,SAAS;gBACT,OAAO,EAAE;oBACP,YAAY,EAAE;wBACZ;4BACE,aAAa,EACX,iGAAiG;yBACpG;qBACF;iBACF;aACF,CACF,CAAC;YAEF,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACjE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,uDAAuD,EAAE,GAAG,EAAE;YAC/D,MAAM,SAAS,GAA8B;gBAC3C,KAAK,EAAE;oBACL,EAAE,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,UAAU,EAAE;oBAC9C;wBACE,KAAK,EAAE,eAAe;wBACtB,WAAW,EAAE,qDAAqD;qBACnE;oBACD,EAAE,KAAK,EAAE,qBAAqB,EAAE,WAAW,EAAE,MAAM,EAAE;iBACtD;aACF,CAAC;YAEF,MAAM,OAAO,GAAG;gBACd,YAAY,EAAE;oBACZ;wBACE,aAAa,EACX,sGAAsG;wBACxG,iBAAiB,EAAE;4BACjB,QAAQ,EAAE,MAAM;4BAChB,QAAQ,EAAE,MAAM;yBACjB;qBACF;iBACF;aACF,CAAC;YAEF,MAAM,gBAAgB,GAAG,IAAI,qCAAgB,CAAC,KAAK,EAAE,eAAe,EAAE;gBACpE,IAAI,EAAE,8BAA8B;gBACpC,eAAe,EAAE,gDAAgD;gBACjE,WAAW,EAAE,wCAAwC;gBACrD,OAAO,EAAE,IAAI;gBACb,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACnC,SAAS;gBACT,OAAO;gBACP,IAAI,EAAE;oBACJ,WAAW,EAAE,YAAY;oBACzB,SAAS,EAAE,UAAU;oBACrB,QAAQ,EAAE,MAAM;iBACjB;aACF,CAAC,CAAC;YAEH,MAAM,YAAY,GAAI,gBAAwB,CAAC,kBAAkB,CAC/D,gBAAgB,CAAC,KAAK,CACvB,CAAC;YAEF,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YAChE,MAAM,CACJ,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAClE,CAAC,cAAc,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["/**\n * Comprehensive tests for the ActivityLogAlert implementation\n *\n * This test suite validates the ActivityLogAlert class using the AzapiResource framework.\n * Tests cover automatic version resolution, explicit version pinning, schema validation,\n * condition filtering, category types, scope configurations, action group integration,\n * property transformation, and resource creation.\n */\n\nimport { Testing } from \"cdktf\";\nimport * as cdktf from \"cdktf\";\nimport {\n  ActivityLogAlert,\n  ActivityLogAlertProps,\n  ActivityLogAlertCondition,\n} from \"../lib/activity-log-alert\";\n\ndescribe(\"ActivityLogAlert - Implementation\", () => {\n  let app: cdktf.App;\n  let stack: cdktf.TerraformStack;\n\n  beforeEach(() => {\n    app = Testing.app();\n    stack = new cdktf.TerraformStack(app, \"TestStack\");\n  });\n\n  // =============================================================================\n  // Constructor and Basic Properties\n  // =============================================================================\n\n  describe(\"Constructor and Basic Properties\", () => {\n    it(\"should create activity log alert with minimal required properties\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.Compute/virtualMachines/delete\",\n          },\n        ],\n      };\n\n      const props: ActivityLogAlertProps = {\n        name: \"test-activity-log-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"TestActivityLogAlert\",\n        props,\n      );\n\n      expect(activityLogAlert).toBeInstanceOf(ActivityLogAlert);\n      expect(activityLogAlert.props).toBe(props);\n      expect(activityLogAlert.props.name).toBe(\"test-activity-log-alert\");\n      expect(activityLogAlert.props.scopes).toHaveLength(1);\n    });\n\n    it(\"should apply default values correctly\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const props: ActivityLogAlertProps = {\n        name: \"default-activity-log-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"DefaultActivityLogAlert\",\n        props,\n      );\n\n      expect(activityLogAlert).toBeInstanceOf(ActivityLogAlert);\n      expect(activityLogAlert.props.enabled).toBeUndefined(); // Should use default in createResourceBody\n    });\n\n    it(\"should assign all properties correctly\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Security\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.Security/locations/alerts/activate/action\",\n          },\n        ],\n      };\n\n      const actions = {\n        actionGroups: [\n          {\n            actionGroupId:\n              \"/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/test-ag\",\n          },\n        ],\n      };\n\n      const props: ActivityLogAlertProps = {\n        name: \"full-activity-log-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        description: \"Alert for security events\",\n        enabled: false,\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n        actions,\n        tags: {\n          environment: \"test\",\n          team: \"security\",\n        },\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"FullActivityLogAlert\",\n        props,\n      );\n\n      expect(activityLogAlert.props.name).toBe(\"full-activity-log-alert\");\n      expect(activityLogAlert.props.description).toBe(\n        \"Alert for security events\",\n      );\n      expect(activityLogAlert.props.enabled).toBe(false);\n      expect(activityLogAlert.props.condition).toEqual(condition);\n      expect(activityLogAlert.props.actions).toEqual(actions);\n      expect(activityLogAlert.props.tags).toEqual({\n        environment: \"test\",\n        team: \"security\",\n      });\n    });\n\n    it(\"should verify schema registration occurs\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      // Create first activity log alert to trigger schema registration\n      new ActivityLogAlert(stack, \"FirstActivityLogAlert\", {\n        name: \"first-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      });\n\n      // Create second activity log alert to verify schemas are already registered\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"SecondActivityLogAlert\",\n        {\n          name: \"second-alert\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          scopes: [\"/subscriptions/test-sub\"],\n          condition,\n        },\n      );\n\n      expect(activityLogAlert).toBeInstanceOf(ActivityLogAlert);\n    });\n  });\n\n  // =============================================================================\n  // Version Resolution\n  // =============================================================================\n\n  describe(\"Version Resolution\", () => {\n    it(\"should use default version 2020-10-01 when no version specified\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"DefaultVersion\", {\n        name: \"default-version-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      });\n\n      expect(activityLogAlert.resolvedApiVersion).toBe(\"2020-10-01\");\n    });\n\n    it(\"should use explicit version when specified\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"PinnedVersion\", {\n        name: \"pinned-version-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n        apiVersion: \"2020-10-01\",\n      });\n\n      expect(activityLogAlert.resolvedApiVersion).toBe(\"2020-10-01\");\n    });\n\n    it(\"should apply version configuration correctly\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const props: ActivityLogAlertProps = {\n        name: \"versioned-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n        apiVersion: \"2020-10-01\",\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"VersionedAlert\",\n        props,\n      );\n\n      expect(activityLogAlert.resolvedApiVersion).toBe(\"2020-10-01\");\n      expect(activityLogAlert).toBeInstanceOf(ActivityLogAlert);\n    });\n  });\n\n  // =============================================================================\n  // Category Types\n  // =============================================================================\n\n  describe(\"Category Types\", () => {\n    it(\"should configure alert for Administrative category\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.Compute/virtualMachines/delete\",\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"AdministrativeAlert\",\n        {\n          name: \"administrative-alert\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          scopes: [\"/subscriptions/test-sub\"],\n          condition,\n        },\n      );\n\n      expect(activityLogAlert.props.condition.allOf[0].equalsValue).toBe(\n        \"Administrative\",\n      );\n    });\n\n    it(\"should configure alert for ServiceHealth category\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"ServiceHealth\" },\n          { field: \"properties.incidentType\", equalsValue: \"Incident\" },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"ServiceHealthAlert\",\n        {\n          name: \"service-health-alert\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          scopes: [\"/subscriptions/test-sub\"],\n          condition,\n        },\n      );\n\n      expect(activityLogAlert.props.condition.allOf[0].equalsValue).toBe(\n        \"ServiceHealth\",\n      );\n    });\n\n    it(\"should configure alert for ResourceHealth category\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"ResourceHealth\" },\n          {\n            field: \"properties.currentHealthStatus\",\n            equalsValue: \"Unavailable\",\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"ResourceHealthAlert\",\n        {\n          name: \"resource-health-alert\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          scopes: [\"/subscriptions/test-sub\"],\n          condition,\n        },\n      );\n\n      expect(activityLogAlert.props.condition.allOf[0].equalsValue).toBe(\n        \"ResourceHealth\",\n      );\n    });\n\n    it(\"should configure alert for Security category\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Security\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.Security/locations/alerts/activate/action\",\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"SecurityAlert\", {\n        name: \"security-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      });\n\n      expect(activityLogAlert.props.condition.allOf[0].equalsValue).toBe(\n        \"Security\",\n      );\n    });\n\n    it(\"should configure alert for Alert category\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Alert\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.Insights/metricAlerts/write\",\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"AlertCategoryAlert\",\n        {\n          name: \"alert-category-alert\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          scopes: [\"/subscriptions/test-sub\"],\n          condition,\n        },\n      );\n\n      expect(activityLogAlert.props.condition.allOf[0].equalsValue).toBe(\n        \"Alert\",\n      );\n    });\n\n    it(\"should configure alert for Autoscale category\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Autoscale\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.Insights/AutoscaleSettings/ScaleUpAction\",\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"AutoscaleAlert\", {\n        name: \"autoscale-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      });\n\n      expect(activityLogAlert.props.condition.allOf[0].equalsValue).toBe(\n        \"Autoscale\",\n      );\n    });\n  });\n\n  // =============================================================================\n  // Condition Filtering\n  // =============================================================================\n\n  describe(\"Condition Filtering\", () => {\n    it(\"should configure single condition\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"SingleCondition\", {\n        name: \"single-condition-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      });\n\n      expect(activityLogAlert.props.condition.allOf).toHaveLength(1);\n      expect(activityLogAlert.props.condition.allOf[0].field).toBe(\"category\");\n    });\n\n    it(\"should configure multiple conditions with AND logic\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.Storage/storageAccounts/write\",\n          },\n          { field: \"status\", equalsValue: \"Succeeded\" },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"MultipleConditions\",\n        {\n          name: \"multi-condition-alert\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          scopes: [\"/subscriptions/test-sub\"],\n          condition,\n        },\n      );\n\n      expect(activityLogAlert.props.condition.allOf).toHaveLength(3);\n      expect(activityLogAlert.props.condition.allOf[1].field).toBe(\n        \"operationName\",\n      );\n      expect(activityLogAlert.props.condition.allOf[2].field).toBe(\"status\");\n    });\n\n    it(\"should filter by operation name\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.Compute/virtualMachines/write\",\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"OperationNameFilter\",\n        {\n          name: \"operation-name-alert\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          scopes: [\"/subscriptions/test-sub\"],\n          condition,\n        },\n      );\n\n      expect(activityLogAlert.props.condition.allOf[1].equalsValue).toBe(\n        \"Microsoft.Compute/virtualMachines/write\",\n      );\n    });\n\n    it(\"should filter by resource type\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          {\n            field: \"resourceType\",\n            equalsValue: \"Microsoft.Compute/virtualMachines\",\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"ResourceTypeFilter\",\n        {\n          name: \"resource-type-alert\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          scopes: [\"/subscriptions/test-sub\"],\n          condition,\n        },\n      );\n\n      const resourceTypeCondition = activityLogAlert.props.condition.allOf.find(\n        (c) => c.field === \"resourceType\",\n      );\n      expect(resourceTypeCondition?.equalsValue).toBe(\n        \"Microsoft.Compute/virtualMachines\",\n      );\n    });\n\n    it(\"should filter by status Succeeded\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          { field: \"status\", equalsValue: \"Succeeded\" },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"StatusSucceededFilter\",\n        {\n          name: \"status-succeeded-alert\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          scopes: [\"/subscriptions/test-sub\"],\n          condition,\n        },\n      );\n\n      const statusCondition = activityLogAlert.props.condition.allOf.find(\n        (c) => c.field === \"status\",\n      );\n      expect(statusCondition?.equalsValue).toBe(\"Succeeded\");\n    });\n\n    it(\"should filter by status Failed\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.Network/networkSecurityGroups/delete\",\n          },\n          { field: \"status\", equalsValue: \"Failed\" },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"StatusFailedFilter\",\n        {\n          name: \"status-failed-alert\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          scopes: [\"/subscriptions/test-sub\"],\n          condition,\n        },\n      );\n\n      const statusCondition = activityLogAlert.props.condition.allOf.find(\n        (c) => c.field === \"status\",\n      );\n      expect(statusCondition?.equalsValue).toBe(\"Failed\");\n    });\n\n    it(\"should filter by status Started\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          { field: \"status\", equalsValue: \"Started\" },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"StatusStartedFilter\",\n        {\n          name: \"status-started-alert\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          scopes: [\"/subscriptions/test-sub\"],\n          condition,\n        },\n      );\n\n      const statusCondition = activityLogAlert.props.condition.allOf.find(\n        (c) => c.field === \"status\",\n      );\n      expect(statusCondition?.equalsValue).toBe(\"Started\");\n    });\n\n    it(\"should filter by resource group\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          { field: \"resourceGroup\", equalsValue: \"production-rg\" },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"ResourceGroupFilter\",\n        {\n          name: \"resource-group-alert\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          scopes: [\"/subscriptions/test-sub\"],\n          condition,\n        },\n      );\n\n      const rgCondition = activityLogAlert.props.condition.allOf.find(\n        (c) => c.field === \"resourceGroup\",\n      );\n      expect(rgCondition?.equalsValue).toBe(\"production-rg\");\n    });\n\n    it(\"should filter by subStatus\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          { field: \"subStatus\", equalsValue: \"Created\" },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"SubStatusFilter\", {\n        name: \"substatus-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      });\n\n      const subStatusCondition = activityLogAlert.props.condition.allOf.find(\n        (c) => c.field === \"subStatus\",\n      );\n      expect(subStatusCondition?.equalsValue).toBe(\"Created\");\n    });\n  });\n\n  // =============================================================================\n  // Scope Configuration\n  // =============================================================================\n\n  describe(\"Scope Configuration\", () => {\n    it(\"should configure subscription-level scope\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"SubscriptionScope\",\n        {\n          name: \"subscription-scope-alert\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          scopes: [\"/subscriptions/00000000-0000-0000-0000-000000000000\"],\n          condition,\n        },\n      );\n\n      expect(activityLogAlert.props.scopes).toHaveLength(1);\n      expect(activityLogAlert.props.scopes[0]).toContain(\"/subscriptions/\");\n    });\n\n    it(\"should configure resource group scope\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"ResourceGroupScope\",\n        {\n          name: \"rg-scope-alert\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          scopes: [\"/subscriptions/test-sub/resourceGroups/production-rg\"],\n          condition,\n        },\n      );\n\n      expect(activityLogAlert.props.scopes[0]).toContain(\"/resourceGroups/\");\n    });\n\n    it(\"should configure specific resource scope\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"ResourceScope\", {\n        name: \"resource-scope-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\n          \"/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Storage/storageAccounts/myaccount\",\n        ],\n        condition,\n      });\n\n      expect(activityLogAlert.props.scopes[0]).toContain(\n        \"/providers/Microsoft.Storage/\",\n      );\n    });\n\n    it(\"should configure multiple scopes\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"MultipleScopes\", {\n        name: \"multi-scope-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\n          \"/subscriptions/test-sub/resourceGroups/rg1\",\n          \"/subscriptions/test-sub/resourceGroups/rg2\",\n          \"/subscriptions/test-sub/resourceGroups/rg3\",\n        ],\n        condition,\n      });\n\n      expect(activityLogAlert.props.scopes).toHaveLength(3);\n    });\n  });\n\n  // =============================================================================\n  // Operation Name Filtering\n  // =============================================================================\n\n  describe(\"Operation Name Filtering\", () => {\n    it(\"should filter storage account operations\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.Storage/storageAccounts/write\",\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"StorageOperation\", {\n        name: \"storage-operation-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      });\n\n      expect(activityLogAlert.props.condition.allOf[1].equalsValue).toBe(\n        \"Microsoft.Storage/storageAccounts/write\",\n      );\n    });\n\n    it(\"should filter virtual machine operations\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.Compute/virtualMachines/delete\",\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"VMOperation\", {\n        name: \"vm-operation-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      });\n\n      expect(activityLogAlert.props.condition.allOf[1].equalsValue).toBe(\n        \"Microsoft.Compute/virtualMachines/delete\",\n      );\n    });\n\n    it(\"should filter network security group operations\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          {\n            field: \"operationName\",\n            equalsValue:\n              \"Microsoft.Network/networkSecurityGroups/securityRules/write\",\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"NSGOperation\", {\n        name: \"nsg-operation-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      });\n\n      expect(activityLogAlert.props.condition.allOf[1].equalsValue).toBe(\n        \"Microsoft.Network/networkSecurityGroups/securityRules/write\",\n      );\n    });\n\n    it(\"should filter SQL database operations\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.Sql/servers/databases/write\",\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"SQLOperation\", {\n        name: \"sql-operation-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      });\n\n      expect(activityLogAlert.props.condition.allOf[1].equalsValue).toBe(\n        \"Microsoft.Sql/servers/databases/write\",\n      );\n    });\n\n    it(\"should filter key vault operations\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.KeyVault/vaults/delete\",\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"KeyVaultOperation\",\n        {\n          name: \"keyvault-operation-alert\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          scopes: [\"/subscriptions/test-sub\"],\n          condition,\n        },\n      );\n\n      expect(activityLogAlert.props.condition.allOf[1].equalsValue).toBe(\n        \"Microsoft.KeyVault/vaults/delete\",\n      );\n    });\n  });\n\n  // =============================================================================\n  // Action Group Integration\n  // =============================================================================\n\n  describe(\"Action Group Integration\", () => {\n    it(\"should configure single action group\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const actions = {\n        actionGroups: [\n          {\n            actionGroupId:\n              \"/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/ops-ag\",\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"SingleAction\", {\n        name: \"single-action-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n        actions,\n      });\n\n      expect(activityLogAlert.props.actions?.actionGroups).toHaveLength(1);\n      expect(\n        activityLogAlert.props.actions?.actionGroups![0].actionGroupId,\n      ).toContain(\"ops-ag\");\n    });\n\n    it(\"should configure multiple action groups\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Security\" }],\n      };\n\n      const actions = {\n        actionGroups: [\n          {\n            actionGroupId:\n              \"/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/ops-ag\",\n          },\n          {\n            actionGroupId:\n              \"/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/security-ag\",\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"MultipleActions\", {\n        name: \"multi-action-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n        actions,\n      });\n\n      expect(activityLogAlert.props.actions?.actionGroups).toHaveLength(2);\n    });\n\n    it(\"should configure action with webhook properties\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const actions = {\n        actionGroups: [\n          {\n            actionGroupId:\n              \"/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/webhook-ag\",\n            webhookProperties: {\n              customProperty1: \"value1\",\n              customProperty2: \"value2\",\n            },\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"WebhookAction\", {\n        name: \"webhook-action-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n        actions,\n      });\n\n      expect(\n        activityLogAlert.props.actions?.actionGroups![0].webhookProperties,\n      ).toEqual({\n        customProperty1: \"value1\",\n        customProperty2: \"value2\",\n      });\n    });\n\n    it(\"should handle alert without actions\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"NoActions\", {\n        name: \"no-actions-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      });\n\n      expect(activityLogAlert.props.actions).toBeUndefined();\n    });\n  });\n\n  // =============================================================================\n  // Property Transformation\n  // =============================================================================\n\n  describe(\"Property Transformation\", () => {\n    it(\"should generate correct Azure API format via createResourceBody\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.Compute/virtualMachines/delete\",\n          },\n        ],\n      };\n\n      const props: ActivityLogAlertProps = {\n        name: \"transform-test\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n        tags: {\n          environment: \"production\",\n        },\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"TransformTest\",\n        props,\n      );\n\n      // Access the protected createResourceBody method via the instance\n      const resourceBody = (activityLogAlert as any).createResourceBody(props);\n\n      expect(resourceBody).toHaveProperty(\"location\");\n      expect(resourceBody).toHaveProperty(\"tags\");\n      expect(resourceBody).toHaveProperty(\"properties\");\n      expect(resourceBody.properties).toHaveProperty(\"scopes\");\n      expect(resourceBody.properties).toHaveProperty(\"condition\");\n      expect(resourceBody.properties).toHaveProperty(\"enabled\");\n    });\n\n    it(\"should set location to global\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const props: ActivityLogAlertProps = {\n        name: \"location-test\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"LocationTest\",\n        props,\n      );\n      const resourceBody = (activityLogAlert as any).createResourceBody(props);\n\n      expect(resourceBody.location).toBe(\"global\");\n    });\n\n    it(\"should transform tags correctly\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const props: ActivityLogAlertProps = {\n        name: \"tags-test\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n        tags: {\n          environment: \"dev\",\n          owner: \"platform-team\",\n          cost_center: \"engineering\",\n        },\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"TagsTest\", props);\n      const resourceBody = (activityLogAlert as any).createResourceBody(props);\n\n      expect(resourceBody.tags).toEqual({\n        environment: \"dev\",\n        owner: \"platform-team\",\n        cost_center: \"engineering\",\n      });\n    });\n\n    it(\"should format condition object properly\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.Storage/storageAccounts/write\",\n          },\n          { field: \"status\", equalsValue: \"Succeeded\" },\n        ],\n      };\n\n      const props: ActivityLogAlertProps = {\n        name: \"condition-test\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"ConditionTest\",\n        props,\n      );\n      const resourceBody = (activityLogAlert as any).createResourceBody(props);\n\n      expect(resourceBody.properties.condition).toHaveProperty(\"allOf\");\n      expect(resourceBody.properties.condition.allOf).toHaveLength(3);\n      expect(resourceBody.properties.condition.allOf[0]).toHaveProperty(\n        \"field\",\n      );\n      expect(resourceBody.properties.condition.allOf[0]).toHaveProperty(\n        \"equals\",\n      );\n    });\n\n    it(\"should apply default enabled value\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const props: ActivityLogAlertProps = {\n        name: \"default-enabled-test\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"DefaultEnabledTest\",\n        props,\n      );\n      const resourceBody = (activityLogAlert as any).createResourceBody(props);\n\n      expect(resourceBody.properties.enabled).toBe(true);\n    });\n\n    it(\"should respect explicit enabled value\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const props: ActivityLogAlertProps = {\n        name: \"explicit-enabled-test\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n        enabled: false,\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"ExplicitEnabledTest\",\n        props,\n      );\n      const resourceBody = (activityLogAlert as any).createResourceBody(props);\n\n      expect(resourceBody.properties.enabled).toBe(false);\n    });\n  });\n\n  // =============================================================================\n  // Integration with Base Class\n  // =============================================================================\n\n  describe(\"Integration with Base Class\", () => {\n    it(\"should inherit from AzapiResource\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"InheritanceTest\", {\n        name: \"inheritance-test\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      });\n\n      // Verify it has AzapiResource properties\n      expect(activityLogAlert).toHaveProperty(\"terraformResource\");\n      expect(activityLogAlert).toHaveProperty(\"resolvedApiVersion\");\n    });\n\n    it(\"should have correct azapiResourceType\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"ResourceTypeTest\", {\n        name: \"resource-type-test\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      });\n\n      // Access the protected resourceType method\n      const resourceType = (activityLogAlert as any).resourceType();\n      expect(resourceType).toBe(\"Microsoft.Insights/activityLogAlerts\");\n    });\n\n    it(\"should generate resource outputs\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"OutputsTest\", {\n        name: \"outputs-test\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      });\n\n      expect(activityLogAlert.idOutput).toBeInstanceOf(cdktf.TerraformOutput);\n      expect(activityLogAlert.nameOutput).toBeInstanceOf(cdktf.TerraformOutput);\n      expect(activityLogAlert.id).toMatch(/^\\$\\{.*\\.id\\}$/);\n    });\n  });\n\n  // =============================================================================\n  // Tag Management\n  // =============================================================================\n\n  describe(\"Tag Management\", () => {\n    it(\"should add tags using addTag method\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"AddTagTest\", {\n        name: \"add-tag-test\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n        tags: {\n          initial: \"value\",\n        },\n      });\n\n      activityLogAlert.addTag(\"newTag\", \"newValue\");\n\n      expect(activityLogAlert.props.tags).toHaveProperty(\"newTag\", \"newValue\");\n      expect(activityLogAlert.props.tags).toHaveProperty(\"initial\", \"value\");\n    });\n\n    it(\"should remove tags using removeTag method\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"RemoveTagTest\", {\n        name: \"remove-tag-test\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n        tags: {\n          toRemove: \"value\",\n          toKeep: \"value\",\n        },\n      });\n\n      activityLogAlert.removeTag(\"toRemove\");\n\n      expect(activityLogAlert.props.tags).not.toHaveProperty(\"toRemove\");\n      expect(activityLogAlert.props.tags).toHaveProperty(\"toKeep\", \"value\");\n    });\n\n    it(\"should initialize tags object when adding to undefined tags\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"InitTagTest\", {\n        name: \"init-tag-test\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n      });\n\n      activityLogAlert.addTag(\"firstTag\", \"firstValue\");\n\n      expect(activityLogAlert.props.tags).toHaveProperty(\n        \"firstTag\",\n        \"firstValue\",\n      );\n    });\n  });\n\n  // =============================================================================\n  // CDK Terraform Integration\n  // =============================================================================\n\n  describe(\"CDK Terraform Integration\", () => {\n    it(\"should synthesize to valid Terraform configuration\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      new ActivityLogAlert(stack, \"SynthTest\", {\n        name: \"synth-test\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\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 handle multiple activity log alerts in the same stack\", () => {\n      const condition1: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"Administrative\" }],\n      };\n\n      const condition2: ActivityLogAlertCondition = {\n        allOf: [{ field: \"category\", equalsValue: \"ServiceHealth\" }],\n      };\n\n      const alert1 = new ActivityLogAlert(stack, \"ActivityLogAlert1\", {\n        name: \"alert-1\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition: condition1,\n      });\n\n      const alert2 = new ActivityLogAlert(stack, \"ActivityLogAlert2\", {\n        name: \"alert-2\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        scopes: [\"/subscriptions/test-sub\"],\n        condition: condition2,\n        apiVersion: \"2020-10-01\",\n      });\n\n      expect(alert1.resolvedApiVersion).toBe(\"2020-10-01\");\n      expect(alert2.resolvedApiVersion).toBe(\"2020-10-01\");\n\n      const synthesized = Testing.synth(stack);\n      expect(synthesized).toBeDefined();\n    });\n  });\n\n  // =============================================================================\n  // Complex Scenarios\n  // =============================================================================\n\n  describe(\"Complex Scenarios\", () => {\n    it(\"should handle comprehensive VM deletion alert\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Administrative\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.Compute/virtualMachines/delete\",\n          },\n          { field: \"status\", equalsValue: \"Succeeded\" },\n          { field: \"resourceGroup\", equalsValue: \"production-rg\" },\n        ],\n      };\n\n      const actions = {\n        actionGroups: [\n          {\n            actionGroupId:\n              \"/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/critical-ag\",\n            webhookProperties: {\n              severity: \"critical\",\n              alertType: \"vm-deletion\",\n            },\n          },\n          {\n            actionGroupId:\n              \"/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/audit-ag\",\n          },\n        ],\n      };\n\n      const props: ActivityLogAlertProps = {\n        name: \"comprehensive-vm-deletion-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        description: \"Alert when production VMs are deleted\",\n        enabled: true,\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n        actions,\n        tags: {\n          environment: \"production\",\n          criticality: \"high\",\n          team: \"ops\",\n          alertCategory: \"security\",\n        },\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"ComprehensiveAlert\",\n        props,\n      );\n      const resourceBody = (activityLogAlert as any).createResourceBody(props);\n\n      expect(resourceBody.properties.condition.allOf).toHaveLength(4);\n      expect(resourceBody.properties.actions.actionGroups).toHaveLength(2);\n      expect(resourceBody.properties.enabled).toBe(true);\n      expect(resourceBody.tags).toHaveProperty(\"alertCategory\", \"security\");\n    });\n\n    it(\"should handle service health incident alert\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"ServiceHealth\" },\n          { field: \"properties.incidentType\", equalsValue: \"Incident\" },\n          {\n            field: \"properties.impactedServices[*].ServiceName\",\n            equalsValue: \"Virtual Machines\",\n          },\n        ],\n      };\n\n      const actions = {\n        actionGroups: [\n          {\n            actionGroupId:\n              \"/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/oncall-ag\",\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"ServiceHealthAlert\",\n        {\n          name: \"service-health-incident\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          description: \"Alert on Azure service health incidents affecting VMs\",\n          scopes: [\"/subscriptions/test-sub\"],\n          condition,\n          actions,\n        },\n      );\n\n      expect(activityLogAlert.props.condition.allOf).toHaveLength(3);\n      expect(activityLogAlert.props.condition.allOf[0].equalsValue).toBe(\n        \"ServiceHealth\",\n      );\n    });\n\n    it(\"should handle resource health degraded alert\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"ResourceHealth\" },\n          { field: \"properties.currentHealthStatus\", equalsValue: \"Degraded\" },\n          { field: \"properties.cause\", equalsValue: \"PlatformInitiated\" },\n          {\n            field: \"resourceType\",\n            equalsValue: \"Microsoft.Compute/virtualMachines\",\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(\n        stack,\n        \"ResourceHealthAlert\",\n        {\n          name: \"resource-health-degraded\",\n          resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n          description: \"Alert when VM health is degraded\",\n          scopes: [\"/subscriptions/test-sub/resourceGroups/production-rg\"],\n          condition,\n          actions: {\n            actionGroups: [\n              {\n                actionGroupId:\n                  \"/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/ops-ag\",\n              },\n            ],\n          },\n        },\n      );\n\n      expect(activityLogAlert.props.condition.allOf).toHaveLength(4);\n    });\n\n    it(\"should handle security alert with multiple conditions\", () => {\n      const condition: ActivityLogAlertCondition = {\n        allOf: [\n          { field: \"category\", equalsValue: \"Security\" },\n          {\n            field: \"operationName\",\n            equalsValue: \"Microsoft.Security/locations/alerts/activate/action\",\n          },\n          { field: \"properties.severity\", equalsValue: \"High\" },\n        ],\n      };\n\n      const actions = {\n        actionGroups: [\n          {\n            actionGroupId:\n              \"/subscriptions/test-sub/resourceGroups/test-rg/providers/Microsoft.Insights/actionGroups/security-ag\",\n            webhookProperties: {\n              priority: \"high\",\n              escalate: \"true\",\n            },\n          },\n        ],\n      };\n\n      const activityLogAlert = new ActivityLogAlert(stack, \"SecurityAlert\", {\n        name: \"high-severity-security-alert\",\n        resourceGroupId: \"/subscriptions/test-sub/resourceGroups/test-rg\",\n        description: \"Alert on high-severity security events\",\n        enabled: true,\n        scopes: [\"/subscriptions/test-sub\"],\n        condition,\n        actions,\n        tags: {\n          environment: \"production\",\n          alertType: \"security\",\n          severity: \"high\",\n        },\n      });\n\n      const resourceBody = (activityLogAlert as any).createResourceBody(\n        activityLogAlert.props,\n      );\n\n      expect(resourceBody.properties.condition.allOf).toHaveLength(3);\n      expect(\n        resourceBody.properties.actions.actionGroups[0].webhookProperties,\n      ).toHaveProperty(\"escalate\", \"true\");\n    });\n  });\n});\n"]}