@aws-cdk/integ-runner 2.197.11 → 2.197.12
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/README.md +6 -0
- package/THIRD_PARTY_LICENSES +599 -0
- package/lib/cli.d.ts +2 -0
- package/lib/cli.d.ts.map +1 -1
- package/lib/cli.js +9 -1
- package/lib/engines/proxy-agent.d.ts +37 -0
- package/lib/engines/proxy-agent.d.ts.map +1 -0
- package/lib/engines/proxy-agent.js +57 -0
- package/lib/engines/toolkit-lib.d.ts +34 -2
- package/lib/engines/toolkit-lib.d.ts.map +1 -1
- package/lib/engines/toolkit-lib.js +27 -13
- package/lib/index.js +13 -5
- package/lib/runner/engine.d.ts.map +1 -1
- package/lib/runner/engine.js +3 -1
- package/lib/runner/runner-base.d.ts +12 -0
- package/lib/runner/runner-base.d.ts.map +1 -1
- package/lib/runner/runner-base.js +1 -1
- package/lib/workers/common.d.ts +12 -0
- package/lib/workers/common.d.ts.map +1 -1
- package/lib/workers/common.js +1 -1
- package/lib/workers/extract/extract_worker.d.ts.map +1 -1
- package/lib/workers/extract/extract_worker.js +5 -1
- package/lib/workers/extract/index.js +29155 -1286
- package/lib/workers/integ-test-worker.d.ts.map +1 -1
- package/lib/workers/integ-test-worker.js +3 -1
- package/lib/workers/integ-watch-worker.d.ts +2 -0
- package/lib/workers/integ-watch-worker.d.ts.map +1 -1
- package/lib/workers/integ-watch-worker.js +1 -1
- package/package.json +6 -5
package/lib/cli.d.ts
CHANGED
|
@@ -22,6 +22,8 @@ export declare function parseCliArgs(args?: string[]): {
|
|
|
22
22
|
watch: boolean;
|
|
23
23
|
strict: boolean;
|
|
24
24
|
unstable: string[];
|
|
25
|
+
proxy: (string | undefined);
|
|
26
|
+
caBundlePath: (string | undefined);
|
|
25
27
|
};
|
|
26
28
|
export declare function main(args: string[]): Promise<void>;
|
|
27
29
|
export declare function cli(args?: string[]): void;
|
package/lib/cli.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["cli.ts"],"names":[],"mappings":"AAkBA,wBAAgB,YAAY,CAAC,IAAI,GAAE,MAAM,EAAO;;
|
|
1
|
+
{"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["cli.ts"],"names":[],"mappings":"AAkBA,wBAAgB,YAAY,CAAC,IAAI,GAAE,MAAM,EAAO;;SA+E3B,CAAC,MAAM,GAAG,SAAS,CAAC;;;;;uBAKqB,OAAO;;aAExC,OAAO;;UAEb,OAAO;eACG,MAAM;qBACU,OAAO;;;WAG/B,OAAO;WACP,OAAO;YACD,OAAO;;;WAGb,OAAO;YACL,OAAO;;WAET,CAAC,MAAM,GAAG,SAAS,CAAC;kBACD,CAAC,MAAM,GAAG,SAAS,CAAC;EAE/D;AAED,wBAAsB,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,iBAYxC;AAuLD,wBAAgB,GAAG,CAAC,IAAI,GAAE,MAAM,EAA0B,QAIzD"}
|
package/lib/cli.js
CHANGED
|
@@ -53,6 +53,8 @@ function parseCliArgs(args = []) {
|
|
|
53
53
|
})
|
|
54
54
|
.option('app', { type: 'string', default: undefined, desc: 'The custom CLI command that will be used to run the test files. You can include {filePath} to specify where in the command the test file path should be inserted. Example: --app="python3.8 {filePath}".' })
|
|
55
55
|
.option('test-regex', { type: 'array', desc: 'Detect integration test files matching this JavaScript regex pattern. If used multiple times, all files matching any one of the patterns are detected.', default: [] })
|
|
56
|
+
.option('proxy', { type: 'string', desc: 'Use the indicated proxy. Will read from HTTPS_PROXY environment variable if not specified', requiresArg: true })
|
|
57
|
+
.option('ca-bundle-path', { type: 'string', desc: 'Path to CA certificate to use when validating HTTPS requests. Will read from AWS_CA_BUNDLE environment variable if not specified', requiresArg: true })
|
|
56
58
|
.option('unstable', { type: 'array', desc: `Opt-in to using unstable features. By using these flags you acknowledge that scope and API of unstable features may change without notice. Specify multiple times for each unstable feature you want to opt-in to. ${(0, unstable_features_1.availableFeaturesDescription)()}`, nargs: 1, default: [] })
|
|
57
59
|
.strict()
|
|
58
60
|
.parse(args);
|
|
@@ -108,6 +110,8 @@ function parseCliArgs(args = []) {
|
|
|
108
110
|
watch: argv.watch,
|
|
109
111
|
strict: argv.strict,
|
|
110
112
|
unstable: arrayFromYargs(argv.unstable) ?? [],
|
|
113
|
+
proxy: argv.proxy,
|
|
114
|
+
caBundlePath: argv['ca-bundle-path'],
|
|
111
115
|
};
|
|
112
116
|
}
|
|
113
117
|
async function main(args) {
|
|
@@ -181,6 +185,8 @@ async function run(options) {
|
|
|
181
185
|
verbosity: options.verbosity,
|
|
182
186
|
updateWorkflow: options.updateWorkflow,
|
|
183
187
|
watch: options.watch,
|
|
188
|
+
proxy: options.proxy,
|
|
189
|
+
caBundlePath: options.caBundlePath,
|
|
184
190
|
});
|
|
185
191
|
testsSucceeded = success;
|
|
186
192
|
if (options.clean === false) {
|
|
@@ -200,6 +206,8 @@ async function run(options) {
|
|
|
200
206
|
...testsToRun[0],
|
|
201
207
|
profile: options.profiles ? options.profiles[0] : undefined,
|
|
202
208
|
region: options.testRegions[0],
|
|
209
|
+
proxy: options.proxy,
|
|
210
|
+
caBundlePath: options.caBundlePath,
|
|
203
211
|
});
|
|
204
212
|
}
|
|
205
213
|
}
|
|
@@ -304,4 +312,4 @@ function configFromFile(fileName) {
|
|
|
304
312
|
function splitByComma(xs) {
|
|
305
313
|
return xs.flatMap(x => x.split(',')).map(x => x.trim());
|
|
306
314
|
}
|
|
307
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["cli.ts"],"names":[],"mappings":"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","sourcesContent":["// Exercise all integ stacks and if they deploy, update the expected synth files\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as chalk from 'chalk';\nimport * as workerpool from 'workerpool';\nimport * as logger from './logger';\nimport type { IntegTest, IntegTestInfo } from './runner/integration-tests';\nimport { IntegrationTests } from './runner/integration-tests';\nimport { processUnstableFeatures, availableFeaturesDescription } from './unstable-features';\nimport type { IntegRunnerMetrics, IntegTestWorkerConfig, DestructiveChange } from './workers';\nimport { runSnapshotTests, runIntegrationTests } from './workers';\nimport { watchIntegrationTest } from './workers/integ-watch-worker';\n\n// https://github.com/yargs/yargs/issues/1929\n// https://github.com/evanw/esbuild/issues/1492\n// eslint-disable-next-line @typescript-eslint/no-require-imports\nconst yargs = require('yargs');\n\nexport function parseCliArgs(args: string[] = []) {\n  const argv = yargs\n    .usage('Usage: integ-runner [TEST...]')\n    .option('config', {\n      config: true,\n      configParser: configFromFile,\n      default: 'integ.config.json',\n      desc: 'Load options from a JSON config file. Options provided as CLI arguments take precedent.',\n    })\n    .option('watch', { type: 'boolean', default: false, desc: 'Perform integ tests in watch mode' })\n    .option('list', { type: 'boolean', default: false, desc: 'List tests instead of running them' })\n    .option('clean', { type: 'boolean', default: true, desc: 'Clean up and delete stack after test is completed (use --no-clean to negate)' })\n    .option('verbose', { type: 'boolean', default: false, alias: 'v', count: true, desc: 'Verbose logs and metrics on integration tests durations (specify multiple times to increase verbosity)' })\n    .option('dry-run', { type: 'boolean', default: false, desc: 'do not actually deploy the stack. just update the snapshot (not recommended!)' })\n    .option('update-on-failed', { type: 'boolean', default: false, desc: 'rerun integration tests and update snapshots for failed tests.' })\n    .option('force', { type: 'boolean', default: false, desc: 'Rerun all integration tests even if tests are passing' })\n    .option('parallel-regions', { type: 'array', desc: 'Tests are run in parallel across these regions. To prevent tests from running in parallel, provide only a single region', default: [], coerce: splitByComma })\n    .options('directory', { type: 'string', default: 'test', desc: 'starting directory to discover integration tests. Tests will be discovered recursively from this directory' })\n    .options('profiles', { type: 'array', desc: 'list of AWS profiles to use. Tests will be run in parallel across each profile+regions', default: [], coerce: splitByComma })\n    .options('max-workers', { type: 'number', desc: 'The max number of workerpool workers to use when running integration tests in parallel', default: 16 })\n    .options('exclude', { type: 'boolean', desc: 'Run all tests in the directory, except the specified TESTs', default: false })\n    .option('strict', { type: 'boolean', default: false, desc: 'Fail if any specified tests are not found' })\n    .options('from-file', { type: 'string', desc: 'Read TEST names from a file (one TEST per line)' })\n    .option('inspect-failures', { type: 'boolean', desc: 'Keep the integ test cloud assembly if a failure occurs for inspection', default: false })\n    .option('disable-update-workflow', { type: 'boolean', default: undefined, desc: 'DEPRECATED, use --[no]-update-workflow instead' })\n    .option('update-workflow', { type: 'boolean', default: undefined, desc: 'Deploys the committed snapshot before the updated application. Only works if snapshots are region-agnostic.' })\n    .option('language', {\n      alias: 'l',\n      default: ['javascript', 'typescript', 'python', 'go'],\n      choices: ['javascript', 'typescript', 'python', 'go'],\n      type: 'array',\n      nargs: 1,\n      desc: 'Use these presets to run integration tests for the selected languages',\n    })\n    .option('app', { type: 'string', default: undefined, desc: 'The custom CLI command that will be used to run the test files. You can include {filePath} to specify where in the command the test file path should be inserted. Example: --app=\"python3.8 {filePath}\".' })\n    .option('test-regex', { type: 'array', desc: 'Detect integration test files matching this JavaScript regex pattern. If used multiple times, all files matching any one of the patterns are detected.', default: [] })\n    .option('unstable', { type: 'array', desc: `Opt-in to using unstable features. By using these flags you acknowledge that scope and API of unstable features may change without notice. Specify multiple times for each unstable feature you want to opt-in to. ${availableFeaturesDescription()}`, nargs: 1, default: [] })\n    .strict()\n    .parse(args);\n\n  const tests: string[] = argv._;\n  const parallelRegions = arrayFromYargs(argv['parallel-regions']);\n  const testRegions: string[] = parallelRegions ?? ['us-east-1', 'us-east-2', 'us-west-2'];\n  const profiles = arrayFromYargs(argv.profiles);\n  const fromFile: string | undefined = argv['from-file'];\n  const maxWorkers: number = argv['max-workers'];\n  const verbosity: number = argv.verbose;\n  const verbose: boolean = verbosity >= 1;\n\n  const numTests = testRegions.length * (profiles ?? [1]).length;\n  if (maxWorkers < numTests) {\n    logger.warning('You are attempting to run %s tests in parallel, but only have %s workers. Not all of your profiles+regions will be utilized', numTests, maxWorkers);\n  }\n\n  if (tests.length > 0 && fromFile) {\n    throw new Error('A list of tests cannot be provided if \"--from-file\" is provided');\n  }\n\n  if (argv.strict && argv.exclude) {\n    throw new Error('Cannot use --strict with --exclude');\n  }\n\n  const requestedTests = fromFile\n    ? (fs.readFileSync(fromFile, { encoding: 'utf8' }))\n      .split('\\n')\n      .filter(x => x)\n      .filter(x => !x.startsWith('#'))\n    : (tests.length > 0 ? tests : undefined); // 'undefined' means no request\n\n  if (argv['disable-update-workflow'] !== undefined && argv['update-workflow'] !== undefined) {\n    throw new Error('--disable-update-workflow and --[no-]update-workflow cannot be used together');\n  }\n\n  let updateWorkflow = argv['update-workflow'] !== undefined ? !!argv['update-workflow'] : !argv['disable-update-workflow'];\n\n  return {\n    tests: requestedTests,\n    app: argv.app as (string | undefined),\n    testRegex: arrayFromYargs(argv['test-regex']),\n    testRegions,\n    originalRegions: parallelRegions,\n    profiles,\n    runUpdateOnFailed: (argv['update-on-failed'] ?? false) as boolean,\n    fromFile,\n    exclude: argv.exclude as boolean,\n    maxWorkers,\n    list: argv.list as boolean,\n    directory: argv.directory as string,\n    inspectFailures: argv['inspect-failures'] as boolean,\n    verbosity,\n    verbose,\n    clean: argv.clean as boolean,\n    force: argv.force as boolean,\n    dryRun: argv['dry-run'] as boolean,\n    updateWorkflow,\n    language: arrayFromYargs(argv.language),\n    watch: argv.watch as boolean,\n    strict: argv.strict as boolean,\n    unstable: arrayFromYargs(argv.unstable) ?? [],\n  };\n}\n\nexport async function main(args: string[]) {\n  try {\n    const options = parseCliArgs(args);\n\n    // Process unstable features and emit appropriate warnings\n    options.unstable = processUnstableFeatures(options.unstable);\n\n    await run(options);\n  } catch (err: any) {\n    logger.error(err);\n    throw err;\n  }\n}\n\nasync function run(options: ReturnType<typeof parseCliArgs>) {\n  const testsFromArgs = await new IntegrationTests(path.resolve(options.directory)).fromCliOptions(options);\n\n  // List only prints the discovered tests\n  if (options.list) {\n    process.stdout.write(testsFromArgs.map(t => t.discoveryRelativeFileName).join('\\n') + '\\n');\n    return;\n  }\n\n  const pool = workerpool.pool(path.join(__dirname, '..', 'lib', 'workers', 'extract', 'index.js'), {\n    maxWorkers: options.watch ? 1 : options.maxWorkers,\n  });\n\n  const testsToRun: IntegTestWorkerConfig[] = [];\n  let destructiveChanges: boolean = false;\n  let failedSnapshots: IntegTestWorkerConfig[] = [];\n  let testsSucceeded = false;\n  validateWatchArgs({\n    ...options,\n    testRegions: options.originalRegions,\n    tests: testsFromArgs,\n  });\n\n  try {\n    if (!options.watch) {\n      // always run snapshot tests, but if '--force' is passed then\n      // run integration tests on all failed tests, not just those that\n      // failed snapshot tests\n      failedSnapshots = await runSnapshotTests(pool, testsFromArgs, {\n        retain: options.inspectFailures,\n        verbose: options.verbose,\n      });\n      for (const failure of failedSnapshots) {\n        logger.warning(`Failed: ${failure.fileName}`);\n        if (failure.destructiveChanges && failure.destructiveChanges.length > 0) {\n          printDestructiveChanges(failure.destructiveChanges);\n          destructiveChanges = true;\n        }\n      }\n      if (!options.force) {\n        testsToRun.push(...failedSnapshots);\n      } else {\n        // if any of the test failed snapshot tests, keep those results\n        // and merge with the rest of the tests from args\n        testsToRun.push(...mergeTests(testsFromArgs.map(t => t.info), failedSnapshots));\n      }\n    } else {\n      testsToRun.push(...testsFromArgs.map(t => t.info));\n    }\n\n    // run integration tests if `--update-on-failed` OR `--force` is used\n    if (options.runUpdateOnFailed || options.force) {\n      const { success, metrics } = await runIntegrationTests({\n        pool,\n        tests: testsToRun,\n        regions: options.testRegions,\n        profiles: options.profiles,\n        clean: options.clean,\n        dryRun: options.dryRun,\n        verbosity: options.verbosity,\n        updateWorkflow: options.updateWorkflow,\n        watch: options.watch,\n      });\n      testsSucceeded = success;\n\n      if (options.clean === false) {\n        logger.warning('Not cleaning up stacks since \"--no-clean\" was used');\n      }\n\n      if (Boolean(options.verbose)) {\n        printMetrics(metrics);\n      }\n\n      if (!success) {\n        throw new Error('Some integration tests failed!');\n      }\n    } else if (options.watch) {\n      await watchIntegrationTest(pool, {\n        watch: true,\n        verbosity: options.verbosity,\n        ...testsToRun[0],\n        profile: options.profiles ? options.profiles[0] : undefined,\n        region: options.testRegions[0],\n      });\n    }\n  } finally {\n    void pool.terminate();\n  }\n\n  if (destructiveChanges) {\n    throw new Error('Some changes were destructive!');\n  }\n  if (failedSnapshots.length > 0) {\n    let message = '';\n    if (!options.runUpdateOnFailed) {\n      message = 'To re-run failed tests run: integ-runner --update-on-failed';\n    }\n    if (!testsSucceeded) {\n      throw new Error(`Some tests failed!\\n${message}`);\n    }\n  }\n}\n\nfunction validateWatchArgs(args: {\n  tests: IntegTest[];\n  testRegions?: string[];\n  profiles?: string[];\n  maxWorkers: number;\n  force: boolean;\n  dryRun: boolean;\n  updateWorkflow: boolean;\n  runUpdateOnFailed: boolean;\n  watch: boolean;\n}) {\n  if (args.watch) {\n    if (\n      (args.testRegions && args.testRegions.length > 1)\n        || (args.profiles && args.profiles.length > 1)\n        || args.tests.length > 1) {\n      throw new Error('Running with watch only supports a single test. Only provide a single option'+\n        'to `--profiles` `--parallel-regions` `--max-workers');\n    }\n\n    if (args.runUpdateOnFailed || args.updateWorkflow || args.force || args.dryRun) {\n      logger.warning('args `--update-on-failed`, `--update-workflow`, `--force`, `--dry-run` have no effect when running with `--watch`');\n    }\n  }\n}\n\nfunction printDestructiveChanges(changes: DestructiveChange[]): void {\n  if (changes.length > 0) {\n    logger.warning('!!! This test contains %s !!!', chalk.bold('destructive changes'));\n    changes.forEach(change => {\n      logger.warning('    Stack: %s - Resource: %s - Impact: %s', change.stackName, change.logicalId, change.impact);\n    });\n    logger.warning('!!! If these destructive changes are necessary, please indicate this on the PR !!!');\n  }\n}\n\nfunction printMetrics(metrics: IntegRunnerMetrics[]): void {\n  logger.highlight('   --- Integration test metrics ---');\n  const sortedMetrics = metrics.sort((a, b) => a.duration - b.duration);\n  sortedMetrics.forEach(metric => {\n    logger.print('Profile %s + Region %s total time: %s', metric.profile, metric.region, metric.duration);\n    const sortedTests = Object.entries(metric.tests).sort((a, b) => a[1] - b[1]);\n    sortedTests.forEach(test => logger.print('  %s: %s', test[0], test[1]));\n  });\n}\n\n/**\n * Translate a Yargs input array to something that makes more sense in a programming language\n * model (telling the difference between absence and an empty array)\n *\n * - An empty array is the default case, meaning the user didn't pass any arguments. We return\n *   undefined.\n * - If the user passed a single empty string, they did something like `--array=`, which we'll\n *   take to mean they passed an empty array.\n */\nfunction arrayFromYargs(xs: string[]): string[] | undefined {\n  if (xs.length === 0) {\n    return undefined;\n  }\n  return xs.filter(x => x !== '');\n}\n\n/**\n * Merge the tests we received from command line arguments with\n * tests that failed snapshot tests. The failed snapshot tests have additional\n * information that we want to keep so this should override any test from args\n */\nfunction mergeTests(testFromArgs: IntegTestInfo[], failedSnapshotTests: IntegTestWorkerConfig[]): IntegTestWorkerConfig[] {\n  const failedTestNames = new Set(failedSnapshotTests.map(test => test.fileName));\n  const final: IntegTestWorkerConfig[] = failedSnapshotTests;\n  final.push(...testFromArgs.filter(test => !failedTestNames.has(test.fileName)));\n  return final;\n}\n\nexport function cli(args: string[] = process.argv.slice(2)) {\n  main(args).then().catch(() => {\n    process.exitCode = 1;\n  });\n}\n\n/**\n * Read CLI options from a config file if provided.\n *\n * @returns parsed CLI config options\n */\nfunction configFromFile(fileName?: string): Record<string, any> {\n  if (!fileName) {\n    return {};\n  }\n\n  try {\n    return JSON.parse(fs.readFileSync(fileName, { encoding: 'utf-8' }));\n  } catch {\n    return {};\n  }\n}\n\n/**\n * Coerce function for yargs array options to support comma-separated values.\n * Yargs doesn't natively split `--option=a,b,c` into ['a', 'b', 'c'].\n */\nfunction splitByComma(xs: string[]): string[] {\n  return xs.flatMap(x => x.split(',')).map(x => x.trim());\n}\n"]}
|
|
315
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["cli.ts"],"names":[],"mappings":"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","sourcesContent":["// Exercise all integ stacks and if they deploy, update the expected synth files\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as chalk from 'chalk';\nimport * as workerpool from 'workerpool';\nimport * as logger from './logger';\nimport type { IntegTest, IntegTestInfo } from './runner/integration-tests';\nimport { IntegrationTests } from './runner/integration-tests';\nimport { processUnstableFeatures, availableFeaturesDescription } from './unstable-features';\nimport type { IntegRunnerMetrics, IntegTestWorkerConfig, DestructiveChange } from './workers';\nimport { runSnapshotTests, runIntegrationTests } from './workers';\nimport { watchIntegrationTest } from './workers/integ-watch-worker';\n\n// https://github.com/yargs/yargs/issues/1929\n// https://github.com/evanw/esbuild/issues/1492\n// eslint-disable-next-line @typescript-eslint/no-require-imports\nconst yargs = require('yargs');\n\nexport function parseCliArgs(args: string[] = []) {\n  const argv = yargs\n    .usage('Usage: integ-runner [TEST...]')\n    .option('config', {\n      config: true,\n      configParser: configFromFile,\n      default: 'integ.config.json',\n      desc: 'Load options from a JSON config file. Options provided as CLI arguments take precedent.',\n    })\n    .option('watch', { type: 'boolean', default: false, desc: 'Perform integ tests in watch mode' })\n    .option('list', { type: 'boolean', default: false, desc: 'List tests instead of running them' })\n    .option('clean', { type: 'boolean', default: true, desc: 'Clean up and delete stack after test is completed (use --no-clean to negate)' })\n    .option('verbose', { type: 'boolean', default: false, alias: 'v', count: true, desc: 'Verbose logs and metrics on integration tests durations (specify multiple times to increase verbosity)' })\n    .option('dry-run', { type: 'boolean', default: false, desc: 'do not actually deploy the stack. just update the snapshot (not recommended!)' })\n    .option('update-on-failed', { type: 'boolean', default: false, desc: 'rerun integration tests and update snapshots for failed tests.' })\n    .option('force', { type: 'boolean', default: false, desc: 'Rerun all integration tests even if tests are passing' })\n    .option('parallel-regions', { type: 'array', desc: 'Tests are run in parallel across these regions. To prevent tests from running in parallel, provide only a single region', default: [], coerce: splitByComma })\n    .options('directory', { type: 'string', default: 'test', desc: 'starting directory to discover integration tests. Tests will be discovered recursively from this directory' })\n    .options('profiles', { type: 'array', desc: 'list of AWS profiles to use. Tests will be run in parallel across each profile+regions', default: [], coerce: splitByComma })\n    .options('max-workers', { type: 'number', desc: 'The max number of workerpool workers to use when running integration tests in parallel', default: 16 })\n    .options('exclude', { type: 'boolean', desc: 'Run all tests in the directory, except the specified TESTs', default: false })\n    .option('strict', { type: 'boolean', default: false, desc: 'Fail if any specified tests are not found' })\n    .options('from-file', { type: 'string', desc: 'Read TEST names from a file (one TEST per line)' })\n    .option('inspect-failures', { type: 'boolean', desc: 'Keep the integ test cloud assembly if a failure occurs for inspection', default: false })\n    .option('disable-update-workflow', { type: 'boolean', default: undefined, desc: 'DEPRECATED, use --[no]-update-workflow instead' })\n    .option('update-workflow', { type: 'boolean', default: undefined, desc: 'Deploys the committed snapshot before the updated application. Only works if snapshots are region-agnostic.' })\n    .option('language', {\n      alias: 'l',\n      default: ['javascript', 'typescript', 'python', 'go'],\n      choices: ['javascript', 'typescript', 'python', 'go'],\n      type: 'array',\n      nargs: 1,\n      desc: 'Use these presets to run integration tests for the selected languages',\n    })\n    .option('app', { type: 'string', default: undefined, desc: 'The custom CLI command that will be used to run the test files. You can include {filePath} to specify where in the command the test file path should be inserted. Example: --app=\"python3.8 {filePath}\".' })\n    .option('test-regex', { type: 'array', desc: 'Detect integration test files matching this JavaScript regex pattern. If used multiple times, all files matching any one of the patterns are detected.', default: [] })\n    .option('proxy', { type: 'string', desc: 'Use the indicated proxy. Will read from HTTPS_PROXY environment variable if not specified', requiresArg: true })\n    .option('ca-bundle-path', { type: 'string', desc: 'Path to CA certificate to use when validating HTTPS requests. Will read from AWS_CA_BUNDLE environment variable if not specified', requiresArg: true })\n    .option('unstable', { type: 'array', desc: `Opt-in to using unstable features. By using these flags you acknowledge that scope and API of unstable features may change without notice. Specify multiple times for each unstable feature you want to opt-in to. ${availableFeaturesDescription()}`, nargs: 1, default: [] })\n    .strict()\n    .parse(args);\n\n  const tests: string[] = argv._;\n  const parallelRegions = arrayFromYargs(argv['parallel-regions']);\n  const testRegions: string[] = parallelRegions ?? ['us-east-1', 'us-east-2', 'us-west-2'];\n  const profiles = arrayFromYargs(argv.profiles);\n  const fromFile: string | undefined = argv['from-file'];\n  const maxWorkers: number = argv['max-workers'];\n  const verbosity: number = argv.verbose;\n  const verbose: boolean = verbosity >= 1;\n\n  const numTests = testRegions.length * (profiles ?? [1]).length;\n  if (maxWorkers < numTests) {\n    logger.warning('You are attempting to run %s tests in parallel, but only have %s workers. Not all of your profiles+regions will be utilized', numTests, maxWorkers);\n  }\n\n  if (tests.length > 0 && fromFile) {\n    throw new Error('A list of tests cannot be provided if \"--from-file\" is provided');\n  }\n\n  if (argv.strict && argv.exclude) {\n    throw new Error('Cannot use --strict with --exclude');\n  }\n\n  const requestedTests = fromFile\n    ? (fs.readFileSync(fromFile, { encoding: 'utf8' }))\n      .split('\\n')\n      .filter(x => x)\n      .filter(x => !x.startsWith('#'))\n    : (tests.length > 0 ? tests : undefined); // 'undefined' means no request\n\n  if (argv['disable-update-workflow'] !== undefined && argv['update-workflow'] !== undefined) {\n    throw new Error('--disable-update-workflow and --[no-]update-workflow cannot be used together');\n  }\n\n  let updateWorkflow = argv['update-workflow'] !== undefined ? !!argv['update-workflow'] : !argv['disable-update-workflow'];\n\n  return {\n    tests: requestedTests,\n    app: argv.app as (string | undefined),\n    testRegex: arrayFromYargs(argv['test-regex']),\n    testRegions,\n    originalRegions: parallelRegions,\n    profiles,\n    runUpdateOnFailed: (argv['update-on-failed'] ?? false) as boolean,\n    fromFile,\n    exclude: argv.exclude as boolean,\n    maxWorkers,\n    list: argv.list as boolean,\n    directory: argv.directory as string,\n    inspectFailures: argv['inspect-failures'] as boolean,\n    verbosity,\n    verbose,\n    clean: argv.clean as boolean,\n    force: argv.force as boolean,\n    dryRun: argv['dry-run'] as boolean,\n    updateWorkflow,\n    language: arrayFromYargs(argv.language),\n    watch: argv.watch as boolean,\n    strict: argv.strict as boolean,\n    unstable: arrayFromYargs(argv.unstable) ?? [],\n    proxy: argv.proxy as (string | undefined),\n    caBundlePath: argv['ca-bundle-path'] as (string | undefined),\n  };\n}\n\nexport async function main(args: string[]) {\n  try {\n    const options = parseCliArgs(args);\n\n    // Process unstable features and emit appropriate warnings\n    options.unstable = processUnstableFeatures(options.unstable);\n\n    await run(options);\n  } catch (err: any) {\n    logger.error(err);\n    throw err;\n  }\n}\n\nasync function run(options: ReturnType<typeof parseCliArgs>) {\n  const testsFromArgs = await new IntegrationTests(path.resolve(options.directory)).fromCliOptions(options);\n\n  // List only prints the discovered tests\n  if (options.list) {\n    process.stdout.write(testsFromArgs.map(t => t.discoveryRelativeFileName).join('\\n') + '\\n');\n    return;\n  }\n\n  const pool = workerpool.pool(path.join(__dirname, '..', 'lib', 'workers', 'extract', 'index.js'), {\n    maxWorkers: options.watch ? 1 : options.maxWorkers,\n  });\n\n  const testsToRun: IntegTestWorkerConfig[] = [];\n  let destructiveChanges: boolean = false;\n  let failedSnapshots: IntegTestWorkerConfig[] = [];\n  let testsSucceeded = false;\n  validateWatchArgs({\n    ...options,\n    testRegions: options.originalRegions,\n    tests: testsFromArgs,\n  });\n\n  try {\n    if (!options.watch) {\n      // always run snapshot tests, but if '--force' is passed then\n      // run integration tests on all failed tests, not just those that\n      // failed snapshot tests\n      failedSnapshots = await runSnapshotTests(pool, testsFromArgs, {\n        retain: options.inspectFailures,\n        verbose: options.verbose,\n      });\n      for (const failure of failedSnapshots) {\n        logger.warning(`Failed: ${failure.fileName}`);\n        if (failure.destructiveChanges && failure.destructiveChanges.length > 0) {\n          printDestructiveChanges(failure.destructiveChanges);\n          destructiveChanges = true;\n        }\n      }\n      if (!options.force) {\n        testsToRun.push(...failedSnapshots);\n      } else {\n        // if any of the test failed snapshot tests, keep those results\n        // and merge with the rest of the tests from args\n        testsToRun.push(...mergeTests(testsFromArgs.map(t => t.info), failedSnapshots));\n      }\n    } else {\n      testsToRun.push(...testsFromArgs.map(t => t.info));\n    }\n\n    // run integration tests if `--update-on-failed` OR `--force` is used\n    if (options.runUpdateOnFailed || options.force) {\n      const { success, metrics } = await runIntegrationTests({\n        pool,\n        tests: testsToRun,\n        regions: options.testRegions,\n        profiles: options.profiles,\n        clean: options.clean,\n        dryRun: options.dryRun,\n        verbosity: options.verbosity,\n        updateWorkflow: options.updateWorkflow,\n        watch: options.watch,\n        proxy: options.proxy,\n        caBundlePath: options.caBundlePath,\n      });\n      testsSucceeded = success;\n\n      if (options.clean === false) {\n        logger.warning('Not cleaning up stacks since \"--no-clean\" was used');\n      }\n\n      if (Boolean(options.verbose)) {\n        printMetrics(metrics);\n      }\n\n      if (!success) {\n        throw new Error('Some integration tests failed!');\n      }\n    } else if (options.watch) {\n      await watchIntegrationTest(pool, {\n        watch: true,\n        verbosity: options.verbosity,\n        ...testsToRun[0],\n        profile: options.profiles ? options.profiles[0] : undefined,\n        region: options.testRegions[0],\n        proxy: options.proxy,\n        caBundlePath: options.caBundlePath,\n      });\n    }\n  } finally {\n    void pool.terminate();\n  }\n\n  if (destructiveChanges) {\n    throw new Error('Some changes were destructive!');\n  }\n  if (failedSnapshots.length > 0) {\n    let message = '';\n    if (!options.runUpdateOnFailed) {\n      message = 'To re-run failed tests run: integ-runner --update-on-failed';\n    }\n    if (!testsSucceeded) {\n      throw new Error(`Some tests failed!\\n${message}`);\n    }\n  }\n}\n\nfunction validateWatchArgs(args: {\n  tests: IntegTest[];\n  testRegions?: string[];\n  profiles?: string[];\n  maxWorkers: number;\n  force: boolean;\n  dryRun: boolean;\n  updateWorkflow: boolean;\n  runUpdateOnFailed: boolean;\n  watch: boolean;\n}) {\n  if (args.watch) {\n    if (\n      (args.testRegions && args.testRegions.length > 1)\n        || (args.profiles && args.profiles.length > 1)\n        || args.tests.length > 1) {\n      throw new Error('Running with watch only supports a single test. Only provide a single option'+\n        'to `--profiles` `--parallel-regions` `--max-workers');\n    }\n\n    if (args.runUpdateOnFailed || args.updateWorkflow || args.force || args.dryRun) {\n      logger.warning('args `--update-on-failed`, `--update-workflow`, `--force`, `--dry-run` have no effect when running with `--watch`');\n    }\n  }\n}\n\nfunction printDestructiveChanges(changes: DestructiveChange[]): void {\n  if (changes.length > 0) {\n    logger.warning('!!! This test contains %s !!!', chalk.bold('destructive changes'));\n    changes.forEach(change => {\n      logger.warning('    Stack: %s - Resource: %s - Impact: %s', change.stackName, change.logicalId, change.impact);\n    });\n    logger.warning('!!! If these destructive changes are necessary, please indicate this on the PR !!!');\n  }\n}\n\nfunction printMetrics(metrics: IntegRunnerMetrics[]): void {\n  logger.highlight('   --- Integration test metrics ---');\n  const sortedMetrics = metrics.sort((a, b) => a.duration - b.duration);\n  sortedMetrics.forEach(metric => {\n    logger.print('Profile %s + Region %s total time: %s', metric.profile, metric.region, metric.duration);\n    const sortedTests = Object.entries(metric.tests).sort((a, b) => a[1] - b[1]);\n    sortedTests.forEach(test => logger.print('  %s: %s', test[0], test[1]));\n  });\n}\n\n/**\n * Translate a Yargs input array to something that makes more sense in a programming language\n * model (telling the difference between absence and an empty array)\n *\n * - An empty array is the default case, meaning the user didn't pass any arguments. We return\n *   undefined.\n * - If the user passed a single empty string, they did something like `--array=`, which we'll\n *   take to mean they passed an empty array.\n */\nfunction arrayFromYargs(xs: string[]): string[] | undefined {\n  if (xs.length === 0) {\n    return undefined;\n  }\n  return xs.filter(x => x !== '');\n}\n\n/**\n * Merge the tests we received from command line arguments with\n * tests that failed snapshot tests. The failed snapshot tests have additional\n * information that we want to keep so this should override any test from args\n */\nfunction mergeTests(testFromArgs: IntegTestInfo[], failedSnapshotTests: IntegTestWorkerConfig[]): IntegTestWorkerConfig[] {\n  const failedTestNames = new Set(failedSnapshotTests.map(test => test.fileName));\n  const final: IntegTestWorkerConfig[] = failedSnapshotTests;\n  final.push(...testFromArgs.filter(test => !failedTestNames.has(test.fileName)));\n  return final;\n}\n\nexport function cli(args: string[] = process.argv.slice(2)) {\n  main(args).then().catch(() => {\n    process.exitCode = 1;\n  });\n}\n\n/**\n * Read CLI options from a config file if provided.\n *\n * @returns parsed CLI config options\n */\nfunction configFromFile(fileName?: string): Record<string, any> {\n  if (!fileName) {\n    return {};\n  }\n\n  try {\n    return JSON.parse(fs.readFileSync(fileName, { encoding: 'utf-8' }));\n  } catch {\n    return {};\n  }\n}\n\n/**\n * Coerce function for yargs array options to support comma-separated values.\n * Yargs doesn't natively split `--option=a,b,c` into ['a', 'b', 'c'].\n */\nfunction splitByComma(xs: string[]): string[] {\n  return xs.flatMap(x => x.split(',')).map(x => x.trim());\n}\n"]}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { ProxyAgent } from 'proxy-agent';
|
|
2
|
+
/**
|
|
3
|
+
* Options for creating a proxy agent
|
|
4
|
+
*/
|
|
5
|
+
export interface ProxyAgentOptions {
|
|
6
|
+
/**
|
|
7
|
+
* Proxy address to use
|
|
8
|
+
*
|
|
9
|
+
* @default - ProxyAgent auto-detects from environment variables
|
|
10
|
+
*/
|
|
11
|
+
readonly proxyAddress?: string;
|
|
12
|
+
/**
|
|
13
|
+
* A path to a certificate bundle that contains a cert to be trusted.
|
|
14
|
+
*
|
|
15
|
+
* @default - reads from AWS_CA_BUNDLE environment variable
|
|
16
|
+
*/
|
|
17
|
+
readonly caBundlePath?: string;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Cached provider for proxy-aware HTTP agents.
|
|
21
|
+
*
|
|
22
|
+
* Reuses the same ProxyAgent instance for identical configurations
|
|
23
|
+
* to avoid creating multiple agents across engine instances.
|
|
24
|
+
*/
|
|
25
|
+
export declare class ProxyAgentProvider {
|
|
26
|
+
/**
|
|
27
|
+
* Get or create a ProxyAgent for the given options.
|
|
28
|
+
* Returns a cached instance if one already exists for the same configuration.
|
|
29
|
+
*/
|
|
30
|
+
static getOrCreate(options?: ProxyAgentOptions): ProxyAgent;
|
|
31
|
+
/**
|
|
32
|
+
* Clear the cache. Intended for testing only.
|
|
33
|
+
*/
|
|
34
|
+
static clearCache(): void;
|
|
35
|
+
private static readonly cache;
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=proxy-agent.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"proxy-agent.d.ts","sourceRoot":"","sources":["proxy-agent.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAEzC;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC;;;;OAIG;IACH,QAAQ,CAAC,YAAY,CAAC,EAAE,MAAM,CAAC;IAE/B;;;;OAIG;IACH,QAAQ,CAAC,YAAY,CAAC,EAAE,MAAM,CAAC;CAChC;AAED;;;;;GAKG;AACH,qBAAa,kBAAkB;IAC7B;;;OAGG;WACW,WAAW,CAAC,OAAO,GAAE,iBAAsB,GAAG,UAAU;IAqBtE;;OAEG;WACW,UAAU,IAAI,IAAI;IAIhC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAiC;CAC/D"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ProxyAgentProvider = void 0;
|
|
4
|
+
const fs = require("fs-extra");
|
|
5
|
+
const proxy_agent_1 = require("proxy-agent");
|
|
6
|
+
/**
|
|
7
|
+
* Cached provider for proxy-aware HTTP agents.
|
|
8
|
+
*
|
|
9
|
+
* Reuses the same ProxyAgent instance for identical configurations
|
|
10
|
+
* to avoid creating multiple agents across engine instances.
|
|
11
|
+
*/
|
|
12
|
+
class ProxyAgentProvider {
|
|
13
|
+
/**
|
|
14
|
+
* Get or create a ProxyAgent for the given options.
|
|
15
|
+
* Returns a cached instance if one already exists for the same configuration.
|
|
16
|
+
*/
|
|
17
|
+
static getOrCreate(options = {}) {
|
|
18
|
+
const key = JSON.stringify([options.proxyAddress, options.caBundlePath]);
|
|
19
|
+
const cached = ProxyAgentProvider.cache.get(key);
|
|
20
|
+
if (cached) {
|
|
21
|
+
return cached;
|
|
22
|
+
}
|
|
23
|
+
const getProxyForUrl = options.proxyAddress != null
|
|
24
|
+
? () => Promise.resolve(options.proxyAddress)
|
|
25
|
+
: undefined;
|
|
26
|
+
const agent = new proxy_agent_1.ProxyAgent({
|
|
27
|
+
ca: tryReadCaBundle(options.caBundlePath),
|
|
28
|
+
getProxyForUrl,
|
|
29
|
+
});
|
|
30
|
+
ProxyAgentProvider.cache.set(key, agent);
|
|
31
|
+
return agent;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Clear the cache. Intended for testing only.
|
|
35
|
+
*/
|
|
36
|
+
static clearCache() {
|
|
37
|
+
ProxyAgentProvider.cache.clear();
|
|
38
|
+
}
|
|
39
|
+
static cache = new Map();
|
|
40
|
+
}
|
|
41
|
+
exports.ProxyAgentProvider = ProxyAgentProvider;
|
|
42
|
+
/**
|
|
43
|
+
* Try to read a CA bundle from the given path, or from the AWS_CA_BUNDLE environment variable.
|
|
44
|
+
*/
|
|
45
|
+
function tryReadCaBundle(bundlePath) {
|
|
46
|
+
const resolvedPath = bundlePath ?? process.env.AWS_CA_BUNDLE ?? process.env.aws_ca_bundle;
|
|
47
|
+
if (!resolvedPath) {
|
|
48
|
+
return undefined;
|
|
49
|
+
}
|
|
50
|
+
try {
|
|
51
|
+
return fs.readFileSync(resolvedPath, 'utf-8');
|
|
52
|
+
}
|
|
53
|
+
catch {
|
|
54
|
+
return undefined;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJveHktYWdlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJwcm94eS1hZ2VudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwrQkFBK0I7QUFDL0IsNkNBQXlDO0FBcUJ6Qzs7Ozs7R0FLRztBQUNILE1BQWEsa0JBQWtCO0lBQzdCOzs7T0FHRztJQUNJLE1BQU0sQ0FBQyxXQUFXLENBQUMsVUFBNkIsRUFBRTtRQUN2RCxNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsT0FBTyxDQUFDLFlBQVksRUFBRSxPQUFPLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQztRQUV6RSxNQUFNLE1BQU0sR0FBRyxrQkFBa0IsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ2pELElBQUksTUFBTSxFQUFFLENBQUM7WUFDWCxPQUFPLE1BQU0sQ0FBQztRQUNoQixDQUFDO1FBRUQsTUFBTSxjQUFjLEdBQUcsT0FBTyxDQUFDLFlBQVksSUFBSSxJQUFJO1lBQ2pELENBQUMsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxZQUFhLENBQUM7WUFDOUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztRQUVkLE1BQU0sS0FBSyxHQUFHLElBQUksd0JBQVUsQ0FBQztZQUMzQixFQUFFLEVBQUUsZUFBZSxDQUFDLE9BQU8sQ0FBQyxZQUFZLENBQUM7WUFDekMsY0FBYztTQUNmLENBQUMsQ0FBQztRQUVILGtCQUFrQixDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ3pDLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVEOztPQUVHO0lBQ0ksTUFBTSxDQUFDLFVBQVU7UUFDdEIsa0JBQWtCLENBQUMsS0FBSyxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ25DLENBQUM7SUFFTyxNQUFNLENBQVUsS0FBSyxHQUFHLElBQUksR0FBRyxFQUFzQixDQUFDOztBQWpDaEUsZ0RBa0NDO0FBRUQ7O0dBRUc7QUFDSCxTQUFTLGVBQWUsQ0FBQyxVQUFtQjtJQUMxQyxNQUFNLFlBQVksR0FBRyxVQUFVLElBQUksT0FBTyxDQUFDLEdBQUcsQ0FBQyxhQUFhLElBQUksT0FBTyxDQUFDLEdBQUcsQ0FBQyxhQUFhLENBQUM7SUFDMUYsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBQ2xCLE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7SUFDRCxJQUFJLENBQUM7UUFDSCxPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ2hELENBQUM7SUFBQyxNQUFNLENBQUM7UUFDUCxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGZzIGZyb20gJ2ZzLWV4dHJhJztcbmltcG9ydCB7IFByb3h5QWdlbnQgfSBmcm9tICdwcm94eS1hZ2VudCc7XG5cbi8qKlxuICogT3B0aW9ucyBmb3IgY3JlYXRpbmcgYSBwcm94eSBhZ2VudFxuICovXG5leHBvcnQgaW50ZXJmYWNlIFByb3h5QWdlbnRPcHRpb25zIHtcbiAgLyoqXG4gICAqIFByb3h5IGFkZHJlc3MgdG8gdXNlXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gUHJveHlBZ2VudCBhdXRvLWRldGVjdHMgZnJvbSBlbnZpcm9ubWVudCB2YXJpYWJsZXNcbiAgICovXG4gIHJlYWRvbmx5IHByb3h5QWRkcmVzcz86IHN0cmluZztcblxuICAvKipcbiAgICogQSBwYXRoIHRvIGEgY2VydGlmaWNhdGUgYnVuZGxlIHRoYXQgY29udGFpbnMgYSBjZXJ0IHRvIGJlIHRydXN0ZWQuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gcmVhZHMgZnJvbSBBV1NfQ0FfQlVORExFIGVudmlyb25tZW50IHZhcmlhYmxlXG4gICAqL1xuICByZWFkb25seSBjYUJ1bmRsZVBhdGg/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogQ2FjaGVkIHByb3ZpZGVyIGZvciBwcm94eS1hd2FyZSBIVFRQIGFnZW50cy5cbiAqXG4gKiBSZXVzZXMgdGhlIHNhbWUgUHJveHlBZ2VudCBpbnN0YW5jZSBmb3IgaWRlbnRpY2FsIGNvbmZpZ3VyYXRpb25zXG4gKiB0byBhdm9pZCBjcmVhdGluZyBtdWx0aXBsZSBhZ2VudHMgYWNyb3NzIGVuZ2luZSBpbnN0YW5jZXMuXG4gKi9cbmV4cG9ydCBjbGFzcyBQcm94eUFnZW50UHJvdmlkZXIge1xuICAvKipcbiAgICogR2V0IG9yIGNyZWF0ZSBhIFByb3h5QWdlbnQgZm9yIHRoZSBnaXZlbiBvcHRpb25zLlxuICAgKiBSZXR1cm5zIGEgY2FjaGVkIGluc3RhbmNlIGlmIG9uZSBhbHJlYWR5IGV4aXN0cyBmb3IgdGhlIHNhbWUgY29uZmlndXJhdGlvbi5cbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgZ2V0T3JDcmVhdGUob3B0aW9uczogUHJveHlBZ2VudE9wdGlvbnMgPSB7fSk6IFByb3h5QWdlbnQge1xuICAgIGNvbnN0IGtleSA9IEpTT04uc3RyaW5naWZ5KFtvcHRpb25zLnByb3h5QWRkcmVzcywgb3B0aW9ucy5jYUJ1bmRsZVBhdGhdKTtcblxuICAgIGNvbnN0IGNhY2hlZCA9IFByb3h5QWdlbnRQcm92aWRlci5jYWNoZS5nZXQoa2V5KTtcbiAgICBpZiAoY2FjaGVkKSB7XG4gICAgICByZXR1cm4gY2FjaGVkO1xuICAgIH1cblxuICAgIGNvbnN0IGdldFByb3h5Rm9yVXJsID0gb3B0aW9ucy5wcm94eUFkZHJlc3MgIT0gbnVsbFxuICAgICAgPyAoKSA9PiBQcm9taXNlLnJlc29sdmUob3B0aW9ucy5wcm94eUFkZHJlc3MhKVxuICAgICAgOiB1bmRlZmluZWQ7XG5cbiAgICBjb25zdCBhZ2VudCA9IG5ldyBQcm94eUFnZW50KHtcbiAgICAgIGNhOiB0cnlSZWFkQ2FCdW5kbGUob3B0aW9ucy5jYUJ1bmRsZVBhdGgpLFxuICAgICAgZ2V0UHJveHlGb3JVcmwsXG4gICAgfSk7XG5cbiAgICBQcm94eUFnZW50UHJvdmlkZXIuY2FjaGUuc2V0KGtleSwgYWdlbnQpO1xuICAgIHJldHVybiBhZ2VudDtcbiAgfVxuXG4gIC8qKlxuICAgKiBDbGVhciB0aGUgY2FjaGUuIEludGVuZGVkIGZvciB0ZXN0aW5nIG9ubHkuXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGNsZWFyQ2FjaGUoKTogdm9pZCB7XG4gICAgUHJveHlBZ2VudFByb3ZpZGVyLmNhY2hlLmNsZWFyKCk7XG4gIH1cblxuICBwcml2YXRlIHN0YXRpYyByZWFkb25seSBjYWNoZSA9IG5ldyBNYXA8c3RyaW5nLCBQcm94eUFnZW50PigpO1xufVxuXG4vKipcbiAqIFRyeSB0byByZWFkIGEgQ0EgYnVuZGxlIGZyb20gdGhlIGdpdmVuIHBhdGgsIG9yIGZyb20gdGhlIEFXU19DQV9CVU5ETEUgZW52aXJvbm1lbnQgdmFyaWFibGUuXG4gKi9cbmZ1bmN0aW9uIHRyeVJlYWRDYUJ1bmRsZShidW5kbGVQYXRoPzogc3RyaW5nKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgY29uc3QgcmVzb2x2ZWRQYXRoID0gYnVuZGxlUGF0aCA/PyBwcm9jZXNzLmVudi5BV1NfQ0FfQlVORExFID8/IHByb2Nlc3MuZW52LmF3c19jYV9idW5kbGU7XG4gIGlmICghcmVzb2x2ZWRQYXRoKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuICB0cnkge1xuICAgIHJldHVybiBmcy5yZWFkRmlsZVN5bmMocmVzb2x2ZWRQYXRoLCAndXRmLTgnKTtcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxufVxuIl19
|
|
@@ -30,6 +30,35 @@ export interface ToolkitLibEngineOptions {
|
|
|
30
30
|
* @default - no profile is passed, the default profile is used
|
|
31
31
|
*/
|
|
32
32
|
readonly profile?: string;
|
|
33
|
+
/**
|
|
34
|
+
* Use the indicated proxy
|
|
35
|
+
*
|
|
36
|
+
* @default - no proxy, ProxyAgent auto-detects from environment variables
|
|
37
|
+
*/
|
|
38
|
+
readonly proxy?: string;
|
|
39
|
+
/**
|
|
40
|
+
* Path to CA certificate to use when validating HTTPS requests
|
|
41
|
+
*
|
|
42
|
+
* @default - no additional CA bundle
|
|
43
|
+
*/
|
|
44
|
+
readonly caBundlePath?: string;
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Per-action options that can override the engine defaults.
|
|
48
|
+
*/
|
|
49
|
+
export interface ActionOptions {
|
|
50
|
+
/**
|
|
51
|
+
* The AWS profile to use
|
|
52
|
+
*/
|
|
53
|
+
readonly profile?: string;
|
|
54
|
+
/**
|
|
55
|
+
* Use the indicated proxy
|
|
56
|
+
*/
|
|
57
|
+
readonly proxy?: string;
|
|
58
|
+
/**
|
|
59
|
+
* Path to CA certificate to use when validating HTTPS requests
|
|
60
|
+
*/
|
|
61
|
+
readonly caBundlePath?: string;
|
|
33
62
|
}
|
|
34
63
|
/**
|
|
35
64
|
* A runner engine powered directly by the toolkit-lib
|
|
@@ -39,11 +68,14 @@ export declare class ToolkitLibRunnerEngine implements ICdk {
|
|
|
39
68
|
private readonly options;
|
|
40
69
|
private readonly showOutput;
|
|
41
70
|
private readonly ioHost;
|
|
71
|
+
private readonly toolkitCache;
|
|
42
72
|
constructor(options: ToolkitLibEngineOptions);
|
|
43
73
|
/**
|
|
44
|
-
*
|
|
74
|
+
* Get or create a Toolkit instance for the given action options.
|
|
75
|
+
* Caches instances by their resolved configuration to avoid creating
|
|
76
|
+
* duplicate Toolkit instances for identical settings.
|
|
45
77
|
*/
|
|
46
|
-
private
|
|
78
|
+
private getOrCreateToolkit;
|
|
47
79
|
/**
|
|
48
80
|
* Synthesizes the CDK app
|
|
49
81
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"toolkit-lib.d.ts","sourceRoot":"","sources":["toolkit-lib.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAa,aAAa,EAAE,cAAc,EAAE,IAAI,EAAE,WAAW,EAAE,YAAY,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"toolkit-lib.d.ts","sourceRoot":"","sources":["toolkit-lib.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAa,aAAa,EAAE,cAAc,EAAE,IAAI,EAAE,WAAW,EAAE,YAAY,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAG5I,MAAM,WAAW,uBAAuB;IACtC;;OAEG;IACH,QAAQ,CAAC,gBAAgB,EAAE,MAAM,CAAC;IAElC;;;;;;OAMG;IACH,QAAQ,CAAC,GAAG,CAAC,EAAE;QAAE,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,CAAC;IAE1C;;;;OAIG;IACH,QAAQ,CAAC,UAAU,CAAC,EAAE,OAAO,CAAC;IAE9B;;OAEG;IACH,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IAExB;;;;OAIG;IACH,QAAQ,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IAE1B;;;;OAIG;IACH,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IAExB;;;;OAIG;IACH,QAAQ,CAAC,YAAY,CAAC,EAAE,MAAM,CAAC;CAChC;AAED;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B;;OAEG;IACH,QAAQ,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IAE1B;;OAEG;IACH,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IAExB;;OAEG;IACH,QAAQ,CAAC,YAAY,CAAC,EAAE,MAAM,CAAC;CAChC;AAED;;GAEG;AACH,qBAAa,sBAAuB,YAAW,IAAI;IACjD,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAU;IAClC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAA0B;IAClD,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAU;IACrC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAoB;IAC3C,OAAO,CAAC,QAAQ,CAAC,YAAY,CAA8B;gBAExC,OAAO,EAAE,uBAAuB;IAyBnD;;;;OAIG;IACH,OAAO,CAAC,kBAAkB;IA4B1B;;OAEG;IACU,KAAK,CAAC,OAAO,EAAE,YAAY;IAkCxC;;OAEG;IACU,IAAI,CAAC,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAU1D;;OAEG;IACU,MAAM,CAAC,OAAO,EAAE,aAAa;IAc1C;;OAEG;IACU,KAAK,CAAC,OAAO,EAAE,YAAY,EAAE,MAAM,CAAC,EAAE,WAAW;IA0B9D;;OAEG;IACU,OAAO,CAAC,OAAO,EAAE,cAAc;IAU5C;;OAEG;YACW,EAAE;IAoChB;;OAEG;IACH,OAAO,CAAC,aAAa;IAQrB;;;;;;;;;;;;;;;;;;;;;;OAsBG;YACW,cAAc;CA4B7B"}
|
|
@@ -58,6 +58,7 @@ const cloud_assembly_api_1 = require("@aws-cdk/cloud-assembly-api");
|
|
|
58
58
|
const toolkit_lib_1 = require("@aws-cdk/toolkit-lib");
|
|
59
59
|
const chalk = require("chalk");
|
|
60
60
|
const fs = require("fs-extra");
|
|
61
|
+
const proxy_agent_1 = require("./proxy-agent");
|
|
61
62
|
/**
|
|
62
63
|
* A runner engine powered directly by the toolkit-lib
|
|
63
64
|
*/
|
|
@@ -66,13 +67,14 @@ class ToolkitLibRunnerEngine {
|
|
|
66
67
|
options;
|
|
67
68
|
showOutput;
|
|
68
69
|
ioHost;
|
|
70
|
+
toolkitCache = new Map();
|
|
69
71
|
constructor(options) {
|
|
70
72
|
this.options = options;
|
|
71
73
|
this.showOutput = options.showOutput ?? false;
|
|
72
74
|
// We always create this for ourselves to emit warnings, but potentially
|
|
73
75
|
// don't pass it to the toolkit.
|
|
74
76
|
this.ioHost = new IntegRunnerIoHost();
|
|
75
|
-
this.toolkit = this.
|
|
77
|
+
this.toolkit = this.getOrCreateToolkit();
|
|
76
78
|
// @TODO - these options are currently available on the action calls
|
|
77
79
|
// but toolkit-lib needs them at the constructor level.
|
|
78
80
|
// Need to decide what to do with them.
|
|
@@ -81,27 +83,39 @@ class ToolkitLibRunnerEngine {
|
|
|
81
83
|
// - assemblyFailureAt: options.strict ?? options.ignoreErrors
|
|
82
84
|
// Logging
|
|
83
85
|
// - options.color
|
|
84
|
-
// SDK
|
|
85
|
-
// - options.proxy
|
|
86
|
-
// - options.caBundlePath
|
|
87
86
|
// @TODO - similar to the above, but in toolkit-lib these options would go on the IoHost
|
|
88
87
|
// - options.trace
|
|
89
88
|
// - options.verbose
|
|
90
89
|
// - options.json
|
|
91
90
|
}
|
|
92
91
|
/**
|
|
93
|
-
*
|
|
92
|
+
* Get or create a Toolkit instance for the given action options.
|
|
93
|
+
* Caches instances by their resolved configuration to avoid creating
|
|
94
|
+
* duplicate Toolkit instances for identical settings.
|
|
94
95
|
*/
|
|
95
|
-
|
|
96
|
-
|
|
96
|
+
getOrCreateToolkit(actionOptions) {
|
|
97
|
+
const profile = actionOptions?.profile ?? this.options.profile;
|
|
98
|
+
const proxy = actionOptions?.proxy ?? this.options.proxy;
|
|
99
|
+
const caBundlePath = actionOptions?.caBundlePath ?? this.options.caBundlePath;
|
|
100
|
+
const key = JSON.stringify([profile, proxy, caBundlePath]);
|
|
101
|
+
const cached = this.toolkitCache.get(key);
|
|
102
|
+
if (cached) {
|
|
103
|
+
return cached;
|
|
104
|
+
}
|
|
105
|
+
const toolkit = new toolkit_lib_1.Toolkit({
|
|
97
106
|
ioHost: this.showOutput ? this.ioHost : new NoopIoHost(),
|
|
98
107
|
sdkConfig: {
|
|
99
108
|
baseCredentials: toolkit_lib_1.BaseCredentials.awsCliCompatible({
|
|
100
109
|
profile,
|
|
101
|
-
defaultRegion: region,
|
|
110
|
+
defaultRegion: this.options.region,
|
|
102
111
|
}),
|
|
112
|
+
httpOptions: {
|
|
113
|
+
agent: proxy_agent_1.ProxyAgentProvider.getOrCreate({ proxyAddress: proxy, caBundlePath }),
|
|
114
|
+
},
|
|
103
115
|
},
|
|
104
116
|
});
|
|
117
|
+
this.toolkitCache.set(key, toolkit);
|
|
118
|
+
return toolkit;
|
|
105
119
|
}
|
|
106
120
|
/**
|
|
107
121
|
* Synthesizes the CDK app
|
|
@@ -155,7 +169,7 @@ class ToolkitLibRunnerEngine {
|
|
|
155
169
|
* Lists the stacks in the CDK app
|
|
156
170
|
*/
|
|
157
171
|
async list(options) {
|
|
158
|
-
const toolkit = this.
|
|
172
|
+
const toolkit = this.getOrCreateToolkit(options);
|
|
159
173
|
const cx = await this.cx(options);
|
|
160
174
|
const stacks = await toolkit.list(cx, {
|
|
161
175
|
stacks: this.stackSelector(options),
|
|
@@ -166,7 +180,7 @@ class ToolkitLibRunnerEngine {
|
|
|
166
180
|
* Deploys the CDK app
|
|
167
181
|
*/
|
|
168
182
|
async deploy(options) {
|
|
169
|
-
const toolkit = this.
|
|
183
|
+
const toolkit = this.getOrCreateToolkit(options);
|
|
170
184
|
const cx = await this.cx(options);
|
|
171
185
|
await toolkit.deploy(cx, {
|
|
172
186
|
roleArn: options.roleArn,
|
|
@@ -182,7 +196,7 @@ class ToolkitLibRunnerEngine {
|
|
|
182
196
|
* Watches the CDK app for changes and deploys them automatically
|
|
183
197
|
*/
|
|
184
198
|
async watch(options, events) {
|
|
185
|
-
const toolkit = this.
|
|
199
|
+
const toolkit = this.getOrCreateToolkit(options);
|
|
186
200
|
const cx = await this.cx(options);
|
|
187
201
|
try {
|
|
188
202
|
const watcher = await toolkit.watch(cx, {
|
|
@@ -210,7 +224,7 @@ class ToolkitLibRunnerEngine {
|
|
|
210
224
|
* Destroys the CDK app
|
|
211
225
|
*/
|
|
212
226
|
async destroy(options) {
|
|
213
|
-
const toolkit = this.
|
|
227
|
+
const toolkit = this.getOrCreateToolkit(options);
|
|
214
228
|
const cx = await this.cx(options);
|
|
215
229
|
await toolkit.destroy(cx, {
|
|
216
230
|
roleArn: options.roleArn,
|
|
@@ -351,4 +365,4 @@ class NoopIoHost {
|
|
|
351
365
|
return msg.defaultResponse;
|
|
352
366
|
}
|
|
353
367
|
}
|
|
354
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolkit-lib.js","sourceRoot":"","sources":["toolkit-lib.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'node:path';\nimport { UNKNOWN_REGION } from '@aws-cdk/cloud-assembly-api';\nimport type { DefaultCdkOptions } from '@aws-cdk/cloud-assembly-schema/lib/integ-tests';\nimport type { ICloudAssemblySource, IIoHost, IoMessage, IoRequest, IReadableCloudAssembly, NonInteractiveIoHostProps, StackSelector } from '@aws-cdk/toolkit-lib';\nimport { BaseCredentials, ExpandStackSelection, MemoryContext, NonInteractiveIoHost, StackSelectionStrategy, Toolkit } from '@aws-cdk/toolkit-lib';\nimport * as chalk from 'chalk';\nimport * as fs from 'fs-extra';\nimport type { CxOptions, DeployOptions, DestroyOptions, ICdk, ListOptions, SynthOptions, WatchEvents, WatchOptions } from './cdk-interface';\n\nexport interface ToolkitLibEngineOptions {\n  /**\n   * The directory to run the cdk commands from\n   */\n  readonly workingDirectory: string;\n\n  /**\n   * Additional environment variables to set\n   * in the execution environment that will be running\n   * the cdk app\n   *\n   * @default - no additional env vars\n   */\n  readonly env?: { [name: string]: string };\n\n  /**\n   * Show the output from running the CDK CLI\n   *\n   * @default false\n   */\n  readonly showOutput?: boolean;\n\n  /**\n   * The region the CDK app should synthesize itself for\n   */\n  readonly region: string;\n\n  /**\n   * The AWS profile to use when authenticating\n   *\n   * @default - no profile is passed, the default profile is used\n   */\n  readonly profile?: string;\n}\n\n/**\n * A runner engine powered directly by the toolkit-lib\n */\nexport class ToolkitLibRunnerEngine implements ICdk {\n  private readonly toolkit: Toolkit;\n  private readonly options: ToolkitLibEngineOptions;\n  private readonly showOutput: boolean;\n  private readonly ioHost: IntegRunnerIoHost;\n\n  public constructor(options: ToolkitLibEngineOptions) {\n    this.options = options;\n    this.showOutput = options.showOutput ?? false;\n\n    // We always create this for ourselves to emit warnings, but potentially\n    // don't pass it to the toolkit.\n    this.ioHost = new IntegRunnerIoHost();\n\n    this.toolkit = this.createToolkit(options.profile, options.region);\n\n    // @TODO - these options are currently available on the action calls\n    // but toolkit-lib needs them at the constructor level.\n    // Need to decide what to do with them.\n    //\n    // Validations\n    //  - assemblyFailureAt: options.strict ?? options.ignoreErrors\n    // Logging\n    //  - options.color\n    // SDK\n    //  - options.proxy\n    //  - options.caBundlePath\n\n    // @TODO - similar to the above, but in toolkit-lib these options would go on the IoHost\n    //  - options.trace\n    //  - options.verbose\n    //  - options.json\n  }\n\n  /**\n   * Creates a Toolkit instance with the given profile and region.\n   */\n  private createToolkit(profile: string | undefined, region: string): Toolkit {\n    return new Toolkit({\n      ioHost: this.showOutput ? this.ioHost : new NoopIoHost(),\n      sdkConfig: {\n        baseCredentials: BaseCredentials.awsCliCompatible({\n          profile,\n          defaultRegion: region,\n        }),\n      },\n    });\n  }\n\n  /**\n   * Synthesizes the CDK app\n   */\n  public async synth(options: SynthOptions) {\n    const cx = await this.cx({\n      app: options.app,\n      output: options.output,\n      context: options.context,\n      lookups: false,\n      resolveDefaultEnvironment: false,\n      env: options.env,\n      versionReporting: false,\n      pathMetadata: false,\n      assetMetadata: false,\n    });\n\n    try {\n      await using lock = await this.toolkit.synth(cx, {\n        validateStacks: false,\n        stacks: {\n          strategy: StackSelectionStrategy.ALL_STACKS,\n          failOnEmpty: false,\n        },\n      });\n      await this.validateRegion(lock);\n    } catch (e: any) {\n      if (e.message.includes('Missing context keys')) {\n        // @TODO - silently ignore missing context\n        // This is actually an undefined case in the old implementation, which doesn't use the toolkit code\n        // and won't fail for missing context. To preserve existing behavior, we do the same here.\n        // However in future we need to find a way for integ tests to provide context through snapshots.\n        return;\n      }\n      throw e;\n    }\n  }\n\n  /**\n   * Lists the stacks in the CDK app\n   */\n  public async list(options: ListOptions): Promise<string[]> {\n    const toolkit = this.createToolkit(options.profile ?? this.options.profile, this.options.region);\n    const cx = await this.cx(options);\n    const stacks = await toolkit.list(cx, {\n      stacks: this.stackSelector(options),\n    });\n\n    return stacks.map(s => s.name);\n  }\n\n  /**\n   * Deploys the CDK app\n   */\n  public async deploy(options: DeployOptions) {\n    const toolkit = this.createToolkit(options.profile ?? this.options.profile, this.options.region);\n    const cx = await this.cx(options);\n    await toolkit.deploy(cx, {\n      roleArn: options.roleArn,\n      traceLogs: options.traceLogs,\n      stacks: this.stackSelector(options),\n      deploymentMethod: {\n        method: 'change-set',\n      },\n      outputsFile: options.outputsFile ? path.join(this.options.workingDirectory, options.outputsFile) : undefined,\n    });\n  }\n\n  /**\n   * Watches the CDK app for changes and deploys them automatically\n   */\n  public async watch(options: WatchOptions, events?: WatchEvents) {\n    const toolkit = this.createToolkit(options.profile ?? this.options.profile, this.options.region);\n    const cx = await this.cx(options);\n    try {\n      const watcher = await toolkit.watch(cx, {\n        roleArn: options.roleArn,\n        traceLogs: options.traceLogs,\n        stacks: this.stackSelector(options),\n        deploymentMethod: options.deploymentMethod,\n      });\n      await watcher.waitForEnd();\n    } catch (e: unknown) {\n      if (events?.onStderr) {\n        events.onStderr(String(e));\n      }\n      if (events?.onClose) {\n        events.onClose(1);\n      }\n      return;\n    }\n\n    if (events?.onClose) {\n      events.onClose(0);\n    }\n  }\n\n  /**\n   * Destroys the CDK app\n   */\n  public async destroy(options: DestroyOptions) {\n    const toolkit = this.createToolkit(options.profile ?? this.options.profile, this.options.region);\n    const cx = await this.cx(options);\n\n    await toolkit.destroy(cx, {\n      roleArn: options.roleArn,\n      stacks: this.stackSelector(options),\n    });\n  }\n\n  /**\n   * Creates a Cloud Assembly Source from the provided options.\n   */\n  private async cx(options: CxOptions): Promise<ICloudAssemblySource> {\n    if (!options.app) {\n      throw new Error('No app provided');\n    }\n\n    // check if the app is a path to existing snapshot and then use it as an assembly directory\n    const potentialCxPath = path.join(this.options.workingDirectory, options.app);\n    if (fs.pathExistsSync(potentialCxPath) && fs.statSync(potentialCxPath).isDirectory()) {\n      return this.toolkit.fromAssemblyDirectory(potentialCxPath);\n    }\n\n    let outdir;\n    if (options.output) {\n      outdir = path.join(this.options.workingDirectory, options.output);\n    }\n\n    return this.toolkit.fromCdkApp(options.app, {\n      workingDirectory: this.options.workingDirectory,\n      outdir,\n      lookups: options.lookups,\n      contextStore: new MemoryContext(options.context),\n      resolveDefaultEnvironment: options.resolveDefaultEnvironment,\n      env: {\n        ...this.options.env,\n        ...options.env,\n      },\n      synthOptions: {\n        debug: options.debug,\n        versionReporting: options.versionReporting ?? false,\n        pathMetadata: options.pathMetadata ?? false,\n        assetMetadata: options.assetMetadata ?? false,\n        assetStaging: options.staging,\n      },\n    });\n  }\n\n  /**\n   * Creates a StackSelector from the provided options.\n   */\n  private stackSelector(options: DefaultCdkOptions & { readonly exclusively?: boolean }): StackSelector {\n    return {\n      strategy: options.all ? StackSelectionStrategy.ALL_STACKS : StackSelectionStrategy.PATTERN_MUST_MATCH,\n      patterns: options.stacks ?? ['**'],\n      expand: options.exclusively ? ExpandStackSelection.NONE : ExpandStackSelection.UPSTREAM,\n    };\n  }\n\n  /**\n   * Check that the regions for the stacks in the CloudAssembly match the regions requested on the engine\n   *\n   * This prevents misconfiguration of the integ test app. People tend to put:\n   *\n   * ```ts\n   * new Stack(app, 'Stack', {\n   *   env: {\n   *     region: 'some-region-that-suits-me',\n   *   }\n   * });\n   * ```\n   *\n   * Into their integ tests, instead of:\n   *\n   * ```ts\n   * {\n   *   region: process.env.CDK_DEFAULT_REGION,\n   * }\n   * ```\n   *\n   * This catches that misconfiguration.\n   */\n  private async validateRegion(asm: IReadableCloudAssembly): Promise<void> {\n    // this happens for existing snapshots, in that case nothing to check\n    if (this.options.region === UNKNOWN_REGION) {\n      return;\n    }\n\n    for (const stack of asm.cloudAssembly.stacksRecursively) {\n      if (stack.environment.region !== this.options.region && stack.environment.region !== UNKNOWN_REGION) {\n        this.ioHost.notify({\n          action: 'deploy',\n          code: 'CDK_RUNNER_W0000',\n          time: new Date(),\n          level: 'warn',\n          message: `Stack ${stack.displayName} synthesizes for region ${stack.environment.region}, even though ${this.options.region} was requested. Please configure \\`{ env: { region: process.env.CDK_DEFAULT_REGION, account: process.env.CDK_DEFAULT_ACCOUNT } }\\`, or use no env at all. Do not hardcode a region or account.`,\n          data: {\n            stackName: stack.displayName,\n            stackRegion: stack.environment.region,\n            requestedRegion: this.options.region,\n          },\n        }).catch((e) => {\n          if (e) {\n            // eslint-disable-next-line no-console\n            console.error(e);\n          }\n        });\n      }\n    }\n  }\n}\n\n/**\n * An IoHost used in the integ-runner to provide non-interactive output\n */\nclass IntegRunnerIoHost extends NonInteractiveIoHost {\n  public constructor(props: NonInteractiveIoHostProps = {}) {\n    super({\n      ...props,\n      isTTY: false,\n    });\n  }\n  public async notify(msg: IoMessage<unknown>): Promise<void> {\n    let color;\n    switch (msg.level) {\n      case 'error': color = chalk.red; break;\n      case 'warn': color = chalk.yellow; break;\n      default: color = chalk.gray;\n    }\n\n    return super.notify({\n      ...msg,\n      message: color(msg.message),\n    });\n  }\n}\n\n/**\n * An IoHost that doesn't do anything\n */\nclass NoopIoHost implements IIoHost {\n  public async notify(): Promise<void> {\n  }\n  public async requestResponse<T>(msg: IoRequest<unknown, T>): Promise<T> {\n    return msg.defaultResponse;\n  }\n}\n"]}
|
|
368
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolkit-lib.js","sourceRoot":"","sources":["toolkit-lib.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'node:path';\nimport { UNKNOWN_REGION } from '@aws-cdk/cloud-assembly-api';\nimport type { DefaultCdkOptions } from '@aws-cdk/cloud-assembly-schema/lib/integ-tests';\nimport type { ICloudAssemblySource, IIoHost, IoMessage, IoRequest, IReadableCloudAssembly, NonInteractiveIoHostProps, StackSelector } from '@aws-cdk/toolkit-lib';\nimport { BaseCredentials, ExpandStackSelection, MemoryContext, NonInteractiveIoHost, StackSelectionStrategy, Toolkit } from '@aws-cdk/toolkit-lib';\nimport * as chalk from 'chalk';\nimport * as fs from 'fs-extra';\nimport type { CxOptions, DeployOptions, DestroyOptions, ICdk, ListOptions, SynthOptions, WatchEvents, WatchOptions } from './cdk-interface';\nimport { ProxyAgentProvider } from './proxy-agent';\n\nexport interface ToolkitLibEngineOptions {\n  /**\n   * The directory to run the cdk commands from\n   */\n  readonly workingDirectory: string;\n\n  /**\n   * Additional environment variables to set\n   * in the execution environment that will be running\n   * the cdk app\n   *\n   * @default - no additional env vars\n   */\n  readonly env?: { [name: string]: string };\n\n  /**\n   * Show the output from running the CDK CLI\n   *\n   * @default false\n   */\n  readonly showOutput?: boolean;\n\n  /**\n   * The region the CDK app should synthesize itself for\n   */\n  readonly region: string;\n\n  /**\n   * The AWS profile to use when authenticating\n   *\n   * @default - no profile is passed, the default profile is used\n   */\n  readonly profile?: string;\n\n  /**\n   * Use the indicated proxy\n   *\n   * @default - no proxy, ProxyAgent auto-detects from environment variables\n   */\n  readonly proxy?: string;\n\n  /**\n   * Path to CA certificate to use when validating HTTPS requests\n   *\n   * @default - no additional CA bundle\n   */\n  readonly caBundlePath?: string;\n}\n\n/**\n * Per-action options that can override the engine defaults.\n */\nexport interface ActionOptions {\n  /**\n   * The AWS profile to use\n   */\n  readonly profile?: string;\n\n  /**\n   * Use the indicated proxy\n   */\n  readonly proxy?: string;\n\n  /**\n   * Path to CA certificate to use when validating HTTPS requests\n   */\n  readonly caBundlePath?: string;\n}\n\n/**\n * A runner engine powered directly by the toolkit-lib\n */\nexport class ToolkitLibRunnerEngine implements ICdk {\n  private readonly toolkit: Toolkit;\n  private readonly options: ToolkitLibEngineOptions;\n  private readonly showOutput: boolean;\n  private readonly ioHost: IntegRunnerIoHost;\n  private readonly toolkitCache = new Map<string, Toolkit>();\n\n  public constructor(options: ToolkitLibEngineOptions) {\n    this.options = options;\n    this.showOutput = options.showOutput ?? false;\n\n    // We always create this for ourselves to emit warnings, but potentially\n    // don't pass it to the toolkit.\n    this.ioHost = new IntegRunnerIoHost();\n\n    this.toolkit = this.getOrCreateToolkit();\n\n    // @TODO - these options are currently available on the action calls\n    // but toolkit-lib needs them at the constructor level.\n    // Need to decide what to do with them.\n    //\n    // Validations\n    //  - assemblyFailureAt: options.strict ?? options.ignoreErrors\n    // Logging\n    //  - options.color\n\n    // @TODO - similar to the above, but in toolkit-lib these options would go on the IoHost\n    //  - options.trace\n    //  - options.verbose\n    //  - options.json\n  }\n\n  /**\n   * Get or create a Toolkit instance for the given action options.\n   * Caches instances by their resolved configuration to avoid creating\n   * duplicate Toolkit instances for identical settings.\n   */\n  private getOrCreateToolkit(actionOptions?: ActionOptions): Toolkit {\n    const profile = actionOptions?.profile ?? this.options.profile;\n    const proxy = actionOptions?.proxy ?? this.options.proxy;\n    const caBundlePath = actionOptions?.caBundlePath ?? this.options.caBundlePath;\n    const key = JSON.stringify([profile, proxy, caBundlePath]);\n\n    const cached = this.toolkitCache.get(key);\n    if (cached) {\n      return cached;\n    }\n\n    const toolkit = new Toolkit({\n      ioHost: this.showOutput ? this.ioHost : new NoopIoHost(),\n      sdkConfig: {\n        baseCredentials: BaseCredentials.awsCliCompatible({\n          profile,\n          defaultRegion: this.options.region,\n        }),\n        httpOptions: {\n          agent: ProxyAgentProvider.getOrCreate({ proxyAddress: proxy, caBundlePath }),\n        },\n      },\n    });\n\n    this.toolkitCache.set(key, toolkit);\n    return toolkit;\n  }\n\n  /**\n   * Synthesizes the CDK app\n   */\n  public async synth(options: SynthOptions) {\n    const cx = await this.cx({\n      app: options.app,\n      output: options.output,\n      context: options.context,\n      lookups: false,\n      resolveDefaultEnvironment: false,\n      env: options.env,\n      versionReporting: false,\n      pathMetadata: false,\n      assetMetadata: false,\n    });\n\n    try {\n      await using lock = await this.toolkit.synth(cx, {\n        validateStacks: false,\n        stacks: {\n          strategy: StackSelectionStrategy.ALL_STACKS,\n          failOnEmpty: false,\n        },\n      });\n      await this.validateRegion(lock);\n    } catch (e: any) {\n      if (e.message.includes('Missing context keys')) {\n        // @TODO - silently ignore missing context\n        // This is actually an undefined case in the old implementation, which doesn't use the toolkit code\n        // and won't fail for missing context. To preserve existing behavior, we do the same here.\n        // However in future we need to find a way for integ tests to provide context through snapshots.\n        return;\n      }\n      throw e;\n    }\n  }\n\n  /**\n   * Lists the stacks in the CDK app\n   */\n  public async list(options: ListOptions): Promise<string[]> {\n    const toolkit = this.getOrCreateToolkit(options);\n    const cx = await this.cx(options);\n    const stacks = await toolkit.list(cx, {\n      stacks: this.stackSelector(options),\n    });\n\n    return stacks.map(s => s.name);\n  }\n\n  /**\n   * Deploys the CDK app\n   */\n  public async deploy(options: DeployOptions) {\n    const toolkit = this.getOrCreateToolkit(options);\n    const cx = await this.cx(options);\n    await toolkit.deploy(cx, {\n      roleArn: options.roleArn,\n      traceLogs: options.traceLogs,\n      stacks: this.stackSelector(options),\n      deploymentMethod: {\n        method: 'change-set',\n      },\n      outputsFile: options.outputsFile ? path.join(this.options.workingDirectory, options.outputsFile) : undefined,\n    });\n  }\n\n  /**\n   * Watches the CDK app for changes and deploys them automatically\n   */\n  public async watch(options: WatchOptions, events?: WatchEvents) {\n    const toolkit = this.getOrCreateToolkit(options);\n    const cx = await this.cx(options);\n    try {\n      const watcher = await toolkit.watch(cx, {\n        roleArn: options.roleArn,\n        traceLogs: options.traceLogs,\n        stacks: this.stackSelector(options),\n        deploymentMethod: options.deploymentMethod,\n      });\n      await watcher.waitForEnd();\n    } catch (e: unknown) {\n      if (events?.onStderr) {\n        events.onStderr(String(e));\n      }\n      if (events?.onClose) {\n        events.onClose(1);\n      }\n      return;\n    }\n\n    if (events?.onClose) {\n      events.onClose(0);\n    }\n  }\n\n  /**\n   * Destroys the CDK app\n   */\n  public async destroy(options: DestroyOptions) {\n    const toolkit = this.getOrCreateToolkit(options);\n    const cx = await this.cx(options);\n\n    await toolkit.destroy(cx, {\n      roleArn: options.roleArn,\n      stacks: this.stackSelector(options),\n    });\n  }\n\n  /**\n   * Creates a Cloud Assembly Source from the provided options.\n   */\n  private async cx(options: CxOptions): Promise<ICloudAssemblySource> {\n    if (!options.app) {\n      throw new Error('No app provided');\n    }\n\n    // check if the app is a path to existing snapshot and then use it as an assembly directory\n    const potentialCxPath = path.join(this.options.workingDirectory, options.app);\n    if (fs.pathExistsSync(potentialCxPath) && fs.statSync(potentialCxPath).isDirectory()) {\n      return this.toolkit.fromAssemblyDirectory(potentialCxPath);\n    }\n\n    let outdir;\n    if (options.output) {\n      outdir = path.join(this.options.workingDirectory, options.output);\n    }\n\n    return this.toolkit.fromCdkApp(options.app, {\n      workingDirectory: this.options.workingDirectory,\n      outdir,\n      lookups: options.lookups,\n      contextStore: new MemoryContext(options.context),\n      resolveDefaultEnvironment: options.resolveDefaultEnvironment,\n      env: {\n        ...this.options.env,\n        ...options.env,\n      },\n      synthOptions: {\n        debug: options.debug,\n        versionReporting: options.versionReporting ?? false,\n        pathMetadata: options.pathMetadata ?? false,\n        assetMetadata: options.assetMetadata ?? false,\n        assetStaging: options.staging,\n      },\n    });\n  }\n\n  /**\n   * Creates a StackSelector from the provided options.\n   */\n  private stackSelector(options: DefaultCdkOptions & { readonly exclusively?: boolean }): StackSelector {\n    return {\n      strategy: options.all ? StackSelectionStrategy.ALL_STACKS : StackSelectionStrategy.PATTERN_MUST_MATCH,\n      patterns: options.stacks ?? ['**'],\n      expand: options.exclusively ? ExpandStackSelection.NONE : ExpandStackSelection.UPSTREAM,\n    };\n  }\n\n  /**\n   * Check that the regions for the stacks in the CloudAssembly match the regions requested on the engine\n   *\n   * This prevents misconfiguration of the integ test app. People tend to put:\n   *\n   * ```ts\n   * new Stack(app, 'Stack', {\n   *   env: {\n   *     region: 'some-region-that-suits-me',\n   *   }\n   * });\n   * ```\n   *\n   * Into their integ tests, instead of:\n   *\n   * ```ts\n   * {\n   *   region: process.env.CDK_DEFAULT_REGION,\n   * }\n   * ```\n   *\n   * This catches that misconfiguration.\n   */\n  private async validateRegion(asm: IReadableCloudAssembly): Promise<void> {\n    // this happens for existing snapshots, in that case nothing to check\n    if (this.options.region === UNKNOWN_REGION) {\n      return;\n    }\n\n    for (const stack of asm.cloudAssembly.stacksRecursively) {\n      if (stack.environment.region !== this.options.region && stack.environment.region !== UNKNOWN_REGION) {\n        this.ioHost.notify({\n          action: 'deploy',\n          code: 'CDK_RUNNER_W0000',\n          time: new Date(),\n          level: 'warn',\n          message: `Stack ${stack.displayName} synthesizes for region ${stack.environment.region}, even though ${this.options.region} was requested. Please configure \\`{ env: { region: process.env.CDK_DEFAULT_REGION, account: process.env.CDK_DEFAULT_ACCOUNT } }\\`, or use no env at all. Do not hardcode a region or account.`,\n          data: {\n            stackName: stack.displayName,\n            stackRegion: stack.environment.region,\n            requestedRegion: this.options.region,\n          },\n        }).catch((e) => {\n          if (e) {\n            // eslint-disable-next-line no-console\n            console.error(e);\n          }\n        });\n      }\n    }\n  }\n}\n\n/**\n * An IoHost used in the integ-runner to provide non-interactive output\n */\nclass IntegRunnerIoHost extends NonInteractiveIoHost {\n  public constructor(props: NonInteractiveIoHostProps = {}) {\n    super({\n      ...props,\n      isTTY: false,\n    });\n  }\n  public async notify(msg: IoMessage<unknown>): Promise<void> {\n    let color;\n    switch (msg.level) {\n      case 'error': color = chalk.red; break;\n      case 'warn': color = chalk.yellow; break;\n      default: color = chalk.gray;\n    }\n\n    return super.notify({\n      ...msg,\n      message: color(msg.message),\n    });\n  }\n}\n\n/**\n * An IoHost that doesn't do anything\n */\nclass NoopIoHost implements IIoHost {\n  public async notify(): Promise<void> {\n  }\n  public async requestResponse<T>(msg: IoRequest<unknown, T>): Promise<T> {\n    return msg.defaultResponse;\n  }\n}\n"]}
|