@aws-cdk-testing/cli-integ 3.1.0 → 3.1.2
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/NOTICE +1 -1
- package/lib/aws.d.ts +8 -2
- package/lib/aws.js +22 -8
- package/lib/aws.ts +28 -10
- package/lib/cli/run-suite.js +2 -1
- package/lib/cli/run-suite.ts +1 -1
- package/lib/cli/stage-distribution.js +1 -1
- package/lib/cli/stage-distribution.ts +0 -5
- package/lib/github.js +1 -2
- package/lib/github.ts +1 -1
- package/lib/integ-test.d.ts +1 -0
- package/lib/integ-test.js +3 -2
- package/lib/integ-test.ts +4 -1
- package/lib/package-sources/release-source.js +1 -1
- package/lib/package-sources/release-source.ts +2 -1
- package/lib/package-sources/repo-source.d.ts +4 -4
- package/lib/package-sources/repo-source.js +5 -5
- package/lib/package-sources/repo-source.ts +6 -5
- package/lib/proxy.d.ts +13 -0
- package/lib/proxy.js +49 -0
- package/lib/proxy.ts +64 -0
- package/lib/with-aws.d.ts +3 -0
- package/lib/with-aws.js +54 -6
- package/lib/with-aws.ts +52 -5
- package/lib/with-cdk-app.d.ts +21 -2
- package/lib/with-cdk-app.js +73 -73
- package/lib/with-cdk-app.ts +96 -95
- package/lib/with-cli-lib.d.ts +2 -2
- package/lib/with-cli-lib.js +12 -2
- package/lib/with-cli-lib.ts +18 -4
- package/lib/with-sam.js +2 -1
- package/lib/with-sam.ts +1 -0
- package/package.json +6 -5
- package/resources/cdk-apps/sam_cdk_integ_app/src/docker/DockerImageFunctionConstruct/Dockerfile +2 -0
- package/resources/integ.jest.config.js +4 -1
- package/tests/cli-integ-tests/bootstrapping.integtest.js +20 -1
- package/tests/cli-integ-tests/bootstrapping.integtest.ts +25 -1
- package/tests/cli-integ-tests/cli.integtest.js +70 -38
- package/tests/cli-integ-tests/cli.integtest.ts +79 -51
- package/tests/cli-integ-tests/proxy.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/proxy.integtest.js +147 -0
- package/tests/cli-integ-tests/proxy.integtest.ts +167 -0
- package/tests/init-javascript/init-javascript.integtest.js +1 -1
- package/tests/init-javascript/init-javascript.integtest.ts +0 -1
- package/tests/init-typescript-app/init-typescript-app.integtest.js +2 -2
- package/tests/init-typescript-app/init-typescript-app.integtest.ts +1 -1
- package/tests/uberpackage/uberpackage.integtest.js +2 -2
- package/tests/uberpackage/uberpackage.integtest.ts +2 -2
package/lib/with-cdk-app.ts
CHANGED
|
@@ -11,7 +11,7 @@ import { IPackageSource } from './package-sources/source';
|
|
|
11
11
|
import { packageSourceInSubprocess } from './package-sources/subprocess';
|
|
12
12
|
import { RESOURCES_DIR } from './resources';
|
|
13
13
|
import { shell, ShellOptions, ShellHelper, rimraf } from './shell';
|
|
14
|
-
import { AwsContext, withAws } from './with-aws';
|
|
14
|
+
import { AwsContext, atmosphereEnabled, withAws } from './with-aws';
|
|
15
15
|
import { withTimeout } from './with-timeout';
|
|
16
16
|
|
|
17
17
|
export const DEFAULT_TEST_TIMEOUT_S = 20 * 60;
|
|
@@ -99,31 +99,35 @@ export function withCdkApp(
|
|
|
99
99
|
return withSpecificCdkApp('app', block);
|
|
100
100
|
}
|
|
101
101
|
|
|
102
|
-
export function withCdkMigrateApp
|
|
103
|
-
|
|
102
|
+
export function withCdkMigrateApp(
|
|
103
|
+
language: string,
|
|
104
|
+
block: (context: TestFixture) => Promise<void>,
|
|
105
|
+
): (context: TestContext & AwsContext & DisableBootstrapContext) => Promise<void> {
|
|
106
|
+
return async (context: TestContext & AwsContext & DisableBootstrapContext) => {
|
|
104
107
|
const stackName = `cdk-migrate-${language}-integ-${context.randomString}`;
|
|
105
108
|
const integTestDir = path.join(os.tmpdir(), `cdk-migrate-${language}-integ-${context.randomString}`);
|
|
106
109
|
|
|
107
110
|
context.output.write(` Stack name: ${stackName}\n`);
|
|
108
111
|
context.output.write(` Test directory: ${integTestDir}\n`);
|
|
109
112
|
|
|
110
|
-
const awsClients = await AwsClients.default(context.output);
|
|
111
113
|
fs.mkdirSync(integTestDir);
|
|
112
114
|
const fixture = new TestFixture(
|
|
113
115
|
integTestDir,
|
|
114
116
|
stackName,
|
|
115
117
|
context.output,
|
|
116
|
-
|
|
118
|
+
context.aws,
|
|
117
119
|
context.randomString,
|
|
118
120
|
);
|
|
119
121
|
|
|
122
|
+
await ensureBootstrapped(fixture);
|
|
123
|
+
|
|
120
124
|
await fixture.cdkMigrate(language, stackName);
|
|
121
125
|
|
|
122
126
|
const testFixture = new TestFixture(
|
|
123
127
|
path.join(integTestDir, stackName),
|
|
124
128
|
stackName,
|
|
125
129
|
context.output,
|
|
126
|
-
|
|
130
|
+
context.aws,
|
|
127
131
|
context.randomString,
|
|
128
132
|
);
|
|
129
133
|
|
|
@@ -143,50 +147,6 @@ export function withCdkMigrateApp<A extends TestContext>(language: string, block
|
|
|
143
147
|
};
|
|
144
148
|
}
|
|
145
149
|
|
|
146
|
-
export function withMonolithicCfnIncludeCdkApp<A extends TestContext>(block: (context: TestFixture) => Promise<void>) {
|
|
147
|
-
return async (context: A) => {
|
|
148
|
-
const uberPackage = process.env.UBERPACKAGE;
|
|
149
|
-
if (!uberPackage) {
|
|
150
|
-
throw new Error('The UBERPACKAGE environment variable is required for running this test!');
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
const randy = context.randomString;
|
|
154
|
-
const stackNamePrefix = `cdk-uber-cfn-include-${randy}`;
|
|
155
|
-
const integTestDir = path.join(os.tmpdir(), `cdk-uber-cfn-include-${randy}`);
|
|
156
|
-
|
|
157
|
-
context.output.write(` Stack prefix: ${stackNamePrefix}\n`);
|
|
158
|
-
context.output.write(` Test directory: ${integTestDir}\n`);
|
|
159
|
-
|
|
160
|
-
const awsClients = await AwsClients.default(context.output);
|
|
161
|
-
await cloneDirectory(path.join(RESOURCES_DIR, 'cdk-apps', 'cfn-include-app'), integTestDir, context.output);
|
|
162
|
-
const fixture = new TestFixture(
|
|
163
|
-
integTestDir,
|
|
164
|
-
stackNamePrefix,
|
|
165
|
-
context.output,
|
|
166
|
-
awsClients,
|
|
167
|
-
context.randomString,
|
|
168
|
-
);
|
|
169
|
-
|
|
170
|
-
let success = true;
|
|
171
|
-
try {
|
|
172
|
-
await installNpmPackages(fixture, {
|
|
173
|
-
[uberPackage]: fixture.packages.requestedFrameworkVersion(),
|
|
174
|
-
});
|
|
175
|
-
|
|
176
|
-
await block(fixture);
|
|
177
|
-
} catch (e) {
|
|
178
|
-
success = false;
|
|
179
|
-
throw e;
|
|
180
|
-
} finally {
|
|
181
|
-
if (process.env.INTEG_NO_CLEAN) {
|
|
182
|
-
context.log(`Left test directory in '${integTestDir}' ($INTEG_NO_CLEAN)`);
|
|
183
|
-
} else {
|
|
184
|
-
await fixture.dispose(success);
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
};
|
|
188
|
-
}
|
|
189
|
-
|
|
190
150
|
/**
|
|
191
151
|
* Default test fixture for most (all?) integ tests
|
|
192
152
|
*
|
|
@@ -330,6 +290,10 @@ export interface CdkModernBootstrapCommandOptions extends CommonCdkBootstrapComm
|
|
|
330
290
|
* @default undefined
|
|
331
291
|
*/
|
|
332
292
|
readonly usePreviousParameters?: boolean;
|
|
293
|
+
|
|
294
|
+
readonly trust?: string[];
|
|
295
|
+
|
|
296
|
+
readonly untrust?: string[];
|
|
333
297
|
}
|
|
334
298
|
|
|
335
299
|
export interface CdkGarbageCollectionCommandOptions {
|
|
@@ -357,7 +321,7 @@ export interface CdkGarbageCollectionCommandOptions {
|
|
|
357
321
|
}
|
|
358
322
|
|
|
359
323
|
export class TestFixture extends ShellHelper {
|
|
360
|
-
public readonly qualifier
|
|
324
|
+
public readonly qualifier: string;
|
|
361
325
|
private readonly bucketsToDelete = new Array<string>();
|
|
362
326
|
public readonly packages: IPackageSource;
|
|
363
327
|
|
|
@@ -367,9 +331,9 @@ export class TestFixture extends ShellHelper {
|
|
|
367
331
|
public readonly output: NodeJS.WritableStream,
|
|
368
332
|
public readonly aws: AwsClients,
|
|
369
333
|
public readonly randomString: string) {
|
|
370
|
-
|
|
371
334
|
super(integTestDir, output);
|
|
372
335
|
|
|
336
|
+
this.qualifier = this.randomString.slice(0, 10);
|
|
373
337
|
this.packages = packageSourceInSubprocess();
|
|
374
338
|
}
|
|
375
339
|
|
|
@@ -378,16 +342,21 @@ export class TestFixture extends ShellHelper {
|
|
|
378
342
|
}
|
|
379
343
|
|
|
380
344
|
public async cdkDeploy(stackNames: string | string[], options: CdkCliOptions = {}, skipStackRename?: boolean) {
|
|
381
|
-
|
|
345
|
+
return this.cdk(this.cdkDeployCommandLine(stackNames, options, skipStackRename), options);
|
|
346
|
+
}
|
|
382
347
|
|
|
348
|
+
public cdkDeployCommandLine(stackNames: string | string[], options: CdkCliOptions = {}, skipStackRename?: boolean) {
|
|
349
|
+
stackNames = typeof stackNames === 'string' ? [stackNames] : stackNames;
|
|
383
350
|
const neverRequireApproval = options.neverRequireApproval ?? true;
|
|
384
351
|
|
|
385
|
-
return
|
|
352
|
+
return [
|
|
353
|
+
'deploy',
|
|
386
354
|
...(neverRequireApproval ? ['--require-approval=never'] : []), // Default to no approval in an unattended test
|
|
387
355
|
...(options.options ?? []),
|
|
388
356
|
// use events because bar renders bad in tests
|
|
389
357
|
'--progress', 'events',
|
|
390
|
-
...(skipStackRename ? stackNames : this.fullStackName(stackNames))
|
|
358
|
+
...(skipStackRename ? stackNames : this.fullStackName(stackNames)),
|
|
359
|
+
];
|
|
391
360
|
}
|
|
392
361
|
|
|
393
362
|
public async cdkSynth(options: CdkCliOptions = {}) {
|
|
@@ -478,6 +447,13 @@ export class TestFixture extends ShellHelper {
|
|
|
478
447
|
args.push('--template', options.bootstrapTemplate);
|
|
479
448
|
}
|
|
480
449
|
|
|
450
|
+
if (options.trust != null) {
|
|
451
|
+
args.push('--trust', options.trust.join(','));
|
|
452
|
+
}
|
|
453
|
+
if (options.untrust != null) {
|
|
454
|
+
args.push('--untrust', options.untrust.join(','));
|
|
455
|
+
}
|
|
456
|
+
|
|
481
457
|
return this.cdk(args, {
|
|
482
458
|
...options.cliOptions,
|
|
483
459
|
modEnv: {
|
|
@@ -530,17 +506,35 @@ export class TestFixture extends ShellHelper {
|
|
|
530
506
|
return this.shell(['cdk', ...(verbose ? ['-v'] : []), ...args], {
|
|
531
507
|
...options,
|
|
532
508
|
modEnv: {
|
|
533
|
-
|
|
534
|
-
AWS_DEFAULT_REGION: this.aws.region,
|
|
535
|
-
STACK_NAME_PREFIX: this.stackNamePrefix,
|
|
536
|
-
PACKAGE_LAYOUT_VERSION: this.packages.majorVersion(),
|
|
537
|
-
// CI may need to be unset, because we're trying to capture stdout in a bunch of tests
|
|
538
|
-
CI: undefined,
|
|
509
|
+
...this.cdkShellEnv(),
|
|
539
510
|
...options.modEnv,
|
|
540
511
|
},
|
|
541
512
|
});
|
|
542
513
|
}
|
|
543
514
|
|
|
515
|
+
/**
|
|
516
|
+
* Return the environment variables with which to execute CDK
|
|
517
|
+
*/
|
|
518
|
+
public cdkShellEnv() {
|
|
519
|
+
// if tests are using an explicit aws identity already (i.e creds)
|
|
520
|
+
// force every cdk command to use the same identity.
|
|
521
|
+
const awsCreds: Record<string, string> = this.aws.identity ? {
|
|
522
|
+
AWS_ACCESS_KEY_ID: this.aws.identity.accessKeyId,
|
|
523
|
+
AWS_SECRET_ACCESS_KEY: this.aws.identity.secretAccessKey,
|
|
524
|
+
AWS_SESSION_TOKEN: this.aws.identity.sessionToken!,
|
|
525
|
+
} : {};
|
|
526
|
+
|
|
527
|
+
return {
|
|
528
|
+
AWS_REGION: this.aws.region,
|
|
529
|
+
AWS_DEFAULT_REGION: this.aws.region,
|
|
530
|
+
STACK_NAME_PREFIX: this.stackNamePrefix,
|
|
531
|
+
PACKAGE_LAYOUT_VERSION: this.packages.majorVersion(),
|
|
532
|
+
// In these tests we want to make a distinction between stdout and sterr
|
|
533
|
+
CI: 'false',
|
|
534
|
+
...awsCreds,
|
|
535
|
+
};
|
|
536
|
+
}
|
|
537
|
+
|
|
544
538
|
public template(stackName: string): any {
|
|
545
539
|
const fullStackName = this.fullStackName(stackName);
|
|
546
540
|
const templatePath = path.join(this.integTestDir, 'cdk.out', `${fullStackName}.template.json`);
|
|
@@ -586,37 +580,41 @@ export class TestFixture extends ShellHelper {
|
|
|
586
580
|
* Cleanup leftover stacks and bootstrapped resources
|
|
587
581
|
*/
|
|
588
582
|
public async dispose(success: boolean) {
|
|
589
|
-
|
|
590
|
-
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
598
|
-
|
|
599
|
-
|
|
600
|
-
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
|
|
619
|
-
|
|
583
|
+
// when using the atmosphere service, it does resource cleanup on our behalf
|
|
584
|
+
// so we don't have to wait for it.
|
|
585
|
+
if (!atmosphereEnabled()) {
|
|
586
|
+
const stacksToDelete = await this.deleteableStacks(this.stackNamePrefix);
|
|
587
|
+
|
|
588
|
+
this.sortBootstrapStacksToTheEnd(stacksToDelete);
|
|
589
|
+
|
|
590
|
+
// Bootstrap stacks have buckets that need to be cleaned
|
|
591
|
+
const bucketNames = stacksToDelete.map(stack => outputFromStack('BucketName', stack)).filter(defined);
|
|
592
|
+
// Parallelism will be reasonable
|
|
593
|
+
// eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism
|
|
594
|
+
await Promise.all(bucketNames.map(b => this.aws.emptyBucket(b)));
|
|
595
|
+
// The bootstrap bucket has a removal policy of RETAIN by default, so add it to the buckets to be cleaned up.
|
|
596
|
+
this.bucketsToDelete.push(...bucketNames);
|
|
597
|
+
|
|
598
|
+
// Bootstrap stacks have ECR repositories with images which should be deleted
|
|
599
|
+
const imageRepositoryNames = stacksToDelete.map(stack => outputFromStack('ImageRepositoryName', stack)).filter(defined);
|
|
600
|
+
// Parallelism will be reasonable
|
|
601
|
+
// eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism
|
|
602
|
+
await Promise.all(imageRepositoryNames.map(r => this.aws.deleteImageRepository(r)));
|
|
603
|
+
|
|
604
|
+
await this.aws.deleteStacks(
|
|
605
|
+
...stacksToDelete.map((s) => {
|
|
606
|
+
if (!s.StackName) {
|
|
607
|
+
throw new Error('Stack name is required to delete a stack.');
|
|
608
|
+
}
|
|
609
|
+
return s.StackName;
|
|
610
|
+
}),
|
|
611
|
+
);
|
|
612
|
+
|
|
613
|
+
// We might have leaked some buckets by upgrading the bootstrap stack. Be
|
|
614
|
+
// sure to clean everything.
|
|
615
|
+
for (const bucket of this.bucketsToDelete) {
|
|
616
|
+
await this.aws.deleteBucket(bucket);
|
|
617
|
+
}
|
|
620
618
|
}
|
|
621
619
|
|
|
622
620
|
// If the tests completed successfully, happily delete the fixture
|
|
@@ -657,7 +655,6 @@ export class TestFixture extends ShellHelper {
|
|
|
657
655
|
|
|
658
656
|
private sortBootstrapStacksToTheEnd(stacks: Stack[]) {
|
|
659
657
|
stacks.sort((a, b) => {
|
|
660
|
-
|
|
661
658
|
if (!a.StackName || !b.StackName) {
|
|
662
659
|
throw new Error('Stack names do not exists. These are required for sorting the bootstrap stacks.');
|
|
663
660
|
}
|
|
@@ -679,7 +676,7 @@ export class TestFixture extends ShellHelper {
|
|
|
679
676
|
* Since we go striping across regions, it's going to suck doing this
|
|
680
677
|
* by hand so let's just mass-automate it.
|
|
681
678
|
*/
|
|
682
|
-
async function ensureBootstrapped(fixture: TestFixture) {
|
|
679
|
+
export async function ensureBootstrapped(fixture: TestFixture) {
|
|
683
680
|
// Always use the modern bootstrap stack, otherwise we may get the error
|
|
684
681
|
// "refusing to downgrade from version 7 to version 0" when bootstrapping with default
|
|
685
682
|
// settings using a v1 CLI.
|
|
@@ -696,7 +693,11 @@ async function ensureBootstrapped(fixture: TestFixture) {
|
|
|
696
693
|
},
|
|
697
694
|
});
|
|
698
695
|
|
|
699
|
-
|
|
696
|
+
// when using the atmosphere service, every test needs to bootstrap
|
|
697
|
+
// its own environment.
|
|
698
|
+
if (!atmosphereEnabled()) {
|
|
699
|
+
ALREADY_BOOTSTRAPPED_IN_THIS_RUN.add(envSpecifier);
|
|
700
|
+
}
|
|
700
701
|
}
|
|
701
702
|
|
|
702
703
|
function defined<A>(x: A): x is NonNullable<A> {
|
package/lib/with-cli-lib.d.ts
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { TestContext } from './integ-test';
|
|
2
2
|
import { AwsContext } from './with-aws';
|
|
3
|
-
import { TestFixture, CdkCliOptions } from './with-cdk-app';
|
|
3
|
+
import { TestFixture, CdkCliOptions, DisableBootstrapContext } from './with-cdk-app';
|
|
4
4
|
/**
|
|
5
5
|
* Higher order function to execute a block with a CliLib Integration CDK app fixture
|
|
6
6
|
*/
|
|
7
|
-
export declare function withCliLibIntegrationCdkApp<A extends TestContext & AwsContext>(block: (context: CliLibIntegrationTestFixture) => Promise<void>): (context: A) => Promise<void>;
|
|
7
|
+
export declare function withCliLibIntegrationCdkApp<A extends TestContext & AwsContext & DisableBootstrapContext>(block: (context: CliLibIntegrationTestFixture) => Promise<void>): (context: A) => Promise<void>;
|
|
8
8
|
/**
|
|
9
9
|
* SAM Integration test fixture for CDK - SAM integration test cases
|
|
10
10
|
*/
|
package/lib/with-cli-lib.js
CHANGED
|
@@ -29,13 +29,21 @@ function withCliLibIntegrationCdkApp(block) {
|
|
|
29
29
|
throw new Error('This test suite is only compatible with AWS CDK v2');
|
|
30
30
|
}
|
|
31
31
|
const alphaInstallationVersion = fixture.packages.requestedAlphaVersion();
|
|
32
|
+
// cli-lib-alpha has a magic alpha version in the old release pipeline,
|
|
33
|
+
// but will just mirror the CLI version in the new pipeline.
|
|
34
|
+
const cliLibVersion = process.env.CLI_LIB_VERSION_MIRRORS_CLI
|
|
35
|
+
? `${fixture.packages.requestedCliVersion()}-alpha.0`
|
|
36
|
+
: alphaInstallationVersion;
|
|
32
37
|
await (0, with_cdk_app_1.installNpmPackages)(fixture, {
|
|
33
38
|
'aws-cdk-lib': installationVersion,
|
|
34
|
-
'@aws-cdk/cli-lib-alpha':
|
|
39
|
+
'@aws-cdk/cli-lib-alpha': cliLibVersion,
|
|
35
40
|
'@aws-cdk/aws-lambda-go-alpha': alphaInstallationVersion,
|
|
36
41
|
'@aws-cdk/aws-lambda-python-alpha': alphaInstallationVersion,
|
|
37
42
|
'constructs': '^10',
|
|
38
43
|
});
|
|
44
|
+
if (!context.disableBootstrap) {
|
|
45
|
+
await (0, with_cdk_app_1.ensureBootstrapped)(fixture);
|
|
46
|
+
}
|
|
39
47
|
await block(fixture);
|
|
40
48
|
}
|
|
41
49
|
catch (e) {
|
|
@@ -114,10 +122,12 @@ __EOS__`], {
|
|
|
114
122
|
AWS_DEFAULT_REGION: this.aws.region,
|
|
115
123
|
STACK_NAME_PREFIX: this.stackNamePrefix,
|
|
116
124
|
PACKAGE_LAYOUT_VERSION: this.packages.majorVersion(),
|
|
125
|
+
// In these tests we want to make a distinction between stdout and sterr
|
|
126
|
+
CI: 'false',
|
|
117
127
|
...options.modEnv,
|
|
118
128
|
},
|
|
119
129
|
});
|
|
120
130
|
}
|
|
121
131
|
}
|
|
122
132
|
exports.CliLibIntegrationTestFixture = CliLibIntegrationTestFixture;
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-cli-lib.js","sourceRoot":"","sources":["with-cli-lib.ts"],"names":[],"mappings":"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","sourcesContent":["import * as os from 'os';\nimport * as path from 'path';\nimport { TestContext } from './integ-test';\nimport { RESOURCES_DIR } from './resources';\nimport { AwsContext, withAws } from './with-aws';\nimport { cloneDirectory, installNpmPackages, TestFixture, DEFAULT_TEST_TIMEOUT_S, CdkCliOptions } from './with-cdk-app';\nimport { withTimeout } from './with-timeout';\n\n/**\n * Higher order function to execute a block with a CliLib Integration CDK app fixture\n */\nexport function withCliLibIntegrationCdkApp<A extends TestContext & AwsContext>(block: (context: CliLibIntegrationTestFixture) => Promise<void>) {\n  return async (context: A) => {\n    const randy = context.randomString;\n    const stackNamePrefix = `cdktest-${randy}`;\n    const integTestDir = path.join(os.tmpdir(), `cdk-integ-${randy}`);\n\n    context.log(` Stack prefix:   ${stackNamePrefix}\\n`);\n    context.log(` Test directory: ${integTestDir}\\n`);\n    context.log(` Region:         ${context.aws.region}\\n`);\n\n    await cloneDirectory(path.join(RESOURCES_DIR, 'cdk-apps', 'simple-app'), integTestDir, context.output);\n    const fixture = new CliLibIntegrationTestFixture(\n      integTestDir,\n      stackNamePrefix,\n      context.output,\n      context.aws,\n      context.randomString);\n\n    let success = true;\n    try {\n      const installationVersion = fixture.packages.requestedFrameworkVersion();\n\n      if (fixture.packages.majorVersion() === '1') {\n        throw new Error('This test suite is only compatible with AWS CDK v2');\n      }\n\n      const alphaInstallationVersion = fixture.packages.requestedAlphaVersion();\n      await installNpmPackages(fixture, {\n        'aws-cdk-lib': installationVersion,\n        '@aws-cdk/cli-lib-alpha': alphaInstallationVersion,\n        '@aws-cdk/aws-lambda-go-alpha': alphaInstallationVersion,\n        '@aws-cdk/aws-lambda-python-alpha': alphaInstallationVersion,\n        'constructs': '^10',\n      });\n\n      await block(fixture);\n    } catch (e: any) {\n      // We survive certain cases involving gopkg.in\n      if (errorCausedByGoPkg(e.message)) {\n        return;\n      }\n      success = false;\n      throw e;\n    } finally {\n      if (process.env.INTEG_NO_CLEAN) {\n        context.log(`Left test directory in '${integTestDir}' ($INTEG_NO_CLEAN)\\n`);\n      } else {\n        await fixture.dispose(success);\n      }\n    }\n  };\n}\n\n/**\n * Return whether or not the error is being caused by gopkg.in being down\n *\n * Our Go build depends on https://gopkg.in/, which has errors pretty often\n * (every couple of days). It is run by a single volunteer.\n */\nfunction errorCausedByGoPkg(error: string) {\n  // The error is different depending on what request fails. Messages recognized:\n  ////////////////////////////////////////////////////////////////////\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: invalid version: git ls-remote -q origin in /go/pkg/mod/cache/vcs/0901dc1ef67fcce1c9b3ae51078740de4a0e2dc673e720584ac302973af82f36: exit status 128:\n  //        remote: Cannot obtain refs from GitHub: cannot talk to GitHub: Get https://github.com/go-yaml/yaml.git/info/refs?service=git-upload-pack: net/http: request canceled (Client.Timeout exceeded while awaiting headers)\n  //        fatal: unable to access 'https://gopkg.in/yaml.v3/': The requested URL returned error: 502\n  ////////////////////////////////////////////////////////////////////\n  //    go: downloading github.com/aws/aws-lambda-go v1.28.0\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: unrecognized import path \"gopkg.in/yaml.v3\": reading https://gopkg.in/yaml.v3?go-get=1: 502 Bad Gateway\n  //        server response: Cannot obtain refs from GitHub: cannot talk to GitHub: Get https://github.com/go-yaml/yaml.git/info/refs?service=git-upload-pack: net/http: request canceled (Client.Timeout exceeded while awaiting headers)\n  ////////////////////////////////////////////////////////////////////\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: invalid version: git fetch -f origin refs/heads/*:refs/heads/* refs/tags/*:refs/tags/* in /go/pkg/mod/cache/vcs/0901dc1ef67fcce1c9b3ae51078740de4a0e2dc673e720584ac302973af82f36: exit status 128:\n  //        error: RPC failed; HTTP 502 curl 22 The requested URL returned error: 502\n  //        fatal: the remote end hung up unexpectedly\n  ////////////////////////////////////////////////////////////////////\n\n  return (error.includes('gopkg\\.in.*invalid version.*exit status 128')\n    || error.match(/unrecognized import path[^\\n]gopkg\\.in/));\n}\n\n/**\n * SAM Integration test fixture for CDK - SAM integration test cases\n */\nexport function withCliLibFixture(block: (context: CliLibIntegrationTestFixture) => Promise<void>) {\n  return withAws(withTimeout(DEFAULT_TEST_TIMEOUT_S, withCliLibIntegrationCdkApp(block)));\n}\n\nexport class CliLibIntegrationTestFixture extends TestFixture {\n  /**\n   *\n   */\n  public async cdk(args: string[], options: CdkCliOptions = {}) {\n    const action = args[0];\n    const stackName = args[1];\n\n    const cliOpts: Record<string, any> = {\n      stacks: stackName ? [stackName] : undefined,\n    };\n\n    if (action === 'deploy') {\n      cliOpts.requireApproval = options.neverRequireApproval ? 'never' : 'broadening';\n    }\n\n    return this.shell(['node', '--input-type=module', `<<__EOS__\n      import { AwsCdkCli } from '@aws-cdk/cli-lib-alpha';\n      const cli = AwsCdkCli.fromCdkAppDirectory();\n\n      await cli.${action}(${JSON.stringify(cliOpts)});\n__EOS__`], {\n      ...options,\n      modEnv: {\n        AWS_REGION: this.aws.region,\n        AWS_DEFAULT_REGION: this.aws.region,\n        STACK_NAME_PREFIX: this.stackNamePrefix,\n        PACKAGE_LAYOUT_VERSION: this.packages.majorVersion(),\n        ...options.modEnv,\n      },\n    });\n  }\n\n}\n"]}
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-cli-lib.js","sourceRoot":"","sources":["with-cli-lib.ts"],"names":[],"mappings":"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","sourcesContent":["import * as os from 'os';\nimport * as path from 'path';\nimport { TestContext } from './integ-test';\nimport { RESOURCES_DIR } from './resources';\nimport { AwsContext, withAws } from './with-aws';\nimport { cloneDirectory, installNpmPackages, TestFixture, DEFAULT_TEST_TIMEOUT_S, CdkCliOptions, DisableBootstrapContext, ensureBootstrapped } from './with-cdk-app';\nimport { withTimeout } from './with-timeout';\n\n/**\n * Higher order function to execute a block with a CliLib Integration CDK app fixture\n */\nexport function withCliLibIntegrationCdkApp<A extends TestContext & AwsContext & DisableBootstrapContext>(\n  block: (context: CliLibIntegrationTestFixture) => Promise<void>) {\n  return async (context: A) => {\n    const randy = context.randomString;\n    const stackNamePrefix = `cdktest-${randy}`;\n    const integTestDir = path.join(os.tmpdir(), `cdk-integ-${randy}`);\n\n    context.log(` Stack prefix:   ${stackNamePrefix}\\n`);\n    context.log(` Test directory: ${integTestDir}\\n`);\n    context.log(` Region:         ${context.aws.region}\\n`);\n\n    await cloneDirectory(path.join(RESOURCES_DIR, 'cdk-apps', 'simple-app'), integTestDir, context.output);\n    const fixture = new CliLibIntegrationTestFixture(\n      integTestDir,\n      stackNamePrefix,\n      context.output,\n      context.aws,\n      context.randomString);\n\n    let success = true;\n    try {\n      const installationVersion = fixture.packages.requestedFrameworkVersion();\n\n      if (fixture.packages.majorVersion() === '1') {\n        throw new Error('This test suite is only compatible with AWS CDK v2');\n      }\n\n      const alphaInstallationVersion = fixture.packages.requestedAlphaVersion();\n\n      // cli-lib-alpha has a magic alpha version in the old release pipeline,\n      // but will just mirror the CLI version in the new pipeline.\n      const cliLibVersion = process.env.CLI_LIB_VERSION_MIRRORS_CLI\n        ? `${fixture.packages.requestedCliVersion()}-alpha.0`\n        : alphaInstallationVersion;\n\n      await installNpmPackages(fixture, {\n        'aws-cdk-lib': installationVersion,\n        '@aws-cdk/cli-lib-alpha': cliLibVersion,\n        '@aws-cdk/aws-lambda-go-alpha': alphaInstallationVersion,\n        '@aws-cdk/aws-lambda-python-alpha': alphaInstallationVersion,\n        'constructs': '^10',\n      });\n\n      if (!context.disableBootstrap) {\n        await ensureBootstrapped(fixture);\n      }\n\n      await block(fixture);\n    } catch (e: any) {\n      // We survive certain cases involving gopkg.in\n      if (errorCausedByGoPkg(e.message)) {\n        return;\n      }\n      success = false;\n      throw e;\n    } finally {\n      if (process.env.INTEG_NO_CLEAN) {\n        context.log(`Left test directory in '${integTestDir}' ($INTEG_NO_CLEAN)\\n`);\n      } else {\n        await fixture.dispose(success);\n      }\n    }\n  };\n}\n\n/**\n * Return whether or not the error is being caused by gopkg.in being down\n *\n * Our Go build depends on https://gopkg.in/, which has errors pretty often\n * (every couple of days). It is run by a single volunteer.\n */\nfunction errorCausedByGoPkg(error: string) {\n  // The error is different depending on what request fails. Messages recognized:\n  ////////////////////////////////////////////////////////////////////\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: invalid version: git ls-remote -q origin in /go/pkg/mod/cache/vcs/0901dc1ef67fcce1c9b3ae51078740de4a0e2dc673e720584ac302973af82f36: exit status 128:\n  //        remote: Cannot obtain refs from GitHub: cannot talk to GitHub: Get https://github.com/go-yaml/yaml.git/info/refs?service=git-upload-pack: net/http: request canceled (Client.Timeout exceeded while awaiting headers)\n  //        fatal: unable to access 'https://gopkg.in/yaml.v3/': The requested URL returned error: 502\n  ////////////////////////////////////////////////////////////////////\n  //    go: downloading github.com/aws/aws-lambda-go v1.28.0\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: unrecognized import path \"gopkg.in/yaml.v3\": reading https://gopkg.in/yaml.v3?go-get=1: 502 Bad Gateway\n  //        server response: Cannot obtain refs from GitHub: cannot talk to GitHub: Get https://github.com/go-yaml/yaml.git/info/refs?service=git-upload-pack: net/http: request canceled (Client.Timeout exceeded while awaiting headers)\n  ////////////////////////////////////////////////////////////////////\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: invalid version: git fetch -f origin refs/heads/*:refs/heads/* refs/tags/*:refs/tags/* in /go/pkg/mod/cache/vcs/0901dc1ef67fcce1c9b3ae51078740de4a0e2dc673e720584ac302973af82f36: exit status 128:\n  //        error: RPC failed; HTTP 502 curl 22 The requested URL returned error: 502\n  //        fatal: the remote end hung up unexpectedly\n  ////////////////////////////////////////////////////////////////////\n\n  return (error.includes('gopkg\\.in.*invalid version.*exit status 128')\n    || error.match(/unrecognized import path[^\\n]gopkg\\.in/));\n}\n\n/**\n * SAM Integration test fixture for CDK - SAM integration test cases\n */\nexport function withCliLibFixture(block: (context: CliLibIntegrationTestFixture) => Promise<void>) {\n  return withAws(withTimeout(DEFAULT_TEST_TIMEOUT_S, withCliLibIntegrationCdkApp(block)));\n}\n\nexport class CliLibIntegrationTestFixture extends TestFixture {\n  /**\n   *\n   */\n  public async cdk(args: string[], options: CdkCliOptions = {}) {\n    const action = args[0];\n    const stackName = args[1];\n\n    const cliOpts: Record<string, any> = {\n      stacks: stackName ? [stackName] : undefined,\n    };\n\n    if (action === 'deploy') {\n      cliOpts.requireApproval = options.neverRequireApproval ? 'never' : 'broadening';\n    }\n\n    return this.shell(['node', '--input-type=module', `<<__EOS__\n      import { AwsCdkCli } from '@aws-cdk/cli-lib-alpha';\n      const cli = AwsCdkCli.fromCdkAppDirectory();\n\n      await cli.${action}(${JSON.stringify(cliOpts)});\n__EOS__`], {\n      ...options,\n      modEnv: {\n        AWS_REGION: this.aws.region,\n        AWS_DEFAULT_REGION: this.aws.region,\n        STACK_NAME_PREFIX: this.stackNamePrefix,\n        PACKAGE_LAYOUT_VERSION: this.packages.majorVersion(),\n        // In these tests we want to make a distinction between stdout and sterr\n        CI: 'false',\n        ...options.modEnv,\n      },\n    });\n  }\n}\n\n"]}
|
package/lib/with-cli-lib.ts
CHANGED
|
@@ -3,13 +3,14 @@ import * as path from 'path';
|
|
|
3
3
|
import { TestContext } from './integ-test';
|
|
4
4
|
import { RESOURCES_DIR } from './resources';
|
|
5
5
|
import { AwsContext, withAws } from './with-aws';
|
|
6
|
-
import { cloneDirectory, installNpmPackages, TestFixture, DEFAULT_TEST_TIMEOUT_S, CdkCliOptions } from './with-cdk-app';
|
|
6
|
+
import { cloneDirectory, installNpmPackages, TestFixture, DEFAULT_TEST_TIMEOUT_S, CdkCliOptions, DisableBootstrapContext, ensureBootstrapped } from './with-cdk-app';
|
|
7
7
|
import { withTimeout } from './with-timeout';
|
|
8
8
|
|
|
9
9
|
/**
|
|
10
10
|
* Higher order function to execute a block with a CliLib Integration CDK app fixture
|
|
11
11
|
*/
|
|
12
|
-
export function withCliLibIntegrationCdkApp<A extends TestContext & AwsContext
|
|
12
|
+
export function withCliLibIntegrationCdkApp<A extends TestContext & AwsContext & DisableBootstrapContext>(
|
|
13
|
+
block: (context: CliLibIntegrationTestFixture) => Promise<void>) {
|
|
13
14
|
return async (context: A) => {
|
|
14
15
|
const randy = context.randomString;
|
|
15
16
|
const stackNamePrefix = `cdktest-${randy}`;
|
|
@@ -36,14 +37,25 @@ export function withCliLibIntegrationCdkApp<A extends TestContext & AwsContext>(
|
|
|
36
37
|
}
|
|
37
38
|
|
|
38
39
|
const alphaInstallationVersion = fixture.packages.requestedAlphaVersion();
|
|
40
|
+
|
|
41
|
+
// cli-lib-alpha has a magic alpha version in the old release pipeline,
|
|
42
|
+
// but will just mirror the CLI version in the new pipeline.
|
|
43
|
+
const cliLibVersion = process.env.CLI_LIB_VERSION_MIRRORS_CLI
|
|
44
|
+
? `${fixture.packages.requestedCliVersion()}-alpha.0`
|
|
45
|
+
: alphaInstallationVersion;
|
|
46
|
+
|
|
39
47
|
await installNpmPackages(fixture, {
|
|
40
48
|
'aws-cdk-lib': installationVersion,
|
|
41
|
-
'@aws-cdk/cli-lib-alpha':
|
|
49
|
+
'@aws-cdk/cli-lib-alpha': cliLibVersion,
|
|
42
50
|
'@aws-cdk/aws-lambda-go-alpha': alphaInstallationVersion,
|
|
43
51
|
'@aws-cdk/aws-lambda-python-alpha': alphaInstallationVersion,
|
|
44
52
|
'constructs': '^10',
|
|
45
53
|
});
|
|
46
54
|
|
|
55
|
+
if (!context.disableBootstrap) {
|
|
56
|
+
await ensureBootstrapped(fixture);
|
|
57
|
+
}
|
|
58
|
+
|
|
47
59
|
await block(fixture);
|
|
48
60
|
} catch (e: any) {
|
|
49
61
|
// We survive certain cases involving gopkg.in
|
|
@@ -126,9 +138,11 @@ __EOS__`], {
|
|
|
126
138
|
AWS_DEFAULT_REGION: this.aws.region,
|
|
127
139
|
STACK_NAME_PREFIX: this.stackNamePrefix,
|
|
128
140
|
PACKAGE_LAYOUT_VERSION: this.packages.majorVersion(),
|
|
141
|
+
// In these tests we want to make a distinction between stdout and sterr
|
|
142
|
+
CI: 'false',
|
|
129
143
|
...options.modEnv,
|
|
130
144
|
},
|
|
131
145
|
});
|
|
132
146
|
}
|
|
133
|
-
|
|
134
147
|
}
|
|
148
|
+
|
package/lib/with-sam.js
CHANGED
|
@@ -145,6 +145,7 @@ class SamIntegrationTestFixture extends with_cdk_app_1.TestFixture {
|
|
|
145
145
|
if (success) {
|
|
146
146
|
const cleaned = (0, shell_1.rimraf)(this.integTestDir);
|
|
147
147
|
if (!cleaned) {
|
|
148
|
+
// eslint-disable-next-line no-console
|
|
148
149
|
console.error(`Failed to clean up ${this.integTestDir} due to permissions issues (Docker running as root?)`);
|
|
149
150
|
}
|
|
150
151
|
}
|
|
@@ -260,4 +261,4 @@ function killSubProcess(child, command) {
|
|
|
260
261
|
child.kill('SIGINT');
|
|
261
262
|
child_process.exec(`for pid in $(ps -ef | grep "${command}" | awk '{print $2}'); do kill -2 $pid; done`);
|
|
262
263
|
}
|
|
263
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-sam.js","sourceRoot":"","sources":["with-sam.ts"],"names":[],"mappings":"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","sourcesContent":["import * as child_process from 'child_process';\nimport * as os from 'os';\nimport * as path from 'path';\nimport axios from 'axios';\nimport { TestContext } from './integ-test';\nimport { RESOURCES_DIR } from './resources';\nimport { ShellOptions, rimraf } from './shell';\nimport { AwsContext, withAws } from './with-aws';\nimport { cloneDirectory, installNpmPackages, TestFixture, DEFAULT_TEST_TIMEOUT_S } from './with-cdk-app';\nimport { withTimeout } from './with-timeout';\n\nexport interface ActionOutput {\n  actionSucceeded?: boolean;\n  actionOutput?: any;\n  shellOutput?: string;\n}\n\n/**\n * Higher order function to execute a block with a SAM Integration CDK app fixture\n */\nexport function withSamIntegrationCdkApp<A extends TestContext & AwsContext>(block: (context: SamIntegrationTestFixture) => Promise<void>) {\n  return async (context: A) => {\n    const randy = context.randomString;\n    const stackNamePrefix = `cdktest-${randy}`;\n    const integTestDir = path.join(os.tmpdir(), `cdk-integ-${randy}`);\n\n    context.log(` Stack prefix:   ${stackNamePrefix}\\n`);\n    context.log(` Test directory: ${integTestDir}\\n`);\n    context.log(` Region:         ${context.aws.region}\\n`);\n\n    await cloneDirectory(path.join(RESOURCES_DIR, 'cdk-apps', 'sam_cdk_integ_app'), integTestDir, context.output);\n    const fixture = new SamIntegrationTestFixture(\n      integTestDir,\n      stackNamePrefix,\n      context.output,\n      context.aws,\n      context.randomString);\n\n    let success = true;\n    try {\n      const installationVersion = fixture.packages.requestedFrameworkVersion();\n\n      if (fixture.packages.majorVersion() === '1') {\n        await installNpmPackages(fixture, {\n          '@aws-cdk/aws-iam': installationVersion,\n          '@aws-cdk/aws-apigateway': installationVersion,\n          '@aws-cdk/aws-lambda': installationVersion,\n          '@aws-cdk/aws-lambda-go': installationVersion,\n          '@aws-cdk/aws-lambda-nodejs': installationVersion,\n          '@aws-cdk/aws-lambda-python': installationVersion,\n          '@aws-cdk/aws-logs': installationVersion,\n          '@aws-cdk/core': installationVersion,\n          'constructs': '^3',\n        });\n      } else {\n        const alphaInstallationVersion = fixture.packages.requestedAlphaVersion();\n        await installNpmPackages(fixture, {\n          'aws-cdk-lib': installationVersion,\n          '@aws-cdk/aws-lambda-go-alpha': alphaInstallationVersion,\n          '@aws-cdk/aws-lambda-python-alpha': alphaInstallationVersion,\n          'constructs': '^10',\n        });\n      }\n      await block(fixture);\n    } catch (e: any) {\n      // We survive certain cases involving gopkg.in\n      if (errorCausedByGoPkg(e.message)) {\n        return;\n      }\n      success = false;\n      throw e;\n    } finally {\n      if (process.env.INTEG_NO_CLEAN) {\n        context.log(`Left test directory in '${integTestDir}' ($INTEG_NO_CLEAN)\\n`);\n      } else {\n        await fixture.dispose(success);\n      }\n    }\n  };\n}\n\n/**\n * Return whether or not the error is being caused by gopkg.in being down\n *\n * Our Go build depends on https://gopkg.in/, which has errors pretty often\n * (every couple of days). It is run by a single volunteer.\n */\nfunction errorCausedByGoPkg(error: string) {\n  // The error is different depending on what request fails. Messages recognized:\n  ////////////////////////////////////////////////////////////////////\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: invalid version: git ls-remote -q origin in /go/pkg/mod/cache/vcs/0901dc1ef67fcce1c9b3ae51078740de4a0e2dc673e720584ac302973af82f36: exit status 128:\n  //        remote: Cannot obtain refs from GitHub: cannot talk to GitHub: Get https://github.com/go-yaml/yaml.git/info/refs?service=git-upload-pack: net/http: request canceled (Client.Timeout exceeded while awaiting headers)\n  //        fatal: unable to access 'https://gopkg.in/yaml.v3/': The requested URL returned error: 502\n  ////////////////////////////////////////////////////////////////////\n  //    go: downloading github.com/aws/aws-lambda-go v1.28.0\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: unrecognized import path \"gopkg.in/yaml.v3\": reading https://gopkg.in/yaml.v3?go-get=1: 502 Bad Gateway\n  //        server response: Cannot obtain refs from GitHub: cannot talk to GitHub: Get https://github.com/go-yaml/yaml.git/info/refs?service=git-upload-pack: net/http: request canceled (Client.Timeout exceeded while awaiting headers)\n  ////////////////////////////////////////////////////////////////////\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: invalid version: git fetch -f origin refs/heads/*:refs/heads/* refs/tags/*:refs/tags/* in /go/pkg/mod/cache/vcs/0901dc1ef67fcce1c9b3ae51078740de4a0e2dc673e720584ac302973af82f36: exit status 128:\n  //        error: RPC failed; HTTP 502 curl 22 The requested URL returned error: 502\n  //        fatal: the remote end hung up unexpectedly\n  ////////////////////////////////////////////////////////////////////\n\n  return (error.includes('gopkg\\.in.*invalid version.*exit status 128')\n    || error.match(/unrecognized import path[^\\n]gopkg\\.in/));\n}\n\n/**\n * SAM Integration test fixture for CDK - SAM integration test cases\n */\nexport function withSamIntegrationFixture(block: (context: SamIntegrationTestFixture) => Promise<void>) {\n  return withAws(withTimeout(DEFAULT_TEST_TIMEOUT_S, withSamIntegrationCdkApp(block)));\n}\n\nexport class SamIntegrationTestFixture extends TestFixture {\n  public async samShell(command: string[], filter?: string, action?: () => any, options: Omit<ShellOptions, 'cwd' | 'output'> = {}): Promise<ActionOutput> {\n    return shellWithAction(command, filter, action, {\n      outputs: [this.output],\n      cwd: path.join(this.integTestDir, 'cdk.out').toString(),\n      ...options,\n    });\n  }\n\n  public async samBuild(stackName: string) {\n    const fullStackName = this.fullStackName(stackName);\n    const templatePath = path.join(this.integTestDir, 'cdk.out', `${fullStackName}.template.json`);\n    const args = ['--template', templatePath.toString()];\n    return this.samShell(['sam', 'build', ...args]);\n  }\n\n  public async samLocalStartApi(stackName: string, isBuilt: boolean, port: number, apiPath: string): Promise<ActionOutput> {\n    const fullStackName = this.fullStackName(stackName);\n    const templatePath = path.join(this.integTestDir, 'cdk.out', `${fullStackName}.template.json`);\n    const args = isBuilt? [] : ['--template', templatePath.toString()];\n    args.push('--port');\n    args.push(port.toString());\n\n    // \"Press Ctrl+C to quit\" looks to be printed by a Flask server built into SAM CLI.\n    return this.samShell(['sam', 'local', 'start-api', ...args], 'Press CTRL+C to quit', ()=>{\n      return new Promise<ActionOutput>((resolve, reject) => {\n        axios.get(`http://127.0.0.1:${port}${apiPath}`).then( resp => {\n          resolve(resp.data);\n        }).catch( error => {\n          reject(new Error(`Failed to invoke api path ${apiPath} on port ${port} with error ${error}`));\n        });\n      });\n    });\n  }\n\n  /**\n   * Cleanup leftover stacks and buckets\n   */\n  public async dispose(success: boolean) {\n    // If the tests completed successfully, happily delete the fixture\n    // (otherwise leave it for humans to inspect)\n    if (success) {\n      const cleaned = rimraf(this.integTestDir);\n      if (!cleaned) {\n        console.error(`Failed to clean up ${this.integTestDir} due to permissions issues (Docker running as root?)`);\n      }\n    }\n  }\n}\n\nexport function randomInteger(min: number, max: number) {\n  return Math.floor(Math.random() * (max - min) + min);\n}\n\n/**\n * A shell command that does what you want\n *\n * Is platform-aware, handles errors nicely.\n */\nexport async function shellWithAction(\n  command: string[],\n  filter?: string,\n  action?: () => Promise<any>,\n  options: ShellOptions = {},\n  actionTimeoutSeconds: number = 600,\n): Promise<ActionOutput> {\n  if (options.modEnv && options.env) {\n    throw new Error('Use either env or modEnv but not both');\n  }\n\n  const writeToOutputs = (x: string) => {\n    for (const output of options.outputs ?? []) {\n      output.write(x);\n    }\n  };\n  writeToOutputs(`💻 ${command.join(' ')}\\n`);\n\n  const env = options.env ?? (options.modEnv ? { ...process.env, ...options.modEnv } : undefined);\n\n  const child = child_process.spawn(command[0], command.slice(1), {\n    ...options,\n    env,\n    // Need this for Windows where we want .cmd and .bat to be found as well.\n    shell: true,\n    stdio: ['ignore', 'pipe', 'pipe'],\n  });\n\n  return new Promise<ActionOutput>((resolve, reject) => {\n    const out = new Array<Buffer>();\n    const stdout = new Array<Buffer>();\n    const stderr = new Array<Buffer>();\n    let actionSucceeded = false;\n    let actionOutput: any;\n    let actionExecuted = false;\n\n    async function maybeExecuteAction(chunk: any) {\n      out.push(Buffer.from(chunk));\n      if (!actionExecuted && typeof filter === 'string' && Buffer.concat(out).toString('utf-8').includes(filter) && typeof action === 'function') {\n        actionExecuted = true;\n        writeToOutputs('before executing action\\n');\n        try {\n          const output = await action();\n          writeToOutputs(`action output is ${JSON.stringify(output)}\\n`);\n          actionOutput = output;\n          actionSucceeded = true;\n        } catch (error: any) {\n          writeToOutputs(`action error is ${error}\\n`);\n          actionSucceeded = false;\n          actionOutput = error;\n        } finally {\n          writeToOutputs('terminate sam sub process\\n');\n          killSubProcess(child, command.join(' '));\n        }\n      }\n    }\n\n    if (typeof filter === 'string' && typeof action === 'function') {\n      // Reject with an error if an action is configured, but the filter failed\n      // to show up in the output before the timeout occurred.\n      setTimeout(\n        () => {\n          if (!actionExecuted) {\n            reject(new Error(`Timed out waiting for filter ${JSON.stringify(filter)} to appear in command output after ${actionTimeoutSeconds} seconds\\nOutput so far:\\n${Buffer.concat(out).toString('utf-8')}`));\n            killSubProcess(child, command.join(' '));\n          }\n        }, actionTimeoutSeconds * 1_000,\n      ).unref();\n    }\n\n    child.stdout!.on('data', chunk => {\n      writeToOutputs(chunk);\n      stdout.push(chunk);\n      void maybeExecuteAction(chunk);\n    });\n\n    child.stderr!.on('data', chunk => {\n      writeToOutputs(chunk);\n      if (options.captureStderr ?? true) {\n        stderr.push(chunk);\n      }\n      void maybeExecuteAction(chunk);\n    });\n\n    child.once('error', reject);\n\n    // Wait for 'exit' instead of close, don't care about reading the streams all the way to the end\n    child.once('exit', (code, signal) => {\n      writeToOutputs(`Subprocess has exited with code ${code}, signal ${signal}\\n`);\n      const output = (Buffer.concat(stdout).toString('utf-8') + Buffer.concat(stderr).toString('utf-8')).trim();\n      if (code == null || code === 0 || options.allowErrExit) {\n        let result = new Array<string>();\n        result.push(actionOutput);\n        result.push(output);\n        resolve({\n          actionSucceeded: actionSucceeded,\n          actionOutput: actionOutput,\n          shellOutput: output,\n        });\n      } else {\n        reject(new Error(`'${command.join(' ')}' exited with error code ${code}. Output: \\n${output}`));\n      }\n    });\n  });\n}\n\nfunction killSubProcess(child: child_process.ChildProcess, command: string) {\n  /**\n   * Check if the sub process is running in container, so child_process.spawn will\n   * create multiple processes, and to kill all of them we need to run different logic\n   */\n  child.kill('SIGINT');\n  child_process.exec(`for pid in $(ps -ef | grep \"${command}\" | awk '{print $2}'); do kill -2 $pid; done`);\n}\n"]}
|
|
264
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-sam.js","sourceRoot":"","sources":["with-sam.ts"],"names":[],"mappings":"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","sourcesContent":["import * as child_process from 'child_process';\nimport * as os from 'os';\nimport * as path from 'path';\nimport axios from 'axios';\nimport { TestContext } from './integ-test';\nimport { RESOURCES_DIR } from './resources';\nimport { ShellOptions, rimraf } from './shell';\nimport { AwsContext, withAws } from './with-aws';\nimport { cloneDirectory, installNpmPackages, TestFixture, DEFAULT_TEST_TIMEOUT_S } from './with-cdk-app';\nimport { withTimeout } from './with-timeout';\n\nexport interface ActionOutput {\n  actionSucceeded?: boolean;\n  actionOutput?: any;\n  shellOutput?: string;\n}\n\n/**\n * Higher order function to execute a block with a SAM Integration CDK app fixture\n */\nexport function withSamIntegrationCdkApp<A extends TestContext & AwsContext>(block: (context: SamIntegrationTestFixture) => Promise<void>) {\n  return async (context: A) => {\n    const randy = context.randomString;\n    const stackNamePrefix = `cdktest-${randy}`;\n    const integTestDir = path.join(os.tmpdir(), `cdk-integ-${randy}`);\n\n    context.log(` Stack prefix:   ${stackNamePrefix}\\n`);\n    context.log(` Test directory: ${integTestDir}\\n`);\n    context.log(` Region:         ${context.aws.region}\\n`);\n\n    await cloneDirectory(path.join(RESOURCES_DIR, 'cdk-apps', 'sam_cdk_integ_app'), integTestDir, context.output);\n    const fixture = new SamIntegrationTestFixture(\n      integTestDir,\n      stackNamePrefix,\n      context.output,\n      context.aws,\n      context.randomString);\n\n    let success = true;\n    try {\n      const installationVersion = fixture.packages.requestedFrameworkVersion();\n\n      if (fixture.packages.majorVersion() === '1') {\n        await installNpmPackages(fixture, {\n          '@aws-cdk/aws-iam': installationVersion,\n          '@aws-cdk/aws-apigateway': installationVersion,\n          '@aws-cdk/aws-lambda': installationVersion,\n          '@aws-cdk/aws-lambda-go': installationVersion,\n          '@aws-cdk/aws-lambda-nodejs': installationVersion,\n          '@aws-cdk/aws-lambda-python': installationVersion,\n          '@aws-cdk/aws-logs': installationVersion,\n          '@aws-cdk/core': installationVersion,\n          'constructs': '^3',\n        });\n      } else {\n        const alphaInstallationVersion = fixture.packages.requestedAlphaVersion();\n        await installNpmPackages(fixture, {\n          'aws-cdk-lib': installationVersion,\n          '@aws-cdk/aws-lambda-go-alpha': alphaInstallationVersion,\n          '@aws-cdk/aws-lambda-python-alpha': alphaInstallationVersion,\n          'constructs': '^10',\n        });\n      }\n      await block(fixture);\n    } catch (e: any) {\n      // We survive certain cases involving gopkg.in\n      if (errorCausedByGoPkg(e.message)) {\n        return;\n      }\n      success = false;\n      throw e;\n    } finally {\n      if (process.env.INTEG_NO_CLEAN) {\n        context.log(`Left test directory in '${integTestDir}' ($INTEG_NO_CLEAN)\\n`);\n      } else {\n        await fixture.dispose(success);\n      }\n    }\n  };\n}\n\n/**\n * Return whether or not the error is being caused by gopkg.in being down\n *\n * Our Go build depends on https://gopkg.in/, which has errors pretty often\n * (every couple of days). It is run by a single volunteer.\n */\nfunction errorCausedByGoPkg(error: string) {\n  // The error is different depending on what request fails. Messages recognized:\n  ////////////////////////////////////////////////////////////////////\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: invalid version: git ls-remote -q origin in /go/pkg/mod/cache/vcs/0901dc1ef67fcce1c9b3ae51078740de4a0e2dc673e720584ac302973af82f36: exit status 128:\n  //        remote: Cannot obtain refs from GitHub: cannot talk to GitHub: Get https://github.com/go-yaml/yaml.git/info/refs?service=git-upload-pack: net/http: request canceled (Client.Timeout exceeded while awaiting headers)\n  //        fatal: unable to access 'https://gopkg.in/yaml.v3/': The requested URL returned error: 502\n  ////////////////////////////////////////////////////////////////////\n  //    go: downloading github.com/aws/aws-lambda-go v1.28.0\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: unrecognized import path \"gopkg.in/yaml.v3\": reading https://gopkg.in/yaml.v3?go-get=1: 502 Bad Gateway\n  //        server response: Cannot obtain refs from GitHub: cannot talk to GitHub: Get https://github.com/go-yaml/yaml.git/info/refs?service=git-upload-pack: net/http: request canceled (Client.Timeout exceeded while awaiting headers)\n  ////////////////////////////////////////////////////////////////////\n  //    go: github.com/aws/aws-lambda-go@v1.28.0 requires\n  //        gopkg.in/yaml.v3@v3.0.0-20200615113413-eeeca48fe776: invalid version: git fetch -f origin refs/heads/*:refs/heads/* refs/tags/*:refs/tags/* in /go/pkg/mod/cache/vcs/0901dc1ef67fcce1c9b3ae51078740de4a0e2dc673e720584ac302973af82f36: exit status 128:\n  //        error: RPC failed; HTTP 502 curl 22 The requested URL returned error: 502\n  //        fatal: the remote end hung up unexpectedly\n  ////////////////////////////////////////////////////////////////////\n\n  return (error.includes('gopkg\\.in.*invalid version.*exit status 128')\n    || error.match(/unrecognized import path[^\\n]gopkg\\.in/));\n}\n\n/**\n * SAM Integration test fixture for CDK - SAM integration test cases\n */\nexport function withSamIntegrationFixture(block: (context: SamIntegrationTestFixture) => Promise<void>) {\n  return withAws(withTimeout(DEFAULT_TEST_TIMEOUT_S, withSamIntegrationCdkApp(block)));\n}\n\nexport class SamIntegrationTestFixture extends TestFixture {\n  public async samShell(command: string[], filter?: string, action?: () => any, options: Omit<ShellOptions, 'cwd' | 'output'> = {}): Promise<ActionOutput> {\n    return shellWithAction(command, filter, action, {\n      outputs: [this.output],\n      cwd: path.join(this.integTestDir, 'cdk.out').toString(),\n      ...options,\n    });\n  }\n\n  public async samBuild(stackName: string) {\n    const fullStackName = this.fullStackName(stackName);\n    const templatePath = path.join(this.integTestDir, 'cdk.out', `${fullStackName}.template.json`);\n    const args = ['--template', templatePath.toString()];\n    return this.samShell(['sam', 'build', ...args]);\n  }\n\n  public async samLocalStartApi(stackName: string, isBuilt: boolean, port: number, apiPath: string): Promise<ActionOutput> {\n    const fullStackName = this.fullStackName(stackName);\n    const templatePath = path.join(this.integTestDir, 'cdk.out', `${fullStackName}.template.json`);\n    const args = isBuilt? [] : ['--template', templatePath.toString()];\n    args.push('--port');\n    args.push(port.toString());\n\n    // \"Press Ctrl+C to quit\" looks to be printed by a Flask server built into SAM CLI.\n    return this.samShell(['sam', 'local', 'start-api', ...args], 'Press CTRL+C to quit', ()=>{\n      return new Promise<ActionOutput>((resolve, reject) => {\n        axios.get(`http://127.0.0.1:${port}${apiPath}`).then( resp => {\n          resolve(resp.data);\n        }).catch( error => {\n          reject(new Error(`Failed to invoke api path ${apiPath} on port ${port} with error ${error}`));\n        });\n      });\n    });\n  }\n\n  /**\n   * Cleanup leftover stacks and buckets\n   */\n  public async dispose(success: boolean) {\n    // If the tests completed successfully, happily delete the fixture\n    // (otherwise leave it for humans to inspect)\n    if (success) {\n      const cleaned = rimraf(this.integTestDir);\n      if (!cleaned) {\n        // eslint-disable-next-line no-console\n        console.error(`Failed to clean up ${this.integTestDir} due to permissions issues (Docker running as root?)`);\n      }\n    }\n  }\n}\n\nexport function randomInteger(min: number, max: number) {\n  return Math.floor(Math.random() * (max - min) + min);\n}\n\n/**\n * A shell command that does what you want\n *\n * Is platform-aware, handles errors nicely.\n */\nexport async function shellWithAction(\n  command: string[],\n  filter?: string,\n  action?: () => Promise<any>,\n  options: ShellOptions = {},\n  actionTimeoutSeconds: number = 600,\n): Promise<ActionOutput> {\n  if (options.modEnv && options.env) {\n    throw new Error('Use either env or modEnv but not both');\n  }\n\n  const writeToOutputs = (x: string) => {\n    for (const output of options.outputs ?? []) {\n      output.write(x);\n    }\n  };\n  writeToOutputs(`💻 ${command.join(' ')}\\n`);\n\n  const env = options.env ?? (options.modEnv ? { ...process.env, ...options.modEnv } : undefined);\n\n  const child = child_process.spawn(command[0], command.slice(1), {\n    ...options,\n    env,\n    // Need this for Windows where we want .cmd and .bat to be found as well.\n    shell: true,\n    stdio: ['ignore', 'pipe', 'pipe'],\n  });\n\n  return new Promise<ActionOutput>((resolve, reject) => {\n    const out = new Array<Buffer>();\n    const stdout = new Array<Buffer>();\n    const stderr = new Array<Buffer>();\n    let actionSucceeded = false;\n    let actionOutput: any;\n    let actionExecuted = false;\n\n    async function maybeExecuteAction(chunk: any) {\n      out.push(Buffer.from(chunk));\n      if (!actionExecuted && typeof filter === 'string' && Buffer.concat(out).toString('utf-8').includes(filter) && typeof action === 'function') {\n        actionExecuted = true;\n        writeToOutputs('before executing action\\n');\n        try {\n          const output = await action();\n          writeToOutputs(`action output is ${JSON.stringify(output)}\\n`);\n          actionOutput = output;\n          actionSucceeded = true;\n        } catch (error: any) {\n          writeToOutputs(`action error is ${error}\\n`);\n          actionSucceeded = false;\n          actionOutput = error;\n        } finally {\n          writeToOutputs('terminate sam sub process\\n');\n          killSubProcess(child, command.join(' '));\n        }\n      }\n    }\n\n    if (typeof filter === 'string' && typeof action === 'function') {\n      // Reject with an error if an action is configured, but the filter failed\n      // to show up in the output before the timeout occurred.\n      setTimeout(\n        () => {\n          if (!actionExecuted) {\n            reject(new Error(`Timed out waiting for filter ${JSON.stringify(filter)} to appear in command output after ${actionTimeoutSeconds} seconds\\nOutput so far:\\n${Buffer.concat(out).toString('utf-8')}`));\n            killSubProcess(child, command.join(' '));\n          }\n        }, actionTimeoutSeconds * 1_000,\n      ).unref();\n    }\n\n    child.stdout!.on('data', chunk => {\n      writeToOutputs(chunk);\n      stdout.push(chunk);\n      void maybeExecuteAction(chunk);\n    });\n\n    child.stderr!.on('data', chunk => {\n      writeToOutputs(chunk);\n      if (options.captureStderr ?? true) {\n        stderr.push(chunk);\n      }\n      void maybeExecuteAction(chunk);\n    });\n\n    child.once('error', reject);\n\n    // Wait for 'exit' instead of close, don't care about reading the streams all the way to the end\n    child.once('exit', (code, signal) => {\n      writeToOutputs(`Subprocess has exited with code ${code}, signal ${signal}\\n`);\n      const output = (Buffer.concat(stdout).toString('utf-8') + Buffer.concat(stderr).toString('utf-8')).trim();\n      if (code == null || code === 0 || options.allowErrExit) {\n        let result = new Array<string>();\n        result.push(actionOutput);\n        result.push(output);\n        resolve({\n          actionSucceeded: actionSucceeded,\n          actionOutput: actionOutput,\n          shellOutput: output,\n        });\n      } else {\n        reject(new Error(`'${command.join(' ')}' exited with error code ${code}. Output: \\n${output}`));\n      }\n    });\n  });\n}\n\nfunction killSubProcess(child: child_process.ChildProcess, command: string) {\n  /**\n   * Check if the sub process is running in container, so child_process.spawn will\n   * create multiple processes, and to kill all of them we need to run different logic\n   */\n  child.kill('SIGINT');\n  child_process.exec(`for pid in $(ps -ef | grep \"${command}\" | awk '{print $2}'); do kill -2 $pid; done`);\n}\n"]}
|
package/lib/with-sam.ts
CHANGED
|
@@ -159,6 +159,7 @@ export class SamIntegrationTestFixture extends TestFixture {
|
|
|
159
159
|
if (success) {
|
|
160
160
|
const cleaned = rimraf(this.integTestDir);
|
|
161
161
|
if (!cleaned) {
|
|
162
|
+
// eslint-disable-next-line no-console
|
|
162
163
|
console.error(`Failed to clean up ${this.integTestDir} due to permissions issues (Docker running as root?)`);
|
|
163
164
|
}
|
|
164
165
|
}
|