@aws-cdk-testing/cli-integ 3.21.1 → 3.22.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/cli/run-suite.js +7 -1
- package/lib/with-aws.d.ts +15 -1
- package/lib/with-aws.js +16 -3
- package/lib/with-cdk-app.d.ts +16 -6
- package/lib/with-cdk-app.js +18 -11
- package/npm-shrinkwrap.json +1826 -1118
- package/package.json +18 -18
- package/resources/cdk-apps/app/app.js +40 -0
- package/resources/cdk-apps/context-app/app.js +21 -0
- package/resources/cdk-apps/context-app/cdk.json +6 -0
- package/tests/cli-integ-tests/flags/cdk-flags-with-cli-context.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/flags/cdk-flags-with-cli-context.integtest.js +18 -0
- package/tests/cli-integ-tests/hotswap/cdk-hotswap-deployment-supports-bedrock-agentcore-runtime.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/hotswap/cdk-hotswap-deployment-supports-bedrock-agentcore-runtime.integtest.js +54 -0
package/lib/cli/run-suite.js
CHANGED
|
@@ -86,6 +86,11 @@ async function main() {
|
|
|
86
86
|
alias: 'F',
|
|
87
87
|
type: 'string',
|
|
88
88
|
requiresArg: true,
|
|
89
|
+
})
|
|
90
|
+
.options('seed', {
|
|
91
|
+
describe: 'Set the seed value to replicate a test run',
|
|
92
|
+
type: 'string',
|
|
93
|
+
requiresArg: true,
|
|
89
94
|
})
|
|
90
95
|
.options('verbose', {
|
|
91
96
|
alias: 'v',
|
|
@@ -201,6 +206,7 @@ async function main() {
|
|
|
201
206
|
const jestConfig = path.resolve(__dirname, '..', '..', 'resources', 'integ.jest.config.js');
|
|
202
207
|
await jest.run([
|
|
203
208
|
'--randomize',
|
|
209
|
+
...args.seed ? [`--seed=${args.seed}`] : [],
|
|
204
210
|
...args.runInBand ? ['-i'] : [],
|
|
205
211
|
...args.test ? ['-t', args.test] : [],
|
|
206
212
|
...args.verbose ? ['--verbose'] : [],
|
|
@@ -248,4 +254,4 @@ main().catch(e => {
|
|
|
248
254
|
console.error(e);
|
|
249
255
|
process.exitCode = 1;
|
|
250
256
|
});
|
|
251
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"run-suite.js","sourceRoot":"","sources":["run-suite.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-console */\nimport * as path from 'path';\nimport * as jest from 'jest';\nimport * as yargs from 'yargs';\nimport { RunnerCliNpmSource } from '../package-sources/cli-npm-source';\nimport { RunnerCliRepoSource } from '../package-sources/cli-repo-source';\nimport { autoFindRepoRoot } from '../package-sources/find-root';\nimport { RunnerLibraryGlobalInstallSource } from '../package-sources/library-globalinstall-source';\nimport { RunnerLibraryNpmSource } from '../package-sources/library-npm-source';\nimport { RunnerLibraryPreinstalledSource } from '../package-sources/library-preinstalled-source';\nimport type { IRunnerSource, ITestCliSource, ITestLibrarySource } from '../package-sources/source';\nimport { serializeSources } from '../package-sources/subprocess';\n\nconst CLI_PACKAGE_NAME = 'aws-cdk';\nconst CDK_ASSETS_PACKAGE_NAME = 'cdk-assets';\n\nasync function main() {\n  const args = await yargs\n    .command('* <SUITENAME>', 'default command', y => y\n      .positional('SUITENAME', {\n        describe: 'Name of the test suite to run',\n        type: 'string',\n        demandOption: true,\n      })\n      /////////////////////////////////////////////////////////////////////////////\n      //  Sources and versions\n      .options('cli-version', {\n        describe: 'CLI version to use.',\n        alias: 'c',\n        type: 'string',\n      })\n      .options('cli-source', {\n        describe: 'Root of aws-cdk-cli repository, or \"auto\".',\n        alias: 's',\n        type: 'string',\n      })\n      .options('framework-version', {\n        describe: 'Framework version to use',\n        alias: 'f',\n        type: 'string',\n      })\n      .options('toolkit-lib-version', {\n        describe: 'Toolkit lib version to use',\n        alias: 'l',\n        type: 'string',\n      })\n      .options('cdk-assets-version', {\n        describe: 'cdk-assets version to use.',\n        alias: 'a',\n        type: 'string',\n      })\n      .option('use-source', {\n        descripton: 'Use TypeScript packages from the given source repository (or \"auto\")',\n        type: 'string',\n        requiresArg: true,\n        deprecated: 'Use --cli-source instead',\n      })\n      .option('use-cli-release', {\n        descripton: 'Run the current tests against the CLI at the given version',\n        alias: 'u',\n        type: 'string',\n        requiresArg: true,\n        deprecated: 'Use --cli-version instead',\n      })\n      .option('auto-source', {\n        alias: 'a',\n        describe: 'Automatically find the source tree from the current working directory',\n        type: 'boolean',\n        requiresArg: false,\n        deprecated: 'Use --use-source=auto instead',\n      })\n      /////////////////////////////////////////////////////////////////////////////\n      //  Test running flags\n      .option('runInBand', {\n        descripton: 'Run all tests in one Node process',\n        alias: 'i',\n        type: 'boolean',\n      })\n      .option('test', {\n        descripton: 'Test pattern to selectively run tests',\n        alias: 't',\n        type: 'string',\n        requiresArg: true,\n      })\n      .option('test-file', {\n        describe: 'The specific test file to run',\n        alias: 'F',\n        type: 'string',\n        requiresArg: true,\n      })\n      .options('verbose', {\n        alias: 'v',\n        describe: 'Run in verbose mode',\n        type: 'boolean',\n        requiresArg: false,\n      })\n      .options('passWithNoTests', {\n        describe: 'Allow passing if the test suite is not found (default true when IS_CANARY mode, false otherwise)',\n        type: 'boolean',\n        requiresArg: false,\n      })\n      .options('maxWorkers', {\n        alias: 'w',\n        describe: 'Specifies the maximum number of workers the worker-pool will spawn for running tests. We use a sensible default for running cli integ tests.',\n        type: 'string',\n        requiresArg: true,\n      }), () => {\n    },\n    )\n    .strict()\n    .parse();\n\n  const suiteName = args.SUITENAME;\n\n  // So many ways to specify this, and with various ways to spell the same flag (o_O)\n  // Also, some of them depend on each other for convenience.\n  const cliSource = new UniqueOption<IRunnerSource<ITestCliSource>>('CLI version');\n  const cdkAssetsSource = new UniqueOption<IRunnerSource<ITestCliSource>>('cdk-assets version');\n\n  // Specific CLI version\n  for (const flagAlias of ['cli-version', 'use-cli-release'] as const) {\n    if (args[flagAlias]) {\n      cliSource.set(new RunnerCliNpmSource(CLI_PACKAGE_NAME, args[flagAlias]), `--${flagAlias}`);\n    }\n  }\n\n  // Specific cdk-assets version\n  if (args['cdk-assets-version']) {\n    cdkAssetsSource.set(new RunnerCliNpmSource(CDK_ASSETS_PACKAGE_NAME, args['cdk-assets-version']), '--cdk-assets-version');\n  }\n\n  // Specifically use a source location\n  for (const flagAlias of ['cli-source', 'use-source'] as const) {\n    if (args[flagAlias]) {\n      const root = args[flagAlias] === 'auto' ? await autoFindRepoRoot() : args[flagAlias];\n      cliSource.set(new RunnerCliRepoSource(CLI_PACKAGE_NAME, root), `--${flagAlias}`);\n      cdkAssetsSource.set(new RunnerCliRepoSource(CDK_ASSETS_PACKAGE_NAME, root), `--${flagAlias}`);\n    }\n  }\n\n  // Specifically request that a source location is given, or we didn't find a CLI yet.\n  // A CLI source is required, so if this fails that's alright.\n  if (args['auto-source'] || !cliSource.isSet()) {\n    cliSource.set(new RunnerCliRepoSource(CLI_PACKAGE_NAME, await autoFindRepoRoot()), '--auto-source');\n  }\n\n  // If the CLI is taken from the source, and cdk-assets is not set, we can copy the cdk-assets source from the CLI source.\n  if (!cdkAssetsSource.isSet()) {\n    const cliSrc = cliSource.assert();\n    if (cliSrc instanceof RunnerCliRepoSource) {\n      cdkAssetsSource.set(new RunnerCliRepoSource(CDK_ASSETS_PACKAGE_NAME, cliSrc.repoRoot), 'copied from CLI source');\n    }\n  }\n\n  // If cdk-assets is still not configured, fall back to the latest version that is available\n  if (!cdkAssetsSource.isSet()) {\n    cdkAssetsSource.set(new RunnerCliNpmSource(CDK_ASSETS_PACKAGE_NAME, 'latest'), '--cdk-assets-version not set');\n  }\n\n  // Library source is either the given one, or 'latest' (nice and simple)\n  const librarySource: IRunnerSource<ITestLibrarySource>\n    = new RunnerLibraryNpmSource('aws-cdk-lib', args['framework-version'] ? args['framework-version'] : 'latest');\n\n  // Toolkit lib source is either the given one, or the one that's being brought by 'package.json' already, or 'latest'\n  const toolkitLibPackage = '@aws-cdk/toolkit-lib';\n  let toolkitSource: IRunnerSource<ITestLibrarySource> | undefined;\n  if (args['toolkit-lib-version']) {\n    toolkitSource = new RunnerLibraryGlobalInstallSource(toolkitLibPackage, args['toolkit-lib-version']);\n  }\n  if (!toolkitSource) {\n    toolkitSource = await RunnerLibraryPreinstalledSource.isPreinstalled(toolkitLibPackage)\n      ? new RunnerLibraryPreinstalledSource(toolkitLibPackage)\n      : new RunnerLibraryGlobalInstallSource(toolkitLibPackage, 'latest');\n  }\n\n  console.log('------> Configuration');\n  console.log(`        Test suite:         ${suiteName}`);\n  console.log(`        Test version:       ${thisPackageVersion()}`);\n  console.log(`        CLI source:         ${cliSource.assert().sourceDescription}`);\n  console.log(`        Library source:     ${librarySource.sourceDescription}`);\n  console.log(`        Toolkit lib source: ${toolkitSource.sourceDescription}`);\n  console.log(`        cdk-assets source:  ${cdkAssetsSource.assert().sourceDescription}`);\n\n  if (args.verbose) {\n    process.env.VERBOSE = '1';\n  }\n\n  // Motivation behind this behavior: when adding a new test suite to the pipeline, because of the way our\n  // Pipeline package works, the suite would be added to the pipeline AND as a canary immediately. The canary\n  // would fail until the package was actually released, so for canaries we make an exception so that the initial\n  // canary would succeed even if the suite wasn't yet available. The fact that the suite is not optional in\n  // the pipeline protects us from typos.\n  const passWithNoTests = args.passWithNoTests ?? !!process.env.IS_CANARY;\n\n  // Communicate with the config file (integ.jest.config.js)\n  process.env.TEST_SUITE_NAME = suiteName;\n\n  const disposables = new Array<{ dispose(): Promise<void> }>();\n  try {\n    console.log('------> Resolved versions');\n    const cli = await cliSource.assert().runnerPrepare();\n    disposables.push(cli);\n    console.log(`        CLI:             ${cli.version}`);\n\n    const library = await librarySource.runnerPrepare();\n    disposables.push(library);\n    console.log(`        Library:         ${library.version}`);\n\n    const toolkitLib = await toolkitSource.runnerPrepare();\n    disposables.push(toolkitLib);\n    console.log(`        Toolkit library: ${toolkitLib.version}`);\n\n    const cdkAssets = await cdkAssetsSource.assert().runnerPrepare();\n    disposables.push(cdkAssets);\n    console.log(`        cdk-assets:      ${cdkAssets.version}`);\n\n    serializeSources({\n      cli,\n      library,\n      toolkitLib,\n      cdkAssets,\n    });\n\n    const jestConfig = path.resolve(__dirname, '..', '..', 'resources', 'integ.jest.config.js');\n\n    await jest.run([\n      '--randomize',\n      ...args.runInBand ? ['-i'] : [],\n      ...args.test ? ['-t', args.test] : [],\n      ...args.verbose ? ['--verbose'] : [],\n      ...args.maxWorkers ? [`--maxWorkers=${args.maxWorkers}`] : [],\n      ...passWithNoTests ? ['--passWithNoTests'] : [],\n      ...args['test-file'] ? [args['test-file']] : [],\n    ], jestConfig);\n  } finally {\n    for (const disp of disposables) {\n      await disp.dispose();\n    }\n  }\n}\n\nclass UniqueOption<A> {\n  public value: A | undefined;\n  private source: string | undefined;\n\n  constructor(private readonly what: string) {\n  }\n\n  public isSet() {\n    return this.value !== undefined;\n  }\n\n  public assert(): A {\n    if (!this.value) {\n      throw new Error(`${this.what} not configured`);\n    }\n    return this.value;\n  }\n\n  public set(x: A, source: string) {\n    if (this.value) {\n      throw new Error(`${this.what}: ${source} already configured via ${this.source}`);\n    }\n    this.value = x;\n    this.source = source;\n  }\n}\n\nfunction thisPackageVersion(): string {\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  return require('../../package.json').version;\n}\n\nmain().catch(e => {\n  // eslint-disable-next-line no-console\n  console.error(e);\n  process.exitCode = 1;\n});\n"]}
|
|
257
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"run-suite.js","sourceRoot":"","sources":["run-suite.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-console */\nimport * as path from 'path';\nimport * as jest from 'jest';\nimport * as yargs from 'yargs';\nimport { RunnerCliNpmSource } from '../package-sources/cli-npm-source';\nimport { RunnerCliRepoSource } from '../package-sources/cli-repo-source';\nimport { autoFindRepoRoot } from '../package-sources/find-root';\nimport { RunnerLibraryGlobalInstallSource } from '../package-sources/library-globalinstall-source';\nimport { RunnerLibraryNpmSource } from '../package-sources/library-npm-source';\nimport { RunnerLibraryPreinstalledSource } from '../package-sources/library-preinstalled-source';\nimport type { IRunnerSource, ITestCliSource, ITestLibrarySource } from '../package-sources/source';\nimport { serializeSources } from '../package-sources/subprocess';\n\nconst CLI_PACKAGE_NAME = 'aws-cdk';\nconst CDK_ASSETS_PACKAGE_NAME = 'cdk-assets';\n\nasync function main() {\n  const args = await yargs\n    .command('* <SUITENAME>', 'default command', y => y\n      .positional('SUITENAME', {\n        describe: 'Name of the test suite to run',\n        type: 'string',\n        demandOption: true,\n      })\n      /////////////////////////////////////////////////////////////////////////////\n      //  Sources and versions\n      .options('cli-version', {\n        describe: 'CLI version to use.',\n        alias: 'c',\n        type: 'string',\n      })\n      .options('cli-source', {\n        describe: 'Root of aws-cdk-cli repository, or \"auto\".',\n        alias: 's',\n        type: 'string',\n      })\n      .options('framework-version', {\n        describe: 'Framework version to use',\n        alias: 'f',\n        type: 'string',\n      })\n      .options('toolkit-lib-version', {\n        describe: 'Toolkit lib version to use',\n        alias: 'l',\n        type: 'string',\n      })\n      .options('cdk-assets-version', {\n        describe: 'cdk-assets version to use.',\n        alias: 'a',\n        type: 'string',\n      })\n      .option('use-source', {\n        descripton: 'Use TypeScript packages from the given source repository (or \"auto\")',\n        type: 'string',\n        requiresArg: true,\n        deprecated: 'Use --cli-source instead',\n      })\n      .option('use-cli-release', {\n        descripton: 'Run the current tests against the CLI at the given version',\n        alias: 'u',\n        type: 'string',\n        requiresArg: true,\n        deprecated: 'Use --cli-version instead',\n      })\n      .option('auto-source', {\n        alias: 'a',\n        describe: 'Automatically find the source tree from the current working directory',\n        type: 'boolean',\n        requiresArg: false,\n        deprecated: 'Use --use-source=auto instead',\n      })\n      /////////////////////////////////////////////////////////////////////////////\n      //  Test running flags\n      .option('runInBand', {\n        descripton: 'Run all tests in one Node process',\n        alias: 'i',\n        type: 'boolean',\n      })\n      .option('test', {\n        descripton: 'Test pattern to selectively run tests',\n        alias: 't',\n        type: 'string',\n        requiresArg: true,\n      })\n      .option('test-file', {\n        describe: 'The specific test file to run',\n        alias: 'F',\n        type: 'string',\n        requiresArg: true,\n      })\n      .options('seed', {\n        describe: 'Set the seed value to replicate a test run',\n        type: 'string',\n        requiresArg: true,\n      })\n      .options('verbose', {\n        alias: 'v',\n        describe: 'Run in verbose mode',\n        type: 'boolean',\n        requiresArg: false,\n      })\n      .options('passWithNoTests', {\n        describe: 'Allow passing if the test suite is not found (default true when IS_CANARY mode, false otherwise)',\n        type: 'boolean',\n        requiresArg: false,\n      })\n      .options('maxWorkers', {\n        alias: 'w',\n        describe: 'Specifies the maximum number of workers the worker-pool will spawn for running tests. We use a sensible default for running cli integ tests.',\n        type: 'string',\n        requiresArg: true,\n      }), () => {\n    },\n    )\n    .strict()\n    .parse();\n\n  const suiteName = args.SUITENAME;\n\n  // So many ways to specify this, and with various ways to spell the same flag (o_O)\n  // Also, some of them depend on each other for convenience.\n  const cliSource = new UniqueOption<IRunnerSource<ITestCliSource>>('CLI version');\n  const cdkAssetsSource = new UniqueOption<IRunnerSource<ITestCliSource>>('cdk-assets version');\n\n  // Specific CLI version\n  for (const flagAlias of ['cli-version', 'use-cli-release'] as const) {\n    if (args[flagAlias]) {\n      cliSource.set(new RunnerCliNpmSource(CLI_PACKAGE_NAME, args[flagAlias]), `--${flagAlias}`);\n    }\n  }\n\n  // Specific cdk-assets version\n  if (args['cdk-assets-version']) {\n    cdkAssetsSource.set(new RunnerCliNpmSource(CDK_ASSETS_PACKAGE_NAME, args['cdk-assets-version']), '--cdk-assets-version');\n  }\n\n  // Specifically use a source location\n  for (const flagAlias of ['cli-source', 'use-source'] as const) {\n    if (args[flagAlias]) {\n      const root = args[flagAlias] === 'auto' ? await autoFindRepoRoot() : args[flagAlias];\n      cliSource.set(new RunnerCliRepoSource(CLI_PACKAGE_NAME, root), `--${flagAlias}`);\n      cdkAssetsSource.set(new RunnerCliRepoSource(CDK_ASSETS_PACKAGE_NAME, root), `--${flagAlias}`);\n    }\n  }\n\n  // Specifically request that a source location is given, or we didn't find a CLI yet.\n  // A CLI source is required, so if this fails that's alright.\n  if (args['auto-source'] || !cliSource.isSet()) {\n    cliSource.set(new RunnerCliRepoSource(CLI_PACKAGE_NAME, await autoFindRepoRoot()), '--auto-source');\n  }\n\n  // If the CLI is taken from the source, and cdk-assets is not set, we can copy the cdk-assets source from the CLI source.\n  if (!cdkAssetsSource.isSet()) {\n    const cliSrc = cliSource.assert();\n    if (cliSrc instanceof RunnerCliRepoSource) {\n      cdkAssetsSource.set(new RunnerCliRepoSource(CDK_ASSETS_PACKAGE_NAME, cliSrc.repoRoot), 'copied from CLI source');\n    }\n  }\n\n  // If cdk-assets is still not configured, fall back to the latest version that is available\n  if (!cdkAssetsSource.isSet()) {\n    cdkAssetsSource.set(new RunnerCliNpmSource(CDK_ASSETS_PACKAGE_NAME, 'latest'), '--cdk-assets-version not set');\n  }\n\n  // Library source is either the given one, or 'latest' (nice and simple)\n  const librarySource: IRunnerSource<ITestLibrarySource>\n    = new RunnerLibraryNpmSource('aws-cdk-lib', args['framework-version'] ? args['framework-version'] : 'latest');\n\n  // Toolkit lib source is either the given one, or the one that's being brought by 'package.json' already, or 'latest'\n  const toolkitLibPackage = '@aws-cdk/toolkit-lib';\n  let toolkitSource: IRunnerSource<ITestLibrarySource> | undefined;\n  if (args['toolkit-lib-version']) {\n    toolkitSource = new RunnerLibraryGlobalInstallSource(toolkitLibPackage, args['toolkit-lib-version']);\n  }\n  if (!toolkitSource) {\n    toolkitSource = await RunnerLibraryPreinstalledSource.isPreinstalled(toolkitLibPackage)\n      ? new RunnerLibraryPreinstalledSource(toolkitLibPackage)\n      : new RunnerLibraryGlobalInstallSource(toolkitLibPackage, 'latest');\n  }\n\n  console.log('------> Configuration');\n  console.log(`        Test suite:         ${suiteName}`);\n  console.log(`        Test version:       ${thisPackageVersion()}`);\n  console.log(`        CLI source:         ${cliSource.assert().sourceDescription}`);\n  console.log(`        Library source:     ${librarySource.sourceDescription}`);\n  console.log(`        Toolkit lib source: ${toolkitSource.sourceDescription}`);\n  console.log(`        cdk-assets source:  ${cdkAssetsSource.assert().sourceDescription}`);\n\n  if (args.verbose) {\n    process.env.VERBOSE = '1';\n  }\n\n  // Motivation behind this behavior: when adding a new test suite to the pipeline, because of the way our\n  // Pipeline package works, the suite would be added to the pipeline AND as a canary immediately. The canary\n  // would fail until the package was actually released, so for canaries we make an exception so that the initial\n  // canary would succeed even if the suite wasn't yet available. The fact that the suite is not optional in\n  // the pipeline protects us from typos.\n  const passWithNoTests = args.passWithNoTests ?? !!process.env.IS_CANARY;\n\n  // Communicate with the config file (integ.jest.config.js)\n  process.env.TEST_SUITE_NAME = suiteName;\n\n  const disposables = new Array<{ dispose(): Promise<void> }>();\n  try {\n    console.log('------> Resolved versions');\n    const cli = await cliSource.assert().runnerPrepare();\n    disposables.push(cli);\n    console.log(`        CLI:             ${cli.version}`);\n\n    const library = await librarySource.runnerPrepare();\n    disposables.push(library);\n    console.log(`        Library:         ${library.version}`);\n\n    const toolkitLib = await toolkitSource.runnerPrepare();\n    disposables.push(toolkitLib);\n    console.log(`        Toolkit library: ${toolkitLib.version}`);\n\n    const cdkAssets = await cdkAssetsSource.assert().runnerPrepare();\n    disposables.push(cdkAssets);\n    console.log(`        cdk-assets:      ${cdkAssets.version}`);\n\n    serializeSources({\n      cli,\n      library,\n      toolkitLib,\n      cdkAssets,\n    });\n\n    const jestConfig = path.resolve(__dirname, '..', '..', 'resources', 'integ.jest.config.js');\n\n    await jest.run([\n      '--randomize',\n      ...args.seed ? [`--seed=${args.seed}`] : [],\n      ...args.runInBand ? ['-i'] : [],\n      ...args.test ? ['-t', args.test] : [],\n      ...args.verbose ? ['--verbose'] : [],\n      ...args.maxWorkers ? [`--maxWorkers=${args.maxWorkers}`] : [],\n      ...passWithNoTests ? ['--passWithNoTests'] : [],\n      ...args['test-file'] ? [args['test-file']] : [],\n    ], jestConfig);\n  } finally {\n    for (const disp of disposables) {\n      await disp.dispose();\n    }\n  }\n}\n\nclass UniqueOption<A> {\n  public value: A | undefined;\n  private source: string | undefined;\n\n  constructor(private readonly what: string) {\n  }\n\n  public isSet() {\n    return this.value !== undefined;\n  }\n\n  public assert(): A {\n    if (!this.value) {\n      throw new Error(`${this.what} not configured`);\n    }\n    return this.value;\n  }\n\n  public set(x: A, source: string) {\n    if (this.value) {\n      throw new Error(`${this.what}: ${source} already configured via ${this.source}`);\n    }\n    this.value = x;\n    this.source = source;\n  }\n}\n\nfunction thisPackageVersion(): string {\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  return require('../../package.json').version;\n}\n\nmain().catch(e => {\n  // eslint-disable-next-line no-console\n  console.error(e);\n  process.exitCode = 1;\n});\n"]}
|
package/lib/with-aws.d.ts
CHANGED
|
@@ -8,10 +8,24 @@ export declare function atmospherePool(): string;
|
|
|
8
8
|
export type AwsContext = {
|
|
9
9
|
readonly aws: AwsClients;
|
|
10
10
|
};
|
|
11
|
+
export interface AwsContextOptions {
|
|
12
|
+
/**
|
|
13
|
+
* Request the test environment to be in one of these regions
|
|
14
|
+
*
|
|
15
|
+
* @default - all regions are possible
|
|
16
|
+
*/
|
|
17
|
+
readonly regions?: string[];
|
|
18
|
+
/**
|
|
19
|
+
* Do not bootstrap the env
|
|
20
|
+
*
|
|
21
|
+
* @default false
|
|
22
|
+
*/
|
|
23
|
+
readonly disableBootstrap?: boolean;
|
|
24
|
+
}
|
|
11
25
|
/**
|
|
12
26
|
* Higher order function to execute a block with an AWS client setup
|
|
13
27
|
*
|
|
14
28
|
* Allocate the next region from the REGION pool and dispose it afterwards.
|
|
15
29
|
*/
|
|
16
|
-
export declare function withAws<A extends TestContext>(block: (context: A & AwsContext & DisableBootstrapContext) => Promise<void>,
|
|
30
|
+
export declare function withAws<A extends TestContext>(block: (context: A & AwsContext & DisableBootstrapContext) => Promise<void>, options?: AwsContextOptions): (context: A) => Promise<void>;
|
|
17
31
|
export declare function regionPool(): ResourcePool;
|
package/lib/with-aws.js
CHANGED
|
@@ -31,14 +31,27 @@ function atmospherePool() {
|
|
|
31
31
|
*
|
|
32
32
|
* Allocate the next region from the REGION pool and dispose it afterwards.
|
|
33
33
|
*/
|
|
34
|
-
function withAws(block,
|
|
34
|
+
function withAws(block, options = {}) {
|
|
35
35
|
return async (context) => {
|
|
36
|
+
const disableBootstrap = options.disableBootstrap ?? false;
|
|
36
37
|
if (atmosphereEnabled()) {
|
|
37
38
|
const atmosphere = new cdk_atmosphere_client_1.AtmosphereClient(atmosphereEndpoint(), {
|
|
38
39
|
logStream: context.output,
|
|
39
40
|
});
|
|
41
|
+
const constraints = [];
|
|
42
|
+
if (options.regions) {
|
|
43
|
+
constraints.push({
|
|
44
|
+
type: 'region',
|
|
45
|
+
value: [...options.regions],
|
|
46
|
+
});
|
|
47
|
+
}
|
|
40
48
|
const start = Date.now();
|
|
41
|
-
const allocation = await atmosphere.acquire({
|
|
49
|
+
const allocation = await atmosphere.acquire({
|
|
50
|
+
pool: atmospherePool(),
|
|
51
|
+
requester: context.name,
|
|
52
|
+
timeoutSeconds: 60 * 30,
|
|
53
|
+
constraints,
|
|
54
|
+
});
|
|
42
55
|
let outcome = 'success';
|
|
43
56
|
context.reportWaitTime(Date.now() - start);
|
|
44
57
|
try {
|
|
@@ -116,4 +129,4 @@ async function sanityCheck(aws) {
|
|
|
116
129
|
}
|
|
117
130
|
}
|
|
118
131
|
let sanityChecked;
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-aws.js","sourceRoot":"","sources":["with-aws.ts"],"names":[],"mappings":"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","sourcesContent":["import { AtmosphereClient } from '@cdklabs/cdk-atmosphere-client';\nimport { AwsClients } from './aws';\nimport type { TestContext } from './integ-test';\nimport { ResourcePool } from './resource-pool';\nimport type { DisableBootstrapContext } from './with-cdk-app';\n\nexport function atmosphereEnabled(): boolean {\n  const enabled = process.env.CDK_INTEG_ATMOSPHERE_ENABLED;\n  return enabled === 'true' || enabled === '1';\n}\n\nexport function atmosphereEndpoint(): string {\n  const value = process.env.CDK_INTEG_ATMOSPHERE_ENDPOINT;\n  if (!value) {\n    throw new Error('CDK_INTEG_ATMOSPHERE_ENDPOINT is not defined');\n  }\n  return value;\n}\n\nexport function atmospherePool() {\n  const value = process.env.CDK_INTEG_ATMOSPHERE_POOL;\n  if (!value) {\n    throw new Error('CDK_INTEG_ATMOSPHERE_POOL is not defined');\n  }\n  return value;\n}\n\nexport type AwsContext = { readonly aws: AwsClients };\n\n/**\n * Higher order function to execute a block with an AWS client setup\n *\n * Allocate the next region from the REGION pool and dispose it afterwards.\n */\nexport function withAws<A extends TestContext>(\n  block: (context: A & AwsContext & DisableBootstrapContext) => Promise<void>,\n  disableBootstrap: boolean = false,\n): (context: A) => Promise<void> {\n  return async (context: A) => {\n    if (atmosphereEnabled()) {\n      const atmosphere = new AtmosphereClient(atmosphereEndpoint(), {\n        logStream: context.output,\n      });\n\n      const start = Date.now();\n      const allocation = await atmosphere.acquire({ pool: atmospherePool(), requester: context.name, timeoutSeconds: 60 * 30 });\n      let outcome = 'success';\n      context.reportWaitTime(Date.now() - start);\n\n      try {\n        const aws = await AwsClients.forIdentity(context.randomString, allocation.environment.region, {\n          accessKeyId: allocation.credentials.accessKeyId,\n          secretAccessKey: allocation.credentials.secretAccessKey,\n          sessionToken: allocation.credentials.sessionToken,\n          accountId: allocation.environment.account,\n        }, context.output);\n        await sanityCheck(aws);\n\n        try {\n          return await block({ ...context, disableBootstrap, aws });\n        } catch (e: any) {\n          outcome = 'failure';\n          throw e;\n        } finally {\n          await aws.dispose();\n        }\n      } finally {\n        await atmosphere.release(allocation.id, outcome);\n      }\n    } else {\n      return regionPool().using(async (region) => {\n        const aws = await AwsClients.forRegion(context.randomString, region, context.output);\n        try {\n          await sanityCheck(aws);\n\n          return await block({ ...context, disableBootstrap, aws });\n        } finally {\n          await aws.dispose();\n        }\n      });\n    }\n  };\n}\n\nlet _regionPool: undefined | ResourcePool;\nexport function regionPool(): ResourcePool {\n  if (_regionPool !== undefined) {\n    return _regionPool;\n  }\n\n  const REGIONS = process.env.AWS_REGIONS\n    ? process.env.AWS_REGIONS.split(',')\n    : [process.env.AWS_REGION ?? process.env.AWS_DEFAULT_REGION ?? 'us-east-1'];\n\n  _regionPool = ResourcePool.withResources('aws_regions', REGIONS);\n  return _regionPool;\n}\n\n/**\n * Perform a one-time quick sanity check that the AWS clients have properly configured credentials\n *\n * If we don't do this, calls are going to fail and they'll be retried and everything will take\n * forever before the user notices a simple misconfiguration.\n *\n * We can't check for the presence of environment variables since credentials could come from\n * anywhere, so do simple account retrieval.\n *\n * Only do it once per process.\n */\nasync function sanityCheck(aws: AwsClients) {\n  if (sanityChecked === undefined) {\n    try {\n      await aws.account();\n      sanityChecked = true;\n    } catch (e: any) {\n      sanityChecked = false;\n      throw new Error(`AWS credentials probably not configured, got error: ${e.message}`);\n    }\n  }\n  if (!sanityChecked) {\n    throw new Error('AWS credentials probably not configured, see previous error');\n  }\n}\nlet sanityChecked: boolean | undefined;\n"]}
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-aws.js","sourceRoot":"","sources":["with-aws.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Constraint } from '@cdklabs/cdk-atmosphere-client';\nimport { AtmosphereClient } from '@cdklabs/cdk-atmosphere-client';\nimport { AwsClients } from './aws';\nimport type { TestContext } from './integ-test';\nimport { ResourcePool } from './resource-pool';\nimport type { DisableBootstrapContext } from './with-cdk-app';\n\nexport function atmosphereEnabled(): boolean {\n  const enabled = process.env.CDK_INTEG_ATMOSPHERE_ENABLED;\n  return enabled === 'true' || enabled === '1';\n}\n\nexport function atmosphereEndpoint(): string {\n  const value = process.env.CDK_INTEG_ATMOSPHERE_ENDPOINT;\n  if (!value) {\n    throw new Error('CDK_INTEG_ATMOSPHERE_ENDPOINT is not defined');\n  }\n  return value;\n}\n\nexport function atmospherePool() {\n  const value = process.env.CDK_INTEG_ATMOSPHERE_POOL;\n  if (!value) {\n    throw new Error('CDK_INTEG_ATMOSPHERE_POOL is not defined');\n  }\n  return value;\n}\n\nexport type AwsContext = { readonly aws: AwsClients };\n\nexport interface AwsContextOptions {\n  /**\n   * Request the test environment to be in one of these regions\n   *\n   * @default - all regions are possible\n   */\n  readonly regions?: string[];\n\n  /**\n   * Do not bootstrap the env\n   *\n   * @default false\n   */\n  readonly disableBootstrap?: boolean;\n}\n\n/**\n * Higher order function to execute a block with an AWS client setup\n *\n * Allocate the next region from the REGION pool and dispose it afterwards.\n */\nexport function withAws<A extends TestContext>(\n  block: (context: A & AwsContext & DisableBootstrapContext) => Promise<void>,\n  options: AwsContextOptions = {},\n): (context: A) => Promise<void> {\n  return async (context: A) => {\n    const disableBootstrap = options.disableBootstrap ?? false;\n\n    if (atmosphereEnabled()) {\n      const atmosphere = new AtmosphereClient(atmosphereEndpoint(), {\n        logStream: context.output,\n      });\n\n      const constraints: Constraint[] = [];\n      if (options.regions) {\n        constraints.push({\n          type: 'region',\n          value: [...options.regions],\n        });\n      }\n\n      const start = Date.now();\n      const allocation = await atmosphere.acquire({\n        pool: atmospherePool(),\n        requester: context.name,\n        timeoutSeconds: 60 * 30,\n        constraints,\n      });\n      let outcome = 'success';\n      context.reportWaitTime(Date.now() - start);\n\n      try {\n        const aws = await AwsClients.forIdentity(context.randomString, allocation.environment.region, {\n          accessKeyId: allocation.credentials.accessKeyId,\n          secretAccessKey: allocation.credentials.secretAccessKey,\n          sessionToken: allocation.credentials.sessionToken,\n          accountId: allocation.environment.account,\n        }, context.output);\n        await sanityCheck(aws);\n\n        try {\n          return await block({ ...context, disableBootstrap, aws });\n        } catch (e: any) {\n          outcome = 'failure';\n          throw e;\n        } finally {\n          await aws.dispose();\n        }\n      } finally {\n        await atmosphere.release(allocation.id, outcome);\n      }\n    } else {\n      return regionPool().using(async (region) => {\n        const aws = await AwsClients.forRegion(context.randomString, region, context.output);\n        try {\n          await sanityCheck(aws);\n\n          return await block({ ...context, disableBootstrap, aws });\n        } finally {\n          await aws.dispose();\n        }\n      });\n    }\n  };\n}\n\nlet _regionPool: undefined | ResourcePool;\nexport function regionPool(): ResourcePool {\n  if (_regionPool !== undefined) {\n    return _regionPool;\n  }\n\n  const REGIONS = process.env.AWS_REGIONS\n    ? process.env.AWS_REGIONS.split(',')\n    : [process.env.AWS_REGION ?? process.env.AWS_DEFAULT_REGION ?? 'us-east-1'];\n\n  _regionPool = ResourcePool.withResources('aws_regions', REGIONS);\n  return _regionPool;\n}\n\n/**\n * Perform a one-time quick sanity check that the AWS clients have properly configured credentials\n *\n * If we don't do this, calls are going to fail and they'll be retried and everything will take\n * forever before the user notices a simple misconfiguration.\n *\n * We can't check for the presence of environment variables since credentials could come from\n * anywhere, so do simple account retrieval.\n *\n * Only do it once per process.\n */\nasync function sanityCheck(aws: AwsClients) {\n  if (sanityChecked === undefined) {\n    try {\n      await aws.account();\n      sanityChecked = true;\n    } catch (e: any) {\n      sanityChecked = false;\n      throw new Error(`AWS credentials probably not configured, got error: ${e.message}`);\n    }\n  }\n  if (!sanityChecked) {\n    throw new Error('AWS credentials probably not configured, see previous error');\n  }\n}\nlet sanityChecked: boolean | undefined;\n"]}
|
package/lib/with-cdk-app.d.ts
CHANGED
|
@@ -3,9 +3,15 @@ import type { TestContext } from './integ-test';
|
|
|
3
3
|
import type { ITestCliSource, ITestLibrarySource } from './package-sources/source';
|
|
4
4
|
import type { ShellOptions } from './shell';
|
|
5
5
|
import { ShellHelper } from './shell';
|
|
6
|
-
import type { AwsContext } from './with-aws';
|
|
6
|
+
import type { AwsContext, AwsContextOptions } from './with-aws';
|
|
7
7
|
export declare const DEFAULT_TEST_TIMEOUT_S: number;
|
|
8
8
|
export declare const EXTENDED_TEST_TIMEOUT_S: number;
|
|
9
|
+
export interface CdkAppContextOptions {
|
|
10
|
+
/**
|
|
11
|
+
* Configure the AWS context of the app.
|
|
12
|
+
*/
|
|
13
|
+
readonly aws?: AwsContextOptions;
|
|
14
|
+
}
|
|
9
15
|
/**
|
|
10
16
|
* Higher order function to execute a block with a CDK app fixture
|
|
11
17
|
*
|
|
@@ -29,10 +35,10 @@ export declare function withCdkMigrateApp(language: string, block: (context: Tes
|
|
|
29
35
|
* We could have put `withAws(withCdkApp(fixture => { /... actual test here.../ }))` in every
|
|
30
36
|
* test declaration but centralizing it is going to make it convenient to modify in the future.
|
|
31
37
|
*/
|
|
32
|
-
export declare function withDefaultFixture(block: (context: TestFixture) => Promise<void
|
|
33
|
-
export declare function withSpecificFixture(appName: string, block: (context: TestFixture) => Promise<void
|
|
34
|
-
export declare function withExtendedTimeoutFixture(block: (context: TestFixture) => Promise<void
|
|
35
|
-
export declare function withCDKMigrateFixture(language: string, block: (content: TestFixture) => Promise<void
|
|
38
|
+
export declare function withDefaultFixture(block: (context: TestFixture) => Promise<void>, options?: CdkAppContextOptions): (context: TestContext) => Promise<void>;
|
|
39
|
+
export declare function withSpecificFixture(appName: string, block: (context: TestFixture) => Promise<void>, options?: CdkAppContextOptions): (context: TestContext) => Promise<void>;
|
|
40
|
+
export declare function withExtendedTimeoutFixture(block: (context: TestFixture) => Promise<void>, options?: CdkAppContextOptions): (context: TestContext) => Promise<void>;
|
|
41
|
+
export declare function withCDKMigrateFixture(language: string, block: (content: TestFixture) => Promise<void>, options?: CdkAppContextOptions): (context: TestContext) => Promise<void>;
|
|
36
42
|
/**
|
|
37
43
|
* Retry wrapper that executes a test callback up to maxAttempts times
|
|
38
44
|
*
|
|
@@ -56,7 +62,7 @@ export interface DisableBootstrapContext {
|
|
|
56
62
|
* To be used in place of `withDefaultFixture` when the test
|
|
57
63
|
* should not create the default bootstrap stack
|
|
58
64
|
*/
|
|
59
|
-
export declare function withoutBootstrap(block: (context: TestFixture) => Promise<void
|
|
65
|
+
export declare function withoutBootstrap(block: (context: TestFixture) => Promise<void>, options?: CdkAppContextOptions): (context: TestContext) => Promise<void>;
|
|
60
66
|
export interface CdkCliOptions extends ShellOptions {
|
|
61
67
|
options?: string[];
|
|
62
68
|
neverRequireApproval?: boolean;
|
|
@@ -183,6 +189,10 @@ export declare class TestFixture extends ShellHelper {
|
|
|
183
189
|
* Use this if your test needs to directly pull images outside of a `cdk` or `cdk-assets` command.
|
|
184
190
|
*/
|
|
185
191
|
ecrPublicLogin(): Promise<void>;
|
|
192
|
+
/**
|
|
193
|
+
* @returns the captured output of the deploy command.
|
|
194
|
+
* !!! DO NOT assume this is the stack's ARN. It will contain other output. !!!
|
|
195
|
+
*/
|
|
186
196
|
cdkDeploy(stackNames: string | string[], options?: CdkCliOptions, skipStackRename?: boolean): Promise<string>;
|
|
187
197
|
cdkDeployCommandLine(stackNames: string | string[], options?: CdkCliOptions, skipStackRename?: boolean): string[];
|
|
188
198
|
cdkSynth(options?: CdkCliOptions): Promise<string>;
|