@microsoft/terraform-cdk-constructs 1.8.0 → 1.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (97) hide show
  1. package/.jsii +21007 -16056
  2. package/API.md +37023 -29701
  3. package/lib/azure-actiongroup/lib/action-group.js +1 -1
  4. package/lib/azure-activitylogalert/lib/activity-log-alert.js +1 -1
  5. package/lib/azure-aks/lib/aks-cluster.js +1 -1
  6. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +1 -1
  7. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +1 -1
  8. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +1 -1
  9. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +1 -1
  10. package/lib/azure-dnsresolver/lib/dns-resolver.js +1 -1
  11. package/lib/azure-dnsresolver/lib/inbound-endpoint.js +1 -1
  12. package/lib/azure-dnsresolver/lib/outbound-endpoint.js +1 -1
  13. package/lib/azure-dnszone/lib/dns-zone.js +1 -1
  14. package/lib/azure-dnszone/lib/records/dns-records.js +10 -10
  15. package/lib/azure-loganalyticsworkspace/index.d.ts +6 -0
  16. package/lib/azure-loganalyticsworkspace/index.js +23 -0
  17. package/lib/azure-loganalyticsworkspace/lib/index.d.ts +5 -0
  18. package/lib/azure-loganalyticsworkspace/lib/index.js +22 -0
  19. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace-schemas.d.ts +51 -0
  20. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace-schemas.js +255 -0
  21. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.d.ts +301 -0
  22. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.js +213 -0
  23. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.d.ts +9 -0
  24. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.js +71 -0
  25. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.d.ts +8 -0
  26. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.js +504 -0
  27. package/lib/azure-metricalert/lib/metric-alert.js +1 -1
  28. package/lib/azure-networkinterface/lib/network-interface.js +1 -1
  29. package/lib/azure-networksecuritygroup/lib/network-security-group.js +1 -1
  30. package/lib/azure-networkwatcher/index.d.ts +14 -0
  31. package/lib/azure-networkwatcher/index.js +31 -0
  32. package/lib/azure-networkwatcher/lib/index.d.ts +5 -0
  33. package/lib/azure-networkwatcher/lib/index.js +22 -0
  34. package/lib/azure-networkwatcher/lib/network-watcher-schemas.d.ts +47 -0
  35. package/lib/azure-networkwatcher/lib/network-watcher-schemas.js +167 -0
  36. package/lib/azure-networkwatcher/lib/network-watcher.d.ts +181 -0
  37. package/lib/azure-networkwatcher/lib/network-watcher.js +187 -0
  38. package/lib/azure-networkwatcher/test/network-watcher.integ.d.ts +12 -0
  39. package/lib/azure-networkwatcher/test/network-watcher.integ.js +84 -0
  40. package/lib/azure-networkwatcher/test/network-watcher.spec.d.ts +8 -0
  41. package/lib/azure-networkwatcher/test/network-watcher.spec.js +312 -0
  42. package/lib/azure-policyassignment/lib/policy-assignment.js +1 -1
  43. package/lib/azure-policydefinition/lib/policy-definition.js +1 -1
  44. package/lib/azure-policysetdefinition/index.d.ts +10 -0
  45. package/lib/azure-policysetdefinition/index.js +27 -0
  46. package/lib/azure-policysetdefinition/lib/index.d.ts +5 -0
  47. package/lib/azure-policysetdefinition/lib/index.js +22 -0
  48. package/lib/azure-policysetdefinition/lib/policy-set-definition-schemas.d.ts +50 -0
  49. package/lib/azure-policysetdefinition/lib/policy-set-definition-schemas.js +255 -0
  50. package/lib/azure-policysetdefinition/lib/policy-set-definition.d.ts +426 -0
  51. package/lib/azure-policysetdefinition/lib/policy-set-definition.js +255 -0
  52. package/lib/azure-policysetdefinition/test/policy-set-definition.integ.d.ts +9 -0
  53. package/lib/azure-policysetdefinition/test/policy-set-definition.integ.js +56 -0
  54. package/lib/azure-policysetdefinition/test/policy-set-definition.spec.d.ts +8 -0
  55. package/lib/azure-policysetdefinition/test/policy-set-definition.spec.js +745 -0
  56. package/lib/azure-privatednszone/lib/private-dns-zone.js +1 -1
  57. package/lib/azure-privatednszone/lib/records/private-dns-records.js +8 -8
  58. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +1 -1
  59. package/lib/azure-publicipaddress/lib/public-ip-address.js +1 -1
  60. package/lib/azure-resourcegroup/lib/resource-group.js +1 -1
  61. package/lib/azure-roleassignment/lib/role-assignment.js +1 -1
  62. package/lib/azure-roledefinition/lib/role-definition.js +1 -1
  63. package/lib/azure-storageaccount/lib/storage-account.js +1 -1
  64. package/lib/azure-subnet/lib/subnet.js +1 -1
  65. package/lib/azure-virtualmachine/lib/virtual-machine.js +1 -1
  66. package/lib/azure-virtualnetwork/lib/virtual-network.js +1 -1
  67. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway-schemas.js +2 -2
  68. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.d.ts +4 -2
  69. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.js +8 -5
  70. package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.spec.js +109 -1
  71. package/lib/azure-virtualnetworkgatewayconnection/lib/virtual-network-gateway-connection.js +1 -1
  72. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +1 -1
  73. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +1 -1
  74. package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +1 -1
  75. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +1 -1
  76. package/lib/azure-virtualnetworkmanager/lib/network-group.js +1 -1
  77. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +1 -1
  78. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +1 -1
  79. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +1 -1
  80. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +1 -1
  81. package/lib/azure-vmss/lib/virtual-machine-scale-set.js +1 -1
  82. package/lib/core-azure/lib/azapi/azapi-resource.js +2 -2
  83. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
  84. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
  85. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +1 -1
  86. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
  87. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
  88. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
  89. package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +1 -1
  90. package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
  91. package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
  92. package/lib/index.d.ts +9 -0
  93. package/lib/index.js +11 -2
  94. package/lib/testing/index.js +2 -2
  95. package/lib/testing/lib/cleanup.js +1 -1
  96. package/lib/testing/lib/metadata.js +1 -1
  97. package/package.json +1 -1
@@ -0,0 +1,187 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.NetworkWatcher = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ /**
7
+ * Unified Azure Network Watcher implementation using AzapiResource framework
8
+ *
9
+ * This class provides a version-aware implementation for Azure Network Watcher
10
+ * that automatically handles version management, schema validation, and property
11
+ * transformation across all supported API versions.
12
+ *
13
+ * IMPORTANT: Azure only allows one Network Watcher per subscription per region.
14
+ * If you attempt to create a Network Watcher in a region where one already exists,
15
+ * the deployment will fail.
16
+ *
17
+ * Supported API Versions:
18
+ * - 2024-01-01 (Active, Latest)
19
+ * - 2023-11-01 (Active, Backward Compatibility)
20
+ *
21
+ * Features:
22
+ * - Automatic latest version resolution when no version is specified
23
+ * - Explicit version pinning for stability requirements
24
+ * - Schema-driven validation and transformation
25
+ * - Full JSII compliance for multi-language support
26
+ *
27
+ * Network Watcher is primarily used as a dependency for other Network Watcher features:
28
+ * - Flow Logs
29
+ * - Connection Monitor
30
+ * - Packet Capture
31
+ * - Network Diagnostic Tools
32
+ */
33
+ const cdktf = require("cdktf");
34
+ const network_watcher_schemas_1 = require("./network-watcher-schemas");
35
+ const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
36
+ /**
37
+ * Unified Azure Network Watcher implementation
38
+ *
39
+ * This class provides a single, version-aware implementation that automatically handles version
40
+ * resolution, schema validation, and property transformation while maintaining full JSII compliance.
41
+ *
42
+ * Network Watcher is a regional service that provides tools to monitor, diagnose, and gain
43
+ * insights into your network health and performance in Azure. It serves as the anchor for
44
+ * Network Watcher features like Flow Logs, Connection Monitor, and Packet Capture.
45
+ *
46
+ * IMPORTANT CONSTRAINT: Azure only allows one Network Watcher per subscription per region.
47
+ * If you need Network Watcher functionality in multiple regions, you must create a separate
48
+ * Network Watcher for each region.
49
+ *
50
+ * @example
51
+ * // Basic Network Watcher:
52
+ * const networkWatcher = new NetworkWatcher(this, "network-watcher", {
53
+ * name: "nw-eastus",
54
+ * location: "eastus",
55
+ * resourceGroupId: resourceGroup.id,
56
+ * });
57
+ *
58
+ * @example
59
+ * // Network Watcher with specific API version:
60
+ * const networkWatcher = new NetworkWatcher(this, "network-watcher", {
61
+ * name: "nw-westus2",
62
+ * location: "westus2",
63
+ * resourceGroupId: resourceGroup.id,
64
+ * apiVersion: "2024-01-01",
65
+ * tags: {
66
+ * environment: "production",
67
+ * },
68
+ * });
69
+ *
70
+ * @example
71
+ * // Network Watcher for use with Flow Logs:
72
+ * const networkWatcher = new NetworkWatcher(this, "network-watcher", {
73
+ * name: "NetworkWatcher_eastus",
74
+ * location: "eastus",
75
+ * resourceGroupId: networkWatcherRg.id,
76
+ * });
77
+ *
78
+ * // Then use it with NSG Flow Logs
79
+ * const flowLog = new NsgFlowLog(this, "flow-log", {
80
+ * networkWatcherId: networkWatcher.id,
81
+ * // ... other properties
82
+ * });
83
+ *
84
+ * @stability stable
85
+ */
86
+ class NetworkWatcher extends azapi_resource_1.AzapiResource {
87
+ /**
88
+ * Creates a new Azure Network Watcher using the AzapiResource framework
89
+ *
90
+ * The constructor automatically handles version resolution, schema registration,
91
+ * validation, and resource creation.
92
+ *
93
+ * IMPORTANT: Azure only allows one Network Watcher per subscription per region.
94
+ * Attempting to create a Network Watcher in a region where one already exists
95
+ * will result in a deployment error.
96
+ *
97
+ * @param scope - The scope in which to define this construct
98
+ * @param id - The unique identifier for this instance
99
+ * @param props - Configuration properties for the Network Watcher
100
+ */
101
+ constructor(scope, id, props) {
102
+ super(scope, id, props);
103
+ this.props = props;
104
+ // Create Terraform outputs for easy access and referencing from other resources
105
+ this.idOutput = new cdktf.TerraformOutput(this, "id", {
106
+ value: this.id,
107
+ description: "The ID of the Network Watcher",
108
+ });
109
+ this.nameOutput = new cdktf.TerraformOutput(this, "name", {
110
+ value: `\${${this.terraformResource.fqn}.name}`,
111
+ description: "The name of the Network Watcher",
112
+ });
113
+ this.locationOutput = new cdktf.TerraformOutput(this, "location", {
114
+ value: `\${${this.terraformResource.fqn}.output.location}`,
115
+ description: "The location of the Network Watcher",
116
+ });
117
+ this.provisioningStateOutput = new cdktf.TerraformOutput(this, "provisioning_state", {
118
+ value: `\${${this.terraformResource.fqn}.output.properties.provisioningState}`,
119
+ description: "The provisioning state of the Network Watcher",
120
+ });
121
+ // Override logical IDs
122
+ this.idOutput.overrideLogicalId("id");
123
+ this.nameOutput.overrideLogicalId("name");
124
+ this.locationOutput.overrideLogicalId("location");
125
+ this.provisioningStateOutput.overrideLogicalId("provisioning_state");
126
+ }
127
+ // =============================================================================
128
+ // REQUIRED ABSTRACT METHODS FROM AzapiResource
129
+ // =============================================================================
130
+ /**
131
+ * Gets the default API version to use when no explicit version is specified
132
+ * Returns the latest stable version as the default
133
+ */
134
+ defaultVersion() {
135
+ return "2024-01-01";
136
+ }
137
+ /**
138
+ * Gets the Azure resource type for Network Watcher
139
+ */
140
+ resourceType() {
141
+ return network_watcher_schemas_1.NETWORK_WATCHER_TYPE;
142
+ }
143
+ /**
144
+ * Gets the API schema for the resolved version
145
+ * Uses the framework's schema resolution to get the appropriate schema
146
+ */
147
+ apiSchema() {
148
+ return this.resolveSchema();
149
+ }
150
+ /**
151
+ * Indicates that this resource type requires a location
152
+ */
153
+ requiresLocation() {
154
+ return true;
155
+ }
156
+ /**
157
+ * Creates the resource body for the Azure API call
158
+ *
159
+ * Network Watcher is a simple resource with an empty properties block.
160
+ * All configuration is handled at the resource level (name, location, tags).
161
+ */
162
+ createResourceBody(_props) {
163
+ // Network Watcher has an empty properties block
164
+ // The resource is configured primarily through name, location, and tags
165
+ const body = {
166
+ properties: {},
167
+ };
168
+ return body;
169
+ }
170
+ /**
171
+ * Resolves the parent resource ID for Network Watcher
172
+ * Network Watcher is a top-level resource within a resource group
173
+ *
174
+ * @param props - The resource properties
175
+ * @returns The parent resource ID (the resource group)
176
+ */
177
+ resolveParentId(props) {
178
+ return props.resourceGroupId;
179
+ }
180
+ }
181
+ exports.NetworkWatcher = NetworkWatcher;
182
+ _a = JSII_RTTI_SYMBOL_1;
183
+ NetworkWatcher[_a] = { fqn: "@microsoft/terraform-cdk-constructs.NetworkWatcher", version: "1.9.0" };
184
+ (() => {
185
+ azapi_resource_1.AzapiResource.registerSchemas(network_watcher_schemas_1.NETWORK_WATCHER_TYPE, network_watcher_schemas_1.ALL_NETWORK_WATCHER_VERSIONS);
186
+ })();
187
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-watcher.js","sourceRoot":"","sources":["../../../src/azure-networkwatcher/lib/network-watcher.ts"],"names":[],"mappings":";;;;;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AAEH,+BAA+B;AAE/B,uEAGmC;AACnC,8EAGmD;AAiCnD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiDG;AACH,MAAa,cAAe,SAAQ,8BAAa;IAkC/C;;;;;;;;;;;;;OAaG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA0B;QAClE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;QAExB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,gFAAgF;QAChF,IAAI,CAAC,QAAQ,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,EAAE;YACpD,KAAK,EAAE,IAAI,CAAC,EAAE;YACd,WAAW,EAAE,+BAA+B;SAC7C,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE;YACxD,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,QAAQ;YAC/C,WAAW,EAAE,iCAAiC;SAC/C,CAAC,CAAC;QAEH,IAAI,CAAC,cAAc,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,UAAU,EAAE;YAChE,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,mBAAmB;YAC1D,WAAW,EAAE,qCAAqC;SACnD,CAAC,CAAC;QAEH,IAAI,CAAC,uBAAuB,GAAG,IAAI,KAAK,CAAC,eAAe,CACtD,IAAI,EACJ,oBAAoB,EACpB;YACE,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,uCAAuC;YAC9E,WAAW,EAAE,+CAA+C;SAC7D,CACF,CAAC;QAEF,uBAAuB;QACvB,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QACtC,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;QAC1C,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;QAClD,IAAI,CAAC,uBAAuB,CAAC,iBAAiB,CAAC,oBAAoB,CAAC,CAAC;IACvE,CAAC;IAED,gFAAgF;IAChF,+CAA+C;IAC/C,gFAAgF;IAEhF;;;OAGG;IACO,cAAc;QACtB,OAAO,YAAY,CAAC;IACtB,CAAC;IAED;;OAEG;IACO,YAAY;QACpB,OAAO,8CAAoB,CAAC;IAC9B,CAAC;IAED;;;OAGG;IACO,SAAS;QACjB,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC;IAC9B,CAAC;IAED;;OAEG;IACO,gBAAgB;QACxB,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;OAKG;IACO,kBAAkB,CAAC,MAAW;QACtC,gDAAgD;QAChD,wEAAwE;QACxE,MAAM,IAAI,GAAQ;YAChB,UAAU,EAAE,EAAE;SACf,CAAC;QAEF,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;;OAMG;IACO,eAAe,CAAC,KAAU;QAClC,OAAQ,KAA6B,CAAC,eAAe,CAAC;IACxD,CAAC;;AAhJH,wCAiJC;;;AAhJC;IACE,8BAAa,CAAC,eAAe,CAC3B,8CAAoB,EACpB,sDAA4B,CAC7B,CAAC;AACJ,CAAC,GAAA,CAAA","sourcesContent":["/**\n * Unified Azure Network Watcher implementation using AzapiResource framework\n *\n * This class provides a version-aware implementation for Azure Network Watcher\n * that automatically handles version management, schema validation, and property\n * transformation across all supported API versions.\n *\n * IMPORTANT: Azure only allows one Network Watcher per subscription per region.\n * If you attempt to create a Network Watcher in a region where one already exists,\n * the deployment will fail.\n *\n * Supported API Versions:\n * - 2024-01-01 (Active, Latest)\n * - 2023-11-01 (Active, Backward Compatibility)\n *\n * Features:\n * - Automatic latest version resolution when no version is specified\n * - Explicit version pinning for stability requirements\n * - Schema-driven validation and transformation\n * - Full JSII compliance for multi-language support\n *\n * Network Watcher is primarily used as a dependency for other Network Watcher features:\n * - Flow Logs\n * - Connection Monitor\n * - Packet Capture\n * - Network Diagnostic Tools\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_NETWORK_WATCHER_VERSIONS,\n  NETWORK_WATCHER_TYPE,\n} from \"./network-watcher-schemas\";\nimport {\n  AzapiResource,\n  AzapiResourceProps,\n} from \"../../core-azure/lib/azapi/azapi-resource\";\nimport { ApiSchema } from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n/**\n * Properties for the unified Azure Network Watcher\n *\n * Extends AzapiResourceProps with Network Watcher specific properties.\n *\n * IMPORTANT: Azure only allows one Network Watcher per subscription per region.\n * Attempting to create multiple Network Watchers in the same region will fail.\n */\nexport interface NetworkWatcherProps extends AzapiResourceProps {\n  /**\n   * Resource Group ID where the Network Watcher will be created\n   *\n   * The Network Watcher will be created as a child of this resource group.\n   * It's recommended to use a dedicated resource group for Network Watchers,\n   * as Azure automatically creates one named \"NetworkWatcherRG\" when certain\n   * network features are used.\n   */\n  readonly resourceGroupId: string;\n}\n\n/**\n * The resource body interface for Azure Network Watcher API calls\n *\n * Network Watcher is a simple resource with minimal properties.\n * The properties block is typically empty.\n */\nexport interface NetworkWatcherBody {\n  readonly properties: { [key: string]: any };\n}\n\n/**\n * Unified Azure Network Watcher implementation\n *\n * This class provides a single, version-aware implementation that automatically handles version\n * resolution, schema validation, and property transformation while maintaining full JSII compliance.\n *\n * Network Watcher is a regional service that provides tools to monitor, diagnose, and gain\n * insights into your network health and performance in Azure. It serves as the anchor for\n * Network Watcher features like Flow Logs, Connection Monitor, and Packet Capture.\n *\n * IMPORTANT CONSTRAINT: Azure only allows one Network Watcher per subscription per region.\n * If you need Network Watcher functionality in multiple regions, you must create a separate\n * Network Watcher for each region.\n *\n * @example\n * // Basic Network Watcher:\n * const networkWatcher = new NetworkWatcher(this, \"network-watcher\", {\n *   name: \"nw-eastus\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n * });\n *\n * @example\n * // Network Watcher with specific API version:\n * const networkWatcher = new NetworkWatcher(this, \"network-watcher\", {\n *   name: \"nw-westus2\",\n *   location: \"westus2\",\n *   resourceGroupId: resourceGroup.id,\n *   apiVersion: \"2024-01-01\",\n *   tags: {\n *     environment: \"production\",\n *   },\n * });\n *\n * @example\n * // Network Watcher for use with Flow Logs:\n * const networkWatcher = new NetworkWatcher(this, \"network-watcher\", {\n *   name: \"NetworkWatcher_eastus\",\n *   location: \"eastus\",\n *   resourceGroupId: networkWatcherRg.id,\n * });\n *\n * // Then use it with NSG Flow Logs\n * const flowLog = new NsgFlowLog(this, \"flow-log\", {\n *   networkWatcherId: networkWatcher.id,\n *   // ... other properties\n * });\n *\n * @stability stable\n */\nexport class NetworkWatcher extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      NETWORK_WATCHER_TYPE,\n      ALL_NETWORK_WATCHER_VERSIONS,\n    );\n  }\n\n  /**\n   * The input properties for this Network Watcher instance\n   */\n  public readonly props: NetworkWatcherProps;\n\n  // Output properties for easy access and referencing\n  /**\n   * Terraform output for the Network Watcher resource ID\n   */\n  public readonly idOutput: cdktf.TerraformOutput;\n\n  /**\n   * Terraform output for the Network Watcher name\n   */\n  public readonly nameOutput: cdktf.TerraformOutput;\n\n  /**\n   * Terraform output for the Network Watcher location\n   */\n  public readonly locationOutput: cdktf.TerraformOutput;\n\n  /**\n   * Terraform output for the Network Watcher provisioning state\n   */\n  public readonly provisioningStateOutput: cdktf.TerraformOutput;\n\n  /**\n   * Creates a new Azure Network Watcher using the AzapiResource framework\n   *\n   * The constructor automatically handles version resolution, schema registration,\n   * validation, and resource creation.\n   *\n   * IMPORTANT: Azure only allows one Network Watcher per subscription per region.\n   * Attempting to create a Network Watcher in a region where one already exists\n   * will result in a deployment error.\n   *\n   * @param scope - The scope in which to define this construct\n   * @param id - The unique identifier for this instance\n   * @param props - Configuration properties for the Network Watcher\n   */\n  constructor(scope: Construct, id: string, props: NetworkWatcherProps) {\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Create Terraform outputs for easy access and referencing from other resources\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the Network Watcher\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the Network Watcher\",\n    });\n\n    this.locationOutput = new cdktf.TerraformOutput(this, \"location\", {\n      value: `\\${${this.terraformResource.fqn}.output.location}`,\n      description: \"The location of the Network Watcher\",\n    });\n\n    this.provisioningStateOutput = new cdktf.TerraformOutput(\n      this,\n      \"provisioning_state\",\n      {\n        value: `\\${${this.terraformResource.fqn}.output.properties.provisioningState}`,\n        description: \"The provisioning state of the Network Watcher\",\n      },\n    );\n\n    // Override logical IDs\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.locationOutput.overrideLogicalId(\"location\");\n    this.provisioningStateOutput.overrideLogicalId(\"provisioning_state\");\n  }\n\n  // =============================================================================\n  // REQUIRED ABSTRACT METHODS FROM AzapiResource\n  // =============================================================================\n\n  /**\n   * Gets the default API version to use when no explicit version is specified\n   * Returns the latest stable version as the default\n   */\n  protected defaultVersion(): string {\n    return \"2024-01-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for Network Watcher\n   */\n  protected resourceType(): string {\n    return NETWORK_WATCHER_TYPE;\n  }\n\n  /**\n   * Gets the API schema for the resolved version\n   * Uses the framework's schema resolution to get the appropriate schema\n   */\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  /**\n   * Indicates that this resource type requires a location\n   */\n  protected requiresLocation(): boolean {\n    return true;\n  }\n\n  /**\n   * Creates the resource body for the Azure API call\n   *\n   * Network Watcher is a simple resource with an empty properties block.\n   * All configuration is handled at the resource level (name, location, tags).\n   */\n  protected createResourceBody(_props: any): any {\n    // Network Watcher has an empty properties block\n    // The resource is configured primarily through name, location, and tags\n    const body: any = {\n      properties: {},\n    };\n\n    return body;\n  }\n\n  /**\n   * Resolves the parent resource ID for Network Watcher\n   * Network Watcher is a top-level resource within a resource group\n   *\n   * @param props - The resource properties\n   * @returns The parent resource ID (the resource group)\n   */\n  protected resolveParentId(props: any): string {\n    return (props as NetworkWatcherProps).resourceGroupId;\n  }\n}\n"]}
@@ -0,0 +1,12 @@
1
+ /**
2
+ * Integration test for Azure Network Watcher
3
+ *
4
+ * This test demonstrates basic usage of the NetworkWatcher construct
5
+ * and validates deployment, idempotency, and cleanup.
6
+ *
7
+ * IMPORTANT: Azure only allows one Network Watcher per subscription per region.
8
+ * If a Network Watcher already exists in the test region, this test will fail.
9
+ *
10
+ * Run with: npm run integration:nostream
11
+ */
12
+ import "cdktf/lib/testing/adapters/jest";
@@ -0,0 +1,84 @@
1
+ "use strict";
2
+ /**
3
+ * Integration test for Azure Network Watcher
4
+ *
5
+ * This test demonstrates basic usage of the NetworkWatcher construct
6
+ * and validates deployment, idempotency, and cleanup.
7
+ *
8
+ * IMPORTANT: Azure only allows one Network Watcher per subscription per region.
9
+ * If a Network Watcher already exists in the test region, this test will fail.
10
+ *
11
+ * Run with: npm run integration:nostream
12
+ */
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ const cdktf_1 = require("cdktf");
15
+ require("cdktf/lib/testing/adapters/jest");
16
+ const azure_resourcegroup_1 = require("../../azure-resourcegroup");
17
+ const provider_1 = require("../../core-azure/lib/azapi/providers-azapi/provider");
18
+ const testing_1 = require("../../testing");
19
+ const network_watcher_1 = require("../lib/network-watcher");
20
+ /**
21
+ * Example stack demonstrating Network Watcher usage
22
+ *
23
+ * Note: This example creates a dedicated resource group for the Network Watcher.
24
+ * In practice, Azure often uses a resource group named "NetworkWatcherRG" for
25
+ * automatically provisioned Network Watchers.
26
+ */
27
+ class NetworkWatcherExampleStack extends cdktf_1.TerraformStack {
28
+ constructor(scope, id) {
29
+ super(scope, id);
30
+ // Configure AZAPI provider
31
+ new provider_1.AzapiProvider(this, "azapi", {});
32
+ // Create a resource group for Network Watcher
33
+ // Note: Azure typically uses NetworkWatcherRG for auto-provisioned Network Watchers
34
+ // Using northeurope to avoid conflict with existing Network Watchers
35
+ const resourceGroup = new azure_resourcegroup_1.ResourceGroup(this, "example-rg", {
36
+ name: "nw-example-rg",
37
+ location: "northeurope",
38
+ tags: {
39
+ environment: "example",
40
+ purpose: "integration-test",
41
+ },
42
+ });
43
+ // Example 1: Basic Network Watcher
44
+ // Note: Only one Network Watcher per region per subscription is allowed
45
+ new network_watcher_1.NetworkWatcher(this, "basic-network-watcher", {
46
+ name: "nw-basic-example",
47
+ location: resourceGroup.props.location,
48
+ resourceGroupId: resourceGroup.id,
49
+ tags: {
50
+ example: "basic",
51
+ },
52
+ });
53
+ // Example 2: Network Watcher with specific version
54
+ // Using a different construct ID but same region (this is for demonstration only -
55
+ // in practice, you should only have one Network Watcher per region)
56
+ // This example shows version pinning but would fail if deployed alongside Example 1
57
+ // since both use the same region.
58
+ // Uncomment for testing version pinning in a different region:
59
+ /*
60
+ new NetworkWatcher(this, "versioned-network-watcher", {
61
+ name: "nw-versioned-example",
62
+ location: "westus2", // Different region
63
+ resourceGroupId: resourceGroup.id,
64
+ apiVersion: "2024-01-01",
65
+ tags: {
66
+ example: "versioned",
67
+ },
68
+ });
69
+ */
70
+ }
71
+ }
72
+ describe("Network Watcher Integration Test", () => {
73
+ it("should deploy, validate idempotency, and cleanup Network Watcher resources", () => {
74
+ const app = cdktf_1.Testing.app();
75
+ const stack = new NetworkWatcherExampleStack(app, "test-network-watcher");
76
+ const synthesized = cdktf_1.Testing.fullSynth(stack);
77
+ // This will:
78
+ // 1. Run terraform apply to deploy resources
79
+ // 2. Run terraform plan to check idempotency (no changes expected)
80
+ // 3. Run terraform destroy to cleanup resources
81
+ (0, testing_1.TerraformApplyCheckAndDestroy)(synthesized);
82
+ }, 600000); // 10 minute timeout for deployment and cleanup
83
+ });
84
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmV0d29yay13YXRjaGVyLmludGVnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2F6dXJlLW5ldHdvcmt3YXRjaGVyL3Rlc3QvbmV0d29yay13YXRjaGVyLmludGVnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7Ozs7OztHQVVHOztBQUVILGlDQUFnRDtBQUVoRCwyQ0FBeUM7QUFDekMsbUVBQTBEO0FBQzFELGtGQUFvRjtBQUNwRiwyQ0FBOEQ7QUFDOUQsNERBQXdEO0FBRXhEOzs7Ozs7R0FNRztBQUNILE1BQU0sMEJBQTJCLFNBQVEsc0JBQWM7SUFDckQsWUFBWSxLQUFnQixFQUFFLEVBQVU7UUFDdEMsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQiwyQkFBMkI7UUFDM0IsSUFBSSx3QkFBYSxDQUFDLElBQUksRUFBRSxPQUFPLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFckMsOENBQThDO1FBQzlDLG9GQUFvRjtRQUNwRixxRUFBcUU7UUFDckUsTUFBTSxhQUFhLEdBQUcsSUFBSSxtQ0FBYSxDQUFDLElBQUksRUFBRSxZQUFZLEVBQUU7WUFDMUQsSUFBSSxFQUFFLGVBQWU7WUFDckIsUUFBUSxFQUFFLGFBQWE7WUFDdkIsSUFBSSxFQUFFO2dCQUNKLFdBQVcsRUFBRSxTQUFTO2dCQUN0QixPQUFPLEVBQUUsa0JBQWtCO2FBQzVCO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsbUNBQW1DO1FBQ25DLHdFQUF3RTtRQUN4RSxJQUFJLGdDQUFjLENBQUMsSUFBSSxFQUFFLHVCQUF1QixFQUFFO1lBQ2hELElBQUksRUFBRSxrQkFBa0I7WUFDeEIsUUFBUSxFQUFFLGFBQWEsQ0FBQyxLQUFLLENBQUMsUUFBUztZQUN2QyxlQUFlLEVBQUUsYUFBYSxDQUFDLEVBQUU7WUFDakMsSUFBSSxFQUFFO2dCQUNKLE9BQU8sRUFBRSxPQUFPO2FBQ2pCO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsbURBQW1EO1FBQ25ELG1GQUFtRjtRQUNuRixvRUFBb0U7UUFDcEUsb0ZBQW9GO1FBQ3BGLGtDQUFrQztRQUNsQywrREFBK0Q7UUFDL0Q7Ozs7Ozs7Ozs7VUFVRTtJQUNKLENBQUM7Q0FDRjtBQUVELFFBQVEsQ0FBQyxrQ0FBa0MsRUFBRSxHQUFHLEVBQUU7SUFDaEQsRUFBRSxDQUFDLDRFQUE0RSxFQUFFLEdBQUcsRUFBRTtRQUNwRixNQUFNLEdBQUcsR0FBRyxlQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDMUIsTUFBTSxLQUFLLEdBQUcsSUFBSSwwQkFBMEIsQ0FBQyxHQUFHLEVBQUUsc0JBQXNCLENBQUMsQ0FBQztRQUMxRSxNQUFNLFdBQVcsR0FBRyxlQUFPLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRTdDLGFBQWE7UUFDYiw2Q0FBNkM7UUFDN0MsbUVBQW1FO1FBQ25FLGdEQUFnRDtRQUNoRCxJQUFBLHVDQUE2QixFQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQzdDLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLCtDQUErQztBQUM3RCxDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogSW50ZWdyYXRpb24gdGVzdCBmb3IgQXp1cmUgTmV0d29yayBXYXRjaGVyXG4gKlxuICogVGhpcyB0ZXN0IGRlbW9uc3RyYXRlcyBiYXNpYyB1c2FnZSBvZiB0aGUgTmV0d29ya1dhdGNoZXIgY29uc3RydWN0XG4gKiBhbmQgdmFsaWRhdGVzIGRlcGxveW1lbnQsIGlkZW1wb3RlbmN5LCBhbmQgY2xlYW51cC5cbiAqXG4gKiBJTVBPUlRBTlQ6IEF6dXJlIG9ubHkgYWxsb3dzIG9uZSBOZXR3b3JrIFdhdGNoZXIgcGVyIHN1YnNjcmlwdGlvbiBwZXIgcmVnaW9uLlxuICogSWYgYSBOZXR3b3JrIFdhdGNoZXIgYWxyZWFkeSBleGlzdHMgaW4gdGhlIHRlc3QgcmVnaW9uLCB0aGlzIHRlc3Qgd2lsbCBmYWlsLlxuICpcbiAqIFJ1biB3aXRoOiBucG0gcnVuIGludGVncmF0aW9uOm5vc3RyZWFtXG4gKi9cblxuaW1wb3J0IHsgVGVzdGluZywgVGVycmFmb3JtU3RhY2sgfSBmcm9tIFwiY2RrdGZcIjtcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gXCJjb25zdHJ1Y3RzXCI7XG5pbXBvcnQgXCJjZGt0Zi9saWIvdGVzdGluZy9hZGFwdGVycy9qZXN0XCI7XG5pbXBvcnQgeyBSZXNvdXJjZUdyb3VwIH0gZnJvbSBcIi4uLy4uL2F6dXJlLXJlc291cmNlZ3JvdXBcIjtcbmltcG9ydCB7IEF6YXBpUHJvdmlkZXIgfSBmcm9tIFwiLi4vLi4vY29yZS1henVyZS9saWIvYXphcGkvcHJvdmlkZXJzLWF6YXBpL3Byb3ZpZGVyXCI7XG5pbXBvcnQgeyBUZXJyYWZvcm1BcHBseUNoZWNrQW5kRGVzdHJveSB9IGZyb20gXCIuLi8uLi90ZXN0aW5nXCI7XG5pbXBvcnQgeyBOZXR3b3JrV2F0Y2hlciB9IGZyb20gXCIuLi9saWIvbmV0d29yay13YXRjaGVyXCI7XG5cbi8qKlxuICogRXhhbXBsZSBzdGFjayBkZW1vbnN0cmF0aW5nIE5ldHdvcmsgV2F0Y2hlciB1c2FnZVxuICpcbiAqIE5vdGU6IFRoaXMgZXhhbXBsZSBjcmVhdGVzIGEgZGVkaWNhdGVkIHJlc291cmNlIGdyb3VwIGZvciB0aGUgTmV0d29yayBXYXRjaGVyLlxuICogSW4gcHJhY3RpY2UsIEF6dXJlIG9mdGVuIHVzZXMgYSByZXNvdXJjZSBncm91cCBuYW1lZCBcIk5ldHdvcmtXYXRjaGVyUkdcIiBmb3JcbiAqIGF1dG9tYXRpY2FsbHkgcHJvdmlzaW9uZWQgTmV0d29yayBXYXRjaGVycy5cbiAqL1xuY2xhc3MgTmV0d29ya1dhdGNoZXJFeGFtcGxlU3RhY2sgZXh0ZW5kcyBUZXJyYWZvcm1TdGFjayB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgLy8gQ29uZmlndXJlIEFaQVBJIHByb3ZpZGVyXG4gICAgbmV3IEF6YXBpUHJvdmlkZXIodGhpcywgXCJhemFwaVwiLCB7fSk7XG5cbiAgICAvLyBDcmVhdGUgYSByZXNvdXJjZSBncm91cCBmb3IgTmV0d29yayBXYXRjaGVyXG4gICAgLy8gTm90ZTogQXp1cmUgdHlwaWNhbGx5IHVzZXMgTmV0d29ya1dhdGNoZXJSRyBmb3IgYXV0by1wcm92aXNpb25lZCBOZXR3b3JrIFdhdGNoZXJzXG4gICAgLy8gVXNpbmcgbm9ydGhldXJvcGUgdG8gYXZvaWQgY29uZmxpY3Qgd2l0aCBleGlzdGluZyBOZXR3b3JrIFdhdGNoZXJzXG4gICAgY29uc3QgcmVzb3VyY2VHcm91cCA9IG5ldyBSZXNvdXJjZUdyb3VwKHRoaXMsIFwiZXhhbXBsZS1yZ1wiLCB7XG4gICAgICBuYW1lOiBcIm53LWV4YW1wbGUtcmdcIixcbiAgICAgIGxvY2F0aW9uOiBcIm5vcnRoZXVyb3BlXCIsXG4gICAgICB0YWdzOiB7XG4gICAgICAgIGVudmlyb25tZW50OiBcImV4YW1wbGVcIixcbiAgICAgICAgcHVycG9zZTogXCJpbnRlZ3JhdGlvbi10ZXN0XCIsXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgLy8gRXhhbXBsZSAxOiBCYXNpYyBOZXR3b3JrIFdhdGNoZXJcbiAgICAvLyBOb3RlOiBPbmx5IG9uZSBOZXR3b3JrIFdhdGNoZXIgcGVyIHJlZ2lvbiBwZXIgc3Vic2NyaXB0aW9uIGlzIGFsbG93ZWRcbiAgICBuZXcgTmV0d29ya1dhdGNoZXIodGhpcywgXCJiYXNpYy1uZXR3b3JrLXdhdGNoZXJcIiwge1xuICAgICAgbmFtZTogXCJudy1iYXNpYy1leGFtcGxlXCIsXG4gICAgICBsb2NhdGlvbjogcmVzb3VyY2VHcm91cC5wcm9wcy5sb2NhdGlvbiEsXG4gICAgICByZXNvdXJjZUdyb3VwSWQ6IHJlc291cmNlR3JvdXAuaWQsXG4gICAgICB0YWdzOiB7XG4gICAgICAgIGV4YW1wbGU6IFwiYmFzaWNcIixcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICAvLyBFeGFtcGxlIDI6IE5ldHdvcmsgV2F0Y2hlciB3aXRoIHNwZWNpZmljIHZlcnNpb25cbiAgICAvLyBVc2luZyBhIGRpZmZlcmVudCBjb25zdHJ1Y3QgSUQgYnV0IHNhbWUgcmVnaW9uICh0aGlzIGlzIGZvciBkZW1vbnN0cmF0aW9uIG9ubHkgLVxuICAgIC8vIGluIHByYWN0aWNlLCB5b3Ugc2hvdWxkIG9ubHkgaGF2ZSBvbmUgTmV0d29yayBXYXRjaGVyIHBlciByZWdpb24pXG4gICAgLy8gVGhpcyBleGFtcGxlIHNob3dzIHZlcnNpb24gcGlubmluZyBidXQgd291bGQgZmFpbCBpZiBkZXBsb3llZCBhbG9uZ3NpZGUgRXhhbXBsZSAxXG4gICAgLy8gc2luY2UgYm90aCB1c2UgdGhlIHNhbWUgcmVnaW9uLlxuICAgIC8vIFVuY29tbWVudCBmb3IgdGVzdGluZyB2ZXJzaW9uIHBpbm5pbmcgaW4gYSBkaWZmZXJlbnQgcmVnaW9uOlxuICAgIC8qXG4gICAgbmV3IE5ldHdvcmtXYXRjaGVyKHRoaXMsIFwidmVyc2lvbmVkLW5ldHdvcmstd2F0Y2hlclwiLCB7XG4gICAgICBuYW1lOiBcIm53LXZlcnNpb25lZC1leGFtcGxlXCIsXG4gICAgICBsb2NhdGlvbjogXCJ3ZXN0dXMyXCIsICAvLyBEaWZmZXJlbnQgcmVnaW9uXG4gICAgICByZXNvdXJjZUdyb3VwSWQ6IHJlc291cmNlR3JvdXAuaWQsXG4gICAgICBhcGlWZXJzaW9uOiBcIjIwMjQtMDEtMDFcIixcbiAgICAgIHRhZ3M6IHtcbiAgICAgICAgZXhhbXBsZTogXCJ2ZXJzaW9uZWRcIixcbiAgICAgIH0sXG4gICAgfSk7XG4gICAgKi9cbiAgfVxufVxuXG5kZXNjcmliZShcIk5ldHdvcmsgV2F0Y2hlciBJbnRlZ3JhdGlvbiBUZXN0XCIsICgpID0+IHtcbiAgaXQoXCJzaG91bGQgZGVwbG95LCB2YWxpZGF0ZSBpZGVtcG90ZW5jeSwgYW5kIGNsZWFudXAgTmV0d29yayBXYXRjaGVyIHJlc291cmNlc1wiLCAoKSA9PiB7XG4gICAgY29uc3QgYXBwID0gVGVzdGluZy5hcHAoKTtcbiAgICBjb25zdCBzdGFjayA9IG5ldyBOZXR3b3JrV2F0Y2hlckV4YW1wbGVTdGFjayhhcHAsIFwidGVzdC1uZXR3b3JrLXdhdGNoZXJcIik7XG4gICAgY29uc3Qgc3ludGhlc2l6ZWQgPSBUZXN0aW5nLmZ1bGxTeW50aChzdGFjayk7XG5cbiAgICAvLyBUaGlzIHdpbGw6XG4gICAgLy8gMS4gUnVuIHRlcnJhZm9ybSBhcHBseSB0byBkZXBsb3kgcmVzb3VyY2VzXG4gICAgLy8gMi4gUnVuIHRlcnJhZm9ybSBwbGFuIHRvIGNoZWNrIGlkZW1wb3RlbmN5IChubyBjaGFuZ2VzIGV4cGVjdGVkKVxuICAgIC8vIDMuIFJ1biB0ZXJyYWZvcm0gZGVzdHJveSB0byBjbGVhbnVwIHJlc291cmNlc1xuICAgIFRlcnJhZm9ybUFwcGx5Q2hlY2tBbmREZXN0cm95KHN5bnRoZXNpemVkKTtcbiAgfSwgNjAwMDAwKTsgLy8gMTAgbWludXRlIHRpbWVvdXQgZm9yIGRlcGxveW1lbnQgYW5kIGNsZWFudXBcbn0pO1xuIl19
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Comprehensive tests for the NetworkWatcher implementation
3
+ *
4
+ * This test suite validates the NetworkWatcher class using the AzapiResource framework.
5
+ * Tests cover automatic version resolution, explicit version pinning, schema validation,
6
+ * property configurations, and resource creation.
7
+ */
8
+ export {};