@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.
- package/lib/assertions.d.ts +219 -12
- package/lib/assertions.js +228 -66
- package/lib/typed-resource.d.ts +1 -1
- package/lib/typed-resource.js +1 -1
- package/lib/types/cfn-resource-types/aws-accessanalyzer-analyzer.d.ts +33 -1
- package/lib/types/cfn-resource-types/aws-accessanalyzer-analyzer.js +1 -1
- package/lib/types/cfn-resource-types/aws-connect-evaluationform.d.ts +113 -103
- package/lib/types/cfn-resource-types/aws-connect-evaluationform.js +1 -1
- package/lib/types/cfn-resource-types/aws-customerprofiles-segmentdefinition.d.ts +20 -0
- package/lib/types/cfn-resource-types/aws-customerprofiles-segmentdefinition.js +1 -1
- package/lib/types/cfn-resource-types/aws-datazone-projectprofile.d.ts +28 -0
- package/lib/types/cfn-resource-types/aws-datazone-projectprofile.js +1 -1
- package/package.json +1 -1
package/lib/assertions.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Template,
|
|
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
|
|
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
|
|
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
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
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"]}
|
package/lib/typed-resource.d.ts
CHANGED
|
@@ -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
|
*/
|