@horietakehiro/aws-cdk-utul 0.35.6 → 0.40.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.
@@ -1,4 +1,4 @@
1
- import { Template, Match, Matcher } from "aws-cdk-lib/assertions";
1
+ import { Template, Matcher } from "aws-cdk-lib/assertions";
2
2
  import { Condition, InputResource, Mapping, OutputResource, InputParamter, OutputParameter, ReturnValue, InputOutput, OutputOutput, InputResourceWithoutType, IAMPolicyDocument, AlsoMatcher, TypedMatcher } from "./typed-resource";
3
3
  /**
4
4
  * almost same class as `Template` class at "aws-cdk-lib/assertions", but you can use this with proper type definitions
@@ -141,7 +141,7 @@ export interface JoinProps {
141
141
  /**
142
142
  * provides some syntax sugars for `Match` class at `aws-cdk-lib/assertions`
143
143
  */
144
- export declare class ExtraMatch extends Match {
144
+ export declare class ExtraMatch {
145
145
  /**
146
146
  * same function as `Match.objectEquals({ Ref: logicalId })`
147
147
  * @param logicalId
@@ -161,16 +161,6 @@ export declare class ExtraMatch extends Match {
161
161
  * @returns
162
162
  */
163
163
  static getAttArn(logicalId: string): Matcher;
164
- static arrayWith<T extends any[]>(pattern: AlsoMatcher<T>): TypedMatcher<T>;
165
- static arrayEquals<T extends any[]>(pattern: AlsoMatcher<T>): TypedMatcher<T>;
166
- static objectLike<T extends {
167
- [key: string]: any;
168
- }>(pattern: AlsoMatcher<T>): TypedMatcher<T>;
169
- static objectEquals<T extends {
170
- [key: string]: any;
171
- }>(pattern: AlsoMatcher<T>): TypedMatcher<T>;
172
- static not<T>(pattern: AlsoMatcher<T>): TypedMatcher<T>;
173
- static exact<T>(pattern: AlsoMatcher<T>): TypedMatcher<T>;
174
164
  /**
175
165
  * same function as below:
176
166
  *
@@ -183,5 +173,222 @@ export declare class ExtraMatch extends Match {
183
173
  * @returns
184
174
  */
185
175
  static joinLike(props: JoinProps): Matcher;
176
+ /**
177
+ You can define Matcher for IAM Policy Document with type hints.
178
+ ```js
179
+ template.hasResource(
180
+ AWS_IAM_ROLE({
181
+ Properties: {
182
+ AssumeRolePolicyDocument: ExtraMatch.iamPolicyLike({
183
+ Statement: [
184
+ {
185
+ Principal: { Service: "ec2.amazonaws.com" },
186
+ },
187
+ ],
188
+ }),
189
+ },
190
+ })
191
+ );
192
+ ```
193
+ * @param doc
194
+ * @returns
195
+ */
186
196
  static iamPolicyLike(doc: AlsoMatcher<IAMPolicyDocument>): Matcher;
197
+ /**
198
+ Same method as `Match.arrayWith` but provides type hints and validate type match
199
+ ```js
200
+ // this is a right code
201
+ template.hasResource(
202
+ AWS_EC2_EIP({
203
+ Properties: {
204
+ Tags: ExtraMatch.arrayWith<Tag[]>([
205
+ {
206
+ Key: "key2",
207
+ Value: "val2",
208
+ },
209
+ ]),
210
+ },
211
+ })
212
+ );
213
+ // this is a wrong code(type mismatch will be detected and ts-error will be raised)
214
+ template.hasResource(
215
+ AWS_EC2_EIP({
216
+ Properties: {
217
+ Tags: ExtraMatch.arrayWith<string[]>([
218
+ "hoge", "fuga"
219
+ ]),
220
+ },
221
+ })
222
+ );
223
+ ```
224
+ * @param pattern
225
+ * @returns
226
+ */
227
+ static arrayWith<T extends any[]>(pattern: AlsoMatcher<T>): TypedMatcher<T>;
228
+ /**
229
+ * Same method as `Match.arrayEquals` but provides type hints and validate type match
230
+ ```js
231
+ // this is a right code
232
+ template.hasResource(
233
+ AWS_EC2_EIP({
234
+ Properties: {
235
+ Tags: ExtraMatch.arrayEquals<Tag[]>([
236
+ {
237
+ Key: "key1",
238
+ Value: "val1",
239
+ },
240
+ {
241
+ Key: "key2",
242
+ Value: "val2",
243
+ },
244
+ ]),
245
+ },
246
+ })
247
+ );
248
+ // this is a wrong code(type mismatch will be detected and ts-error will be raised)
249
+ template.hasResource(
250
+ AWS_EC2_EIP({
251
+ Properties: {
252
+ Tags: ExtraMatch.arrayEquals<Tag[]>([
253
+ {
254
+ Key: "key1",
255
+ Value: "val1",
256
+ },
257
+ {
258
+ Key: 100,
259
+ Value: 200,
260
+ },
261
+ ]),
262
+ },
263
+ })
264
+ );
265
+ ```
266
+ * @param pattern
267
+ * @returns
268
+ */
269
+ static arrayEquals<T extends any[]>(pattern: AlsoMatcher<T>): TypedMatcher<T>;
270
+ /**
271
+ * Same method as `Match.objectLike` but provides type hints and validate type match
272
+ ```js
273
+ // this is a right code
274
+ template.hasResource(
275
+ AWS_EC2_INSTANCE({
276
+ Properties: {
277
+ BlockDeviceMappings: [
278
+ {
279
+ DeviceName: "test",
280
+ Ebs: ExtraMatch.objectLike<Ebs>({
281
+ VolumeSize: 10,
282
+ }),
283
+ },
284
+ ],
285
+ },
286
+ })
287
+ );
288
+ // this is a wrong code(type mismatch will be detected and ts-error will be raised)
289
+ template.hasResource(
290
+ AWS_EC2_INSTANCE({
291
+ Properties: {
292
+ BlockDeviceMappings: [
293
+ {
294
+ DeviceName: "test",
295
+ Ebs: ExtraMatch.objectLike<Ebs>({
296
+ VolumeSize: "10",
297
+ }),
298
+ },
299
+ ],
300
+ },
301
+ })
302
+ );
303
+ * @param pattern
304
+ * @returns
305
+ */
306
+ static objectLike<T extends {
307
+ [key: string]: any;
308
+ }>(pattern: AlsoMatcher<T>): TypedMatcher<T>;
309
+ /**
310
+ * Same method as `Match.objectEquals` but provides type hints and validate type match
311
+ ```js
312
+ // this is a right code
313
+ template.hasResource(
314
+ AWS_EC2_EIP({
315
+ Properties: {
316
+ // You can nest TypedMatcher(use TypedMatcher inside TypedMatcher)
317
+ Tags: ExtraMatch.arrayWith<Tag[]>([
318
+ ExtraMatch.objectEquals<Tag>({
319
+ Key: "key1",
320
+ Value: "val1",
321
+ }),
322
+ ]),
323
+ },
324
+ })
325
+ );
326
+ // this is a wrong code(type mismatch will be detected and ts-error will be raised)
327
+ template.hasResource(
328
+ AWS_EC2_EIP({
329
+ Properties: {
330
+ Tags: ExtraMatch.arrayWith<Tag[]>([
331
+ ExtraMatch.objectEquals<Tag>({
332
+ Key: "key1",
333
+ Value: 100,
334
+ }),
335
+ ]),
336
+ },
337
+ })
338
+ );
339
+ * @param pattern
340
+ * @returns
341
+ */
342
+ static objectEquals<T extends {
343
+ [key: string]: any;
344
+ }>(pattern: AlsoMatcher<T>): TypedMatcher<T>;
345
+ /**
346
+ * Same method as `Match.not` but provides type hints and validate type match
347
+ ```js
348
+ // this is a right code
349
+ template.hasResource(
350
+ AWS_EC2_INSTANCE({
351
+ Properties: {
352
+ ImageId: ExtraMatch.not("ami-12345"),
353
+ },
354
+ })
355
+ );
356
+ // this is a wrong code(type mismatch will be detected and ts-error will be raised)
357
+ template.hasResource(
358
+ AWS_EC2_INSTANCE({
359
+ Properties: {
360
+ ImageId: ExtraMatch.not(100),
361
+ },
362
+ })
363
+ );
364
+ ```
365
+ * Same method as `Match.not` but provides type hints and validate type match
366
+ * @param pattern
367
+ * @returns
368
+ */
369
+ static not<T>(pattern: AlsoMatcher<T extends never ? never : T>): TypedMatcher<T>;
370
+ /**
371
+ * Same method as `Match.exact` but provides type hints and validate type match
372
+ ```js
373
+ // this is a right code
374
+ template.hasResource(
375
+ AWS_EC2_INSTANCE({
376
+ Properties: {
377
+ InstanceType: ExtraMatch.exact("t2.micro"),
378
+ },
379
+ })
380
+ );
381
+ // this is a wrong code(type mismatch will be detected and ts-error will be raised)
382
+ template.hasResource(
383
+ AWS_EC2_INSTANCE({
384
+ Properties: {
385
+ InstanceType: ExtraMatch.exact(false),
386
+ },
387
+ })
388
+ );
389
+ ```
390
+ * @param pattern
391
+ * @returns
392
+ */
393
+ static exact<T>(pattern: AlsoMatcher<T extends never ? never : T>): TypedMatcher<T>;
187
394
  }
package/lib/assertions.js CHANGED
@@ -199,7 +199,7 @@ exports.TypedTemplate = TypedTemplate;
199
199
  /**
200
200
  * provides some syntax sugars for `Match` class at `aws-cdk-lib/assertions`
201
201
  */
202
- class ExtraMatch extends assertions_1.Match {
202
+ class ExtraMatch {
203
203
  /**
204
204
  * same function as `Match.objectEquals({ Ref: logicalId })`
205
205
  * @param logicalId
@@ -225,24 +225,6 @@ class ExtraMatch extends assertions_1.Match {
225
225
  static getAttArn(logicalId) {
226
226
  return this.getAtt(logicalId, "Arn");
227
227
  }
228
- static arrayWith(pattern) {
229
- return assertions_1.Match.arrayWith(pattern);
230
- }
231
- static arrayEquals(pattern) {
232
- return assertions_1.Match.arrayEquals(pattern);
233
- }
234
- static objectLike(pattern) {
235
- return assertions_1.Match.objectLike(pattern);
236
- }
237
- static objectEquals(pattern) {
238
- return assertions_1.Match.objectEquals(pattern);
239
- }
240
- static not(pattern) {
241
- return assertions_1.Match.not(pattern);
242
- }
243
- static exact(pattern) {
244
- return assertions_1.Match.exact(pattern);
245
- }
246
228
  /**
247
229
  * same function as below:
248
230
  *
@@ -259,55 +241,235 @@ class ExtraMatch extends assertions_1.Match {
259
241
  "Fn::Join": [props.delimiter ?? "", assertions_1.Match.arrayWith(props.arrayWith)],
260
242
  });
261
243
  }
262
- // /**
263
- // * returns Match instance that matches regional resource ARN like : `arn:aws:logs:ap-northeast-1:123456789012:log-group:/log-group-name:log-stream:log-stream-name`
264
- // * @param elems
265
- // * @returns
266
- // */
267
- // static regionalArnLike(elems: AlsoMatcher<ArnElements>): Matcher {
268
- // return Match.objectEquals({
269
- // "Fn::Join": Match.arrayWith([
270
- // "",
271
- // Match.arrayWith([
272
- // "arn:",
273
- // elems.partition ?? { Ref: "AWS::Partition" },
274
- // Match.stringLikeRegexp(`:${elems.service ?? "*"}:`),
275
- // elems.region ?? { Ref: "AWS::Region" },
276
- // elems.account ?? { Ref: "AWS::AccountId" },
277
- // ...(elems.rest instanceof Matcher
278
- // ? [elems.rest]
279
- // : (elems.rest ?? [])),
280
- // ]),
281
- // ]),
282
- // });
283
- // }
284
- // /**
285
- // * returns Match instance that matches global resource ARN like : `arn:aws:iam::123456789012:role/role-name`
286
- // * @param elems
287
- // * @returns
288
- // */
289
- // static globalArn(
290
- // elems: Omit<ArnElements, "region">,
291
- // delimiter: string = ""
292
- // ): Matcher {
293
- // return Match.objectEquals({
294
- // "Fn::Join": Match.arrayEquals([
295
- // delimiter,
296
- // Match.arrayWith([
297
- // "arn:",
298
- // elems.partition ?? { Ref: "AWS::Partition" },
299
- // Match.stringLikeRegexp(`:${elems.service ?? "*"}::`),
300
- // elems.account ?? { Ref: "AWS::AccountId" },
301
- // ...(elems.rest instanceof Matcher
302
- // ? [elems.rest]
303
- // : (elems.rest ?? [])),
304
- // ]),
305
- // ]),
306
- // });
307
- // }
244
+ /**
245
+ You can define Matcher for IAM Policy Document with type hints.
246
+ ```js
247
+ template.hasResource(
248
+ AWS_IAM_ROLE({
249
+ Properties: {
250
+ AssumeRolePolicyDocument: ExtraMatch.iamPolicyLike({
251
+ Statement: [
252
+ {
253
+ Principal: { Service: "ec2.amazonaws.com" },
254
+ },
255
+ ],
256
+ }),
257
+ },
258
+ })
259
+ );
260
+ ```
261
+ * @param doc
262
+ * @returns
263
+ */
308
264
  static iamPolicyLike(doc) {
309
265
  return assertions_1.Match.objectLike(doc);
310
266
  }
267
+ /**
268
+ Same method as `Match.arrayWith` but provides type hints and validate type match
269
+ ```js
270
+ // this is a right code
271
+ template.hasResource(
272
+ AWS_EC2_EIP({
273
+ Properties: {
274
+ Tags: ExtraMatch.arrayWith<Tag[]>([
275
+ {
276
+ Key: "key2",
277
+ Value: "val2",
278
+ },
279
+ ]),
280
+ },
281
+ })
282
+ );
283
+ // this is a wrong code(type mismatch will be detected and ts-error will be raised)
284
+ template.hasResource(
285
+ AWS_EC2_EIP({
286
+ Properties: {
287
+ Tags: ExtraMatch.arrayWith<string[]>([
288
+ "hoge", "fuga"
289
+ ]),
290
+ },
291
+ })
292
+ );
293
+ ```
294
+ * @param pattern
295
+ * @returns
296
+ */
297
+ static arrayWith(pattern) {
298
+ return assertions_1.Match.arrayWith(pattern);
299
+ }
300
+ /**
301
+ * Same method as `Match.arrayEquals` but provides type hints and validate type match
302
+ ```js
303
+ // this is a right code
304
+ template.hasResource(
305
+ AWS_EC2_EIP({
306
+ Properties: {
307
+ Tags: ExtraMatch.arrayEquals<Tag[]>([
308
+ {
309
+ Key: "key1",
310
+ Value: "val1",
311
+ },
312
+ {
313
+ Key: "key2",
314
+ Value: "val2",
315
+ },
316
+ ]),
317
+ },
318
+ })
319
+ );
320
+ // this is a wrong code(type mismatch will be detected and ts-error will be raised)
321
+ template.hasResource(
322
+ AWS_EC2_EIP({
323
+ Properties: {
324
+ Tags: ExtraMatch.arrayEquals<Tag[]>([
325
+ {
326
+ Key: "key1",
327
+ Value: "val1",
328
+ },
329
+ {
330
+ Key: 100,
331
+ Value: 200,
332
+ },
333
+ ]),
334
+ },
335
+ })
336
+ );
337
+ ```
338
+ * @param pattern
339
+ * @returns
340
+ */
341
+ static arrayEquals(pattern) {
342
+ return assertions_1.Match.arrayEquals(pattern);
343
+ }
344
+ /**
345
+ * Same method as `Match.objectLike` but provides type hints and validate type match
346
+ ```js
347
+ // this is a right code
348
+ template.hasResource(
349
+ AWS_EC2_INSTANCE({
350
+ Properties: {
351
+ BlockDeviceMappings: [
352
+ {
353
+ DeviceName: "test",
354
+ Ebs: ExtraMatch.objectLike<Ebs>({
355
+ VolumeSize: 10,
356
+ }),
357
+ },
358
+ ],
359
+ },
360
+ })
361
+ );
362
+ // this is a wrong code(type mismatch will be detected and ts-error will be raised)
363
+ template.hasResource(
364
+ AWS_EC2_INSTANCE({
365
+ Properties: {
366
+ BlockDeviceMappings: [
367
+ {
368
+ DeviceName: "test",
369
+ Ebs: ExtraMatch.objectLike<Ebs>({
370
+ VolumeSize: "10",
371
+ }),
372
+ },
373
+ ],
374
+ },
375
+ })
376
+ );
377
+ * @param pattern
378
+ * @returns
379
+ */
380
+ static objectLike(pattern) {
381
+ return assertions_1.Match.objectLike(pattern);
382
+ }
383
+ /**
384
+ * Same method as `Match.objectEquals` but provides type hints and validate type match
385
+ ```js
386
+ // this is a right code
387
+ template.hasResource(
388
+ AWS_EC2_EIP({
389
+ Properties: {
390
+ // You can nest TypedMatcher(use TypedMatcher inside TypedMatcher)
391
+ Tags: ExtraMatch.arrayWith<Tag[]>([
392
+ ExtraMatch.objectEquals<Tag>({
393
+ Key: "key1",
394
+ Value: "val1",
395
+ }),
396
+ ]),
397
+ },
398
+ })
399
+ );
400
+ // this is a wrong code(type mismatch will be detected and ts-error will be raised)
401
+ template.hasResource(
402
+ AWS_EC2_EIP({
403
+ Properties: {
404
+ Tags: ExtraMatch.arrayWith<Tag[]>([
405
+ ExtraMatch.objectEquals<Tag>({
406
+ Key: "key1",
407
+ Value: 100,
408
+ }),
409
+ ]),
410
+ },
411
+ })
412
+ );
413
+ * @param pattern
414
+ * @returns
415
+ */
416
+ static objectEquals(pattern) {
417
+ return assertions_1.Match.objectEquals(pattern);
418
+ }
419
+ /**
420
+ * Same method as `Match.not` but provides type hints and validate type match
421
+ ```js
422
+ // this is a right code
423
+ template.hasResource(
424
+ AWS_EC2_INSTANCE({
425
+ Properties: {
426
+ ImageId: ExtraMatch.not("ami-12345"),
427
+ },
428
+ })
429
+ );
430
+ // this is a wrong code(type mismatch will be detected and ts-error will be raised)
431
+ template.hasResource(
432
+ AWS_EC2_INSTANCE({
433
+ Properties: {
434
+ ImageId: ExtraMatch.not(100),
435
+ },
436
+ })
437
+ );
438
+ ```
439
+ * Same method as `Match.not` but provides type hints and validate type match
440
+ * @param pattern
441
+ * @returns
442
+ */
443
+ // TODO: why this expression `T extends never ? never : T` is required but this is required
444
+ static not(pattern) {
445
+ return assertions_1.Match.not(pattern);
446
+ }
447
+ /**
448
+ * Same method as `Match.exact` but provides type hints and validate type match
449
+ ```js
450
+ // this is a right code
451
+ template.hasResource(
452
+ AWS_EC2_INSTANCE({
453
+ Properties: {
454
+ InstanceType: ExtraMatch.exact("t2.micro"),
455
+ },
456
+ })
457
+ );
458
+ // this is a wrong code(type mismatch will be detected and ts-error will be raised)
459
+ template.hasResource(
460
+ AWS_EC2_INSTANCE({
461
+ Properties: {
462
+ InstanceType: ExtraMatch.exact(false),
463
+ },
464
+ })
465
+ );
466
+ ```
467
+ * @param pattern
468
+ * @returns
469
+ */
470
+ static exact(pattern) {
471
+ return assertions_1.Match.exact(pattern);
472
+ }
311
473
  }
312
474
  exports.ExtraMatch = ExtraMatch;
313
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"assertions.js","sourceRoot":"","sources":["assertions.ts"],"names":[],"mappings":"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","sourcesContent":["import { Template, Match, Matcher } from \"aws-cdk-lib/assertions\";\nimport {\n  Condition,\n  InputResource,\n  Mapping,\n  OutputResource,\n  InputParamter,\n  OutputParameter,\n  ReturnValue,\n  InputOutput,\n  OutputOutput,\n  InputResourceWithoutType,\n  IAMPolicyDocument,\n  AlsoMatcher,\n  TypedMatcher,\n} from \"./typed-resource\";\n\n/**\n * almost same class as `Template` class at \"aws-cdk-lib/assertions\", but you can use this with proper type definitions\n */\nexport class TypedTemplate {\n  template: Template;\n  private constructor(template: Template) {\n    this.template = template;\n  }\n\n  private get<T>(type: string, def: any, array: T[]): T {\n    if (array.length === 0) {\n      throw Error(`${type} not found with definition : ${JSON.stringify(def)}`);\n    }\n    if (array.length > 1) {\n      throw Error(\n        `multiple ${type} found with definition : ${JSON.stringify(def)}`\n      );\n    }\n    return array[0];\n  }\n\n  /**\n   * same function as `Template.fromStack` but returns `TypedTemplate`\n   * @param args\n   * @returns\n   */\n  static fromStack(\n    ...args: Parameters<typeof Template.fromStack>\n  ): TypedTemplate {\n    return new TypedTemplate(Template.fromStack(...args));\n  }\n  /**\n   * same function as `Template.fromJSON` but returns `TypedTemplate`\n   * @param args\n   * @returns\n   */\n  static fromJSON(\n    ...args: Parameters<typeof Template.fromJSON>\n  ): TypedTemplate {\n    return new TypedTemplate(Template.fromJSON(...args));\n  }\n  /**\n   * same function as `Template.fromString` but returns `TypedTemplate`\n   * @param args\n   * @returns\n   */\n  static fromString(\n    ...args: Parameters<typeof Template.fromString>\n  ): TypedTemplate {\n    return new TypedTemplate(Template.fromString(...args));\n  }\n\n  /**\n   * same function as `Template.resourceCountIs`\n   *\n   * use this method like below:\n   *\n   * ```js\n   * template.resourceCountIs(AWS_EC2_SUBNET, 3)\n   * ```\n   * @param type\n   * @param count\n   */\n  resourceCountIs<T>(\n    type: (resource?: InputResourceWithoutType<T>) => InputResource<T>,\n    count: number\n  ): void {\n    this.template.resourceCountIs(type().Type, count);\n  }\n  /**\n   * same function as `Template.resourcePropertiesCountIs`\n   * @param r\n   * @param count\n   */\n  resourcePropertiesCountIs<T>(r: InputResource<T>, count: number): void {\n    this.template.resourcePropertiesCountIs(r.Type, r.Properties, count);\n  }\n  /**\n   * same function as `Template.hasResourceProperties`\n   * @param r\n   */\n  hasResourceProperties<T>(r: InputResource<T>): void {\n    this.template.hasResourceProperties(r.Type, r.Properties);\n  }\n  /**\n   * same function as `Template.hasResource`\n   * @param r\n   */\n  hasResource<T>(r: InputResource<T>): void {\n    this.template.hasResource(r.Type, r);\n  }\n  /**\n   * same function as `Template.findResources`\n   * @param r\n   * @returns\n   */\n  findResources<T>(r: InputResource<T>): ReturnValue<OutputResource<T>>[] {\n    const resources = this.template.findResources(r.Type, r) as {\n      [id in string]: OutputResource<T>;\n    };\n    return Object.entries(resources).map(([id, resource]) => {\n      return { id: id, def: resource };\n    });\n  }\n  /**\n   * same function as `Template.allResources`\n   * @param r\n   */\n  allResources<T>(r: InputResource<T>): void {\n    this.template.allResources(r.Type, r);\n  }\n  /**\n   * same function as `Template.allResourceProperties`\n   * @param r\n   */\n  allResourcesProperties<T>(r: InputResource<T>): void {\n    this.template.allResourcesProperties(r.Type, r.Properties);\n  }\n  /**\n   * same function as `Template.hasParameter`\n   * @param logicalId\n   * @param props\n   */\n  hasParameter(logicalId: string, props: InputParamter): void {\n    this.template.hasParameter(logicalId, props);\n  }\n  /**\n   * same function as `Template.findParameters`\n   * @param logicalId\n   * @param props\n   * @returns\n   */\n  findParameters(\n    logicalId: string,\n    props?: InputParamter\n  ): ReturnValue<OutputParameter>[] {\n    const parameters = this.template.findParameters(logicalId, props);\n    return Object.entries(parameters).map(([id, parameter]) => {\n      return { id: id, def: parameter as OutputParameter };\n    });\n  }\n\n  /**\n   * same function as `Template.hasOutput`\n   * @param logicalId\n   * @param props\n   */\n  hasOutput(logicalId: string, props: InputOutput): void {\n    this.template.hasOutput(logicalId, props);\n  }\n  /**\n   * same function as `Template.findOutputs`\n   * @param logicalId\n   * @param props\n   * @returns\n   */\n  findOutputs(\n    logicalId: string,\n    props?: InputOutput\n  ): ReturnValue<OutputOutput>[] {\n    const outputs = this.template.findOutputs(logicalId, props);\n    return Object.entries(outputs).map(([id, output]) => {\n      return { id: id, def: output as OutputOutput };\n    });\n  }\n  /**\n   * same function as `Template.hasMapping`\n   * @param logicalId\n   * @param props\n   */\n  hasMapping(logicalId: string, props: any): void {\n    this.template.hasMapping(logicalId, props);\n  }\n  /**\n   * same function as `Template.findMappings`\n   * @param logicalId\n   * @param props\n   * @returns\n   */\n  findMappings(logicalId: string, props?: any): ReturnValue<Mapping>[] {\n    const mappings = this.template.findMappings(logicalId, props);\n    return Object.entries(mappings).map(([id, mapping]) => {\n      return { id: id, def: mapping };\n    });\n  }\n  /**\n   * same function as `Template.hasCondition`\n   * @param logicalId\n   * @param props\n   */\n  hasCondition(logicalId: string, props: any): void {\n    this.template.hasCondition(logicalId, props);\n  }\n  /**\n   * same function as `Template.findConditions`\n   * @param logicalId\n   * @param props\n   * @returns\n   */\n  findConditions(logicalId: string, props?: any): ReturnValue<Condition>[] {\n    const conditions = this.template.findConditions(logicalId, props);\n    return Object.entries(conditions).map(([id, condition]) => {\n      return { id: id, def: condition };\n    });\n  }\n\n  /**\n   * return a single resource for specified type and definition.\n   *\n   * - if no resource matched with the specified type and definition, raise Error.\n   * - if multiple resources matched, raise Error\n   * @param args\n   * @returns\n   */\n  getResource<T>(\n    ...args: Parameters<typeof this.findResources<T>>\n  ): ReturnType<typeof this.findResources<T>> extends (infer U)[] ? U : never {\n    return this.get(\"resource\", args[0], this.findResources(args[0]));\n  }\n}\n\nexport interface JoinProps {\n  /**\n   * @default \"\"\n   */\n  delimiter?: string;\n  arrayWith: any[];\n}\n/**\n * provides some syntax sugars for `Match` class at `aws-cdk-lib/assertions`\n */\nexport class ExtraMatch extends Match {\n  /**\n   * same function as `Match.objectEquals({ Ref: logicalId })`\n   * @param logicalId\n   * @returns\n   */\n  static ref(logicalId: string): Matcher {\n    return Match.objectEquals({ Ref: logicalId });\n  }\n  /**\n   * same function as `Match.objectEquals({\"Fn::GetAtt\": [logicalId, attribute]})`\n   * @param logicalId\n   * @param attribute\n   * @returns\n   */\n  static getAtt(logicalId: string, attribute: string): Matcher {\n    return Match.objectEquals({ \"Fn::GetAtt\": [logicalId, attribute] });\n  }\n  /**\n   * same function as `Match.objectEquals({\"Fn::GetAtt\": [logicalId, \"Arn\"]})`\n   * @param logicalId\n   * @returns\n   */\n  static getAttArn(logicalId: string): Matcher {\n    return this.getAtt(logicalId, \"Arn\");\n  }\n\n  static arrayWith<T extends any[]>(pattern: AlsoMatcher<T>): TypedMatcher<T> {\n    return Match.arrayWith(pattern);\n  }\n  static arrayEquals<T extends any[]>(\n    pattern: AlsoMatcher<T>\n  ): TypedMatcher<T> {\n    return Match.arrayEquals(pattern);\n  }\n  static objectLike<T extends { [key: string]: any }>(\n    pattern: AlsoMatcher<T>\n  ): TypedMatcher<T> {\n    return Match.objectLike(pattern) as TypedMatcher<T>;\n  }\n  static objectEquals<T extends { [key: string]: any }>(\n    pattern: AlsoMatcher<T>\n  ): TypedMatcher<T> {\n    return Match.objectEquals(pattern);\n  }\n  static not<T>(pattern: AlsoMatcher<T>): TypedMatcher<T> {\n    return Match.not(pattern);\n  }\n  static exact<T>(pattern: AlsoMatcher<T>): TypedMatcher<T> {\n    return Match.exact(pattern);\n  }\n\n  /**\n   * same function as below:\n   * \n   * ```js\n   * Match.objectLike({\n   *  \"Fn::Join\": [props.delimiter ?? \"\", Match.arrayWith(props.arrayWith)],\n    });\n   * ```\n   * @param props \n   * @returns \n   */\n  static joinLike(props: JoinProps): Matcher {\n    return Match.objectLike({\n      \"Fn::Join\": [props.delimiter ?? \"\", Match.arrayWith(props.arrayWith)],\n    });\n  }\n\n  // /**\n  //  * returns Match instance that matches regional resource ARN like : `arn:aws:logs:ap-northeast-1:123456789012:log-group:/log-group-name:log-stream:log-stream-name`\n  //  * @param elems\n  //  * @returns\n  //  */\n  // static regionalArnLike(elems: AlsoMatcher<ArnElements>): Matcher {\n  //   return Match.objectEquals({\n  //     \"Fn::Join\": Match.arrayWith([\n  //       \"\",\n  //       Match.arrayWith([\n  //         \"arn:\",\n  //         elems.partition ?? { Ref: \"AWS::Partition\" },\n  //         Match.stringLikeRegexp(`:${elems.service ?? \"*\"}:`),\n  //         elems.region ?? { Ref: \"AWS::Region\" },\n  //         elems.account ?? { Ref: \"AWS::AccountId\" },\n  //         ...(elems.rest instanceof Matcher\n  //           ? [elems.rest]\n  //           : (elems.rest ?? [])),\n  //       ]),\n  //     ]),\n  //   });\n  // }\n\n  // /**\n  //  * returns Match instance that matches global resource ARN like : `arn:aws:iam::123456789012:role/role-name`\n  //  * @param elems\n  //  * @returns\n  //  */\n  // static globalArn(\n  //   elems: Omit<ArnElements, \"region\">,\n  //   delimiter: string = \"\"\n  // ): Matcher {\n  //   return Match.objectEquals({\n  //     \"Fn::Join\": Match.arrayEquals([\n  //       delimiter,\n  //       Match.arrayWith([\n  //         \"arn:\",\n  //         elems.partition ?? { Ref: \"AWS::Partition\" },\n  //         Match.stringLikeRegexp(`:${elems.service ?? \"*\"}::`),\n  //         elems.account ?? { Ref: \"AWS::AccountId\" },\n  //         ...(elems.rest instanceof Matcher\n  //           ? [elems.rest]\n  //           : (elems.rest ?? [])),\n  //       ]),\n  //     ]),\n  //   });\n  // }\n\n  static iamPolicyLike(doc: AlsoMatcher<IAMPolicyDocument>): Matcher {\n    return Match.objectLike(doc);\n  }\n}\n"]}
475
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"assertions.js","sourceRoot":"","sources":["assertions.ts"],"names":[],"mappings":"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","sourcesContent":["import { Template, Match, Matcher } from \"aws-cdk-lib/assertions\";\nimport {\n  Condition,\n  InputResource,\n  Mapping,\n  OutputResource,\n  InputParamter,\n  OutputParameter,\n  ReturnValue,\n  InputOutput,\n  OutputOutput,\n  InputResourceWithoutType,\n  IAMPolicyDocument,\n  AlsoMatcher,\n  TypedMatcher,\n} from \"./typed-resource\";\n\n/**\n * almost same class as `Template` class at \"aws-cdk-lib/assertions\", but you can use this with proper type definitions\n */\nexport class TypedTemplate {\n  template: Template;\n  private constructor(template: Template) {\n    this.template = template;\n  }\n\n  private get<T>(type: string, def: any, array: T[]): T {\n    if (array.length === 0) {\n      throw Error(`${type} not found with definition : ${JSON.stringify(def)}`);\n    }\n    if (array.length > 1) {\n      throw Error(\n        `multiple ${type} found with definition : ${JSON.stringify(def)}`\n      );\n    }\n    return array[0];\n  }\n\n  /**\n   * same function as `Template.fromStack` but returns `TypedTemplate`\n   * @param args\n   * @returns\n   */\n  static fromStack(\n    ...args: Parameters<typeof Template.fromStack>\n  ): TypedTemplate {\n    return new TypedTemplate(Template.fromStack(...args));\n  }\n  /**\n   * same function as `Template.fromJSON` but returns `TypedTemplate`\n   * @param args\n   * @returns\n   */\n  static fromJSON(\n    ...args: Parameters<typeof Template.fromJSON>\n  ): TypedTemplate {\n    return new TypedTemplate(Template.fromJSON(...args));\n  }\n  /**\n   * same function as `Template.fromString` but returns `TypedTemplate`\n   * @param args\n   * @returns\n   */\n  static fromString(\n    ...args: Parameters<typeof Template.fromString>\n  ): TypedTemplate {\n    return new TypedTemplate(Template.fromString(...args));\n  }\n\n  /**\n   * same function as `Template.resourceCountIs`\n   *\n   * use this method like below:\n   *\n   * ```js\n   * template.resourceCountIs(AWS_EC2_SUBNET, 3)\n   * ```\n   * @param type\n   * @param count\n   */\n  resourceCountIs<T>(\n    type: (resource?: InputResourceWithoutType<T>) => InputResource<T>,\n    count: number\n  ): void {\n    this.template.resourceCountIs(type().Type, count);\n  }\n  /**\n   * same function as `Template.resourcePropertiesCountIs`\n   * @param r\n   * @param count\n   */\n  resourcePropertiesCountIs<T>(r: InputResource<T>, count: number): void {\n    this.template.resourcePropertiesCountIs(r.Type, r.Properties, count);\n  }\n  /**\n   * same function as `Template.hasResourceProperties`\n   * @param r\n   */\n  hasResourceProperties<T>(r: InputResource<T>): void {\n    this.template.hasResourceProperties(r.Type, r.Properties);\n  }\n  /**\n   * same function as `Template.hasResource`\n   * @param r\n   */\n  hasResource<T>(r: InputResource<T>): void {\n    this.template.hasResource(r.Type, r);\n  }\n  /**\n   * same function as `Template.findResources`\n   * @param r\n   * @returns\n   */\n  findResources<T>(r: InputResource<T>): ReturnValue<OutputResource<T>>[] {\n    const resources = this.template.findResources(r.Type, r) as {\n      [id in string]: OutputResource<T>;\n    };\n    return Object.entries(resources).map(([id, resource]) => {\n      return { id: id, def: resource };\n    });\n  }\n  /**\n   * same function as `Template.allResources`\n   * @param r\n   */\n  allResources<T>(r: InputResource<T>): void {\n    this.template.allResources(r.Type, r);\n  }\n  /**\n   * same function as `Template.allResourceProperties`\n   * @param r\n   */\n  allResourcesProperties<T>(r: InputResource<T>): void {\n    this.template.allResourcesProperties(r.Type, r.Properties);\n  }\n  /**\n   * same function as `Template.hasParameter`\n   * @param logicalId\n   * @param props\n   */\n  hasParameter(logicalId: string, props: InputParamter): void {\n    this.template.hasParameter(logicalId, props);\n  }\n  /**\n   * same function as `Template.findParameters`\n   * @param logicalId\n   * @param props\n   * @returns\n   */\n  findParameters(\n    logicalId: string,\n    props?: InputParamter\n  ): ReturnValue<OutputParameter>[] {\n    const parameters = this.template.findParameters(logicalId, props);\n    return Object.entries(parameters).map(([id, parameter]) => {\n      return { id: id, def: parameter as OutputParameter };\n    });\n  }\n\n  /**\n   * same function as `Template.hasOutput`\n   * @param logicalId\n   * @param props\n   */\n  hasOutput(logicalId: string, props: InputOutput): void {\n    this.template.hasOutput(logicalId, props);\n  }\n  /**\n   * same function as `Template.findOutputs`\n   * @param logicalId\n   * @param props\n   * @returns\n   */\n  findOutputs(\n    logicalId: string,\n    props?: InputOutput\n  ): ReturnValue<OutputOutput>[] {\n    const outputs = this.template.findOutputs(logicalId, props);\n    return Object.entries(outputs).map(([id, output]) => {\n      return { id: id, def: output as OutputOutput };\n    });\n  }\n  /**\n   * same function as `Template.hasMapping`\n   * @param logicalId\n   * @param props\n   */\n  hasMapping(logicalId: string, props: any): void {\n    this.template.hasMapping(logicalId, props);\n  }\n  /**\n   * same function as `Template.findMappings`\n   * @param logicalId\n   * @param props\n   * @returns\n   */\n  findMappings(logicalId: string, props?: any): ReturnValue<Mapping>[] {\n    const mappings = this.template.findMappings(logicalId, props);\n    return Object.entries(mappings).map(([id, mapping]) => {\n      return { id: id, def: mapping };\n    });\n  }\n  /**\n   * same function as `Template.hasCondition`\n   * @param logicalId\n   * @param props\n   */\n  hasCondition(logicalId: string, props: any): void {\n    this.template.hasCondition(logicalId, props);\n  }\n  /**\n   * same function as `Template.findConditions`\n   * @param logicalId\n   * @param props\n   * @returns\n   */\n  findConditions(logicalId: string, props?: any): ReturnValue<Condition>[] {\n    const conditions = this.template.findConditions(logicalId, props);\n    return Object.entries(conditions).map(([id, condition]) => {\n      return { id: id, def: condition };\n    });\n  }\n\n  /**\n   * return a single resource for specified type and definition.\n   *\n   * - if no resource matched with the specified type and definition, raise Error.\n   * - if multiple resources matched, raise Error\n   * @param args\n   * @returns\n   */\n  getResource<T>(\n    ...args: Parameters<typeof this.findResources<T>>\n  ): ReturnType<typeof this.findResources<T>> extends (infer U)[] ? U : never {\n    return this.get(\"resource\", args[0], this.findResources(args[0]));\n  }\n}\n\nexport interface JoinProps {\n  /**\n   * @default \"\"\n   */\n  delimiter?: string;\n  arrayWith: any[];\n}\n/**\n * provides some syntax sugars for `Match` class at `aws-cdk-lib/assertions`\n */\nexport class ExtraMatch {\n  /**\n   * same function as `Match.objectEquals({ Ref: logicalId })`\n   * @param logicalId\n   * @returns\n   */\n  static ref(logicalId: string): Matcher {\n    return Match.objectEquals({ Ref: logicalId });\n  }\n  /**\n   * same function as `Match.objectEquals({\"Fn::GetAtt\": [logicalId, attribute]})`\n   * @param logicalId\n   * @param attribute\n   * @returns\n   */\n  static getAtt(logicalId: string, attribute: string): Matcher {\n    return Match.objectEquals({ \"Fn::GetAtt\": [logicalId, attribute] });\n  }\n  /**\n   * same function as `Match.objectEquals({\"Fn::GetAtt\": [logicalId, \"Arn\"]})`\n   * @param logicalId\n   * @returns\n   */\n  static getAttArn(logicalId: string): Matcher {\n    return this.getAtt(logicalId, \"Arn\");\n  }\n  /**\n   * same function as below:\n   * \n   * ```js\n   * Match.objectLike({\n   *  \"Fn::Join\": [props.delimiter ?? \"\", Match.arrayWith(props.arrayWith)],\n    });\n   * ```\n   * @param props \n   * @returns \n   */\n  static joinLike(props: JoinProps): Matcher {\n    return Match.objectLike({\n      \"Fn::Join\": [props.delimiter ?? \"\", Match.arrayWith(props.arrayWith)],\n    });\n  }\n\n  /**\n   You can define Matcher for IAM Policy Document with type hints.\n   ```js\n    template.hasResource(\n      AWS_IAM_ROLE({\n        Properties: {\n          AssumeRolePolicyDocument: ExtraMatch.iamPolicyLike({\n            Statement: [\n              {\n                Principal: { Service: \"ec2.amazonaws.com\" },\n              },\n            ],\n          }),\n        },\n      })\n    );\n   ```\n   * @param doc \n   * @returns \n   */\n  static iamPolicyLike(doc: AlsoMatcher<IAMPolicyDocument>): Matcher {\n    return Match.objectLike(doc);\n  }\n  /**\n   Same method as `Match.arrayWith` but provides type hints and validate type match \n   ```js\n    // this is a right code\n    template.hasResource(\n      AWS_EC2_EIP({\n        Properties: {\n          Tags: ExtraMatch.arrayWith<Tag[]>([\n            {\n              Key: \"key2\",\n              Value: \"val2\",\n            },\n          ]),\n        },\n      })\n    );\n    // this is a wrong code(type mismatch will be detected and ts-error will be raised)\n    template.hasResource(\n      AWS_EC2_EIP({\n        Properties: {\n          Tags: ExtraMatch.arrayWith<string[]>([\n            \"hoge\", \"fuga\"\n          ]),\n        },\n      })\n    );\n   ```\n   * @param pattern \n   * @returns \n   */\n  static arrayWith<T extends any[]>(pattern: AlsoMatcher<T>): TypedMatcher<T> {\n    return Match.arrayWith(pattern) as unknown as TypedMatcher<T>;\n  }\n  /**\n   * Same method as `Match.arrayEquals` but provides type hints and validate type match \n   ```js\n    // this is a right code\n    template.hasResource(\n      AWS_EC2_EIP({\n        Properties: {\n          Tags: ExtraMatch.arrayEquals<Tag[]>([\n            {\n              Key: \"key1\",\n              Value: \"val1\",\n            },\n            {\n              Key: \"key2\",\n              Value: \"val2\",\n            },\n          ]),\n        },\n      })\n    );\n    // this is a wrong code(type mismatch will be detected and ts-error will be raised)\n    template.hasResource(\n      AWS_EC2_EIP({\n        Properties: {\n          Tags: ExtraMatch.arrayEquals<Tag[]>([\n            {\n              Key: \"key1\",\n              Value: \"val1\",\n            },\n            {\n              Key: 100,\n              Value: 200,\n            },\n          ]),\n        },\n      })\n    );\n   ```\n   * @param pattern \n   * @returns \n   */\n  static arrayEquals<T extends any[]>(\n    pattern: AlsoMatcher<T>\n  ): TypedMatcher<T> {\n    return Match.arrayEquals(pattern);\n  }\n  /**\n   * Same method as `Match.objectLike` but provides type hints and validate type match \n   ```js\n   // this is a right code\n    template.hasResource(\n      AWS_EC2_INSTANCE({\n        Properties: {\n          BlockDeviceMappings: [\n            {\n              DeviceName: \"test\",\n              Ebs: ExtraMatch.objectLike<Ebs>({\n                VolumeSize: 10,\n              }),\n            },\n          ],\n        },\n      })\n    );\n    // this is a wrong code(type mismatch will be detected and ts-error will be raised)\n    template.hasResource(\n      AWS_EC2_INSTANCE({\n        Properties: {\n          BlockDeviceMappings: [\n            {\n              DeviceName: \"test\",\n              Ebs: ExtraMatch.objectLike<Ebs>({\n                VolumeSize: \"10\",\n              }),\n            },\n          ],\n        },\n      })\n    );\n   * @param pattern \n   * @returns \n   */\n  static objectLike<T extends { [key: string]: any }>(\n    pattern: AlsoMatcher<T>\n  ): TypedMatcher<T> {\n    return Match.objectLike(pattern);\n  }\n  /**\n   * Same method as `Match.objectEquals` but provides type hints and validate type match \n   ```js\n   // this is a right code\n    template.hasResource(\n      AWS_EC2_EIP({\n        Properties: {\n          // You can nest TypedMatcher(use TypedMatcher inside TypedMatcher)\n          Tags: ExtraMatch.arrayWith<Tag[]>([\n            ExtraMatch.objectEquals<Tag>({\n              Key: \"key1\",\n              Value: \"val1\",\n            }),\n          ]),\n        },\n      })\n    );\n    // this is a wrong code(type mismatch will be detected and ts-error will be raised)\n    template.hasResource(\n      AWS_EC2_EIP({\n        Properties: {\n          Tags: ExtraMatch.arrayWith<Tag[]>([\n            ExtraMatch.objectEquals<Tag>({\n              Key: \"key1\",\n              Value: 100,\n            }),\n          ]),\n        },\n      })\n    );\n   * @param pattern \n   * @returns \n   */\n  static objectEquals<T extends { [key: string]: any }>(\n    pattern: AlsoMatcher<T>\n  ): TypedMatcher<T> {\n    return Match.objectEquals(pattern);\n  }\n  /**\n   * Same method as `Match.not` but provides type hints and validate type match \n   ```js\n    // this is a right code\n    template.hasResource(\n      AWS_EC2_INSTANCE({\n        Properties: {\n          ImageId: ExtraMatch.not(\"ami-12345\"),\n        },\n      })\n    );\n    // this is a wrong code(type mismatch will be detected and ts-error will be raised)\n    template.hasResource(\n      AWS_EC2_INSTANCE({\n        Properties: {\n          ImageId: ExtraMatch.not(100),\n        },\n      })\n    );\n   ```\n   * Same method as `Match.not` but provides type hints and validate type match \n   * @param pattern \n   * @returns \n   */\n  // TODO: why this expression `T extends never ? never : T` is required but this is required\n  static not<T>(pattern: AlsoMatcher<T extends never ? never : T>): TypedMatcher<T> {\n    return Match.not(pattern);\n  }\n  /**\n   * Same method as `Match.exact` but provides type hints and validate type match \n   ```js\n    // this is a right code\n    template.hasResource(\n      AWS_EC2_INSTANCE({\n        Properties: {\n          InstanceType: ExtraMatch.exact(\"t2.micro\"),\n        },\n      })\n    );\n    // this is a wrong code(type mismatch will be detected and ts-error will be raised)\n    template.hasResource(\n      AWS_EC2_INSTANCE({\n        Properties: {\n          InstanceType: ExtraMatch.exact(false),\n        },\n      })\n    );\n   ```\n   * @param pattern \n   * @returns \n   */\n  static exact<T>(pattern: AlsoMatcher<T extends never ? never : T>): TypedMatcher<T> {\n    return Match.exact(pattern);\n  }\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import { Matcher } from "aws-cdk-lib/assertions";
2
2
  type Primitives = string | number | boolean | undefined | null | symbol | bigint | string[] | number[] | boolean[] | bigint[];
3
- export type TypedMatcher<T> = Matcher;
3
+ export type TypedMatcher<T> = Matcher | T;
4
4
  /**
5
5
  * make properties of `T` asignable Matcher recirsively and other arbitrary json objects for primitive type fields
6
6
  */