@aws-cdk/integ-runner 2.193.0 → 2.193.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -25,6 +25,12 @@ export interface ToolkitLibEngineOptions {
25
25
  * The region the CDK app should synthesize itself for
26
26
  */
27
27
  readonly region: string;
28
+ /**
29
+ * The AWS profile to use when authenticating
30
+ *
31
+ * @default - no profile is passed, the default profile is used
32
+ */
33
+ readonly profile?: string;
28
34
  }
29
35
  /**
30
36
  * A runner engine powered directly by the toolkit-lib
@@ -20,6 +20,7 @@ class ToolkitLibRunnerEngine {
20
20
  ioHost: this.showOutput ? this.ioHost : new NoopIoHost(),
21
21
  sdkConfig: {
22
22
  baseCredentials: toolkit_lib_1.BaseCredentials.awsCliCompatible({
23
+ profile: options.profile,
23
24
  defaultRegion: options.region,
24
25
  }),
25
26
  },
@@ -303,4 +304,4 @@ class NoopIoHost {
303
304
  return msg.defaultResponse;
304
305
  }
305
306
  }
306
- //# 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 type { DeployOptions, ICdk, ListOptions, SynthFastOptions, SynthOptions, WatchEvents } from '@aws-cdk/cdk-cli-wrapper';\nimport type { DefaultCdkOptions, DestroyOptions } from '@aws-cdk/cloud-assembly-schema/lib/integ-tests';\nimport { UNKNOWN_REGION } from '@aws-cdk/cx-api';\nimport type { DeploymentMethod, 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';\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/**\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 = new Toolkit({\n      ioHost: this.showOutput ? this.ioHost : new NoopIoHost(),\n      sdkConfig: {\n        baseCredentials: BaseCredentials.awsCliCompatible({\n          defaultRegion: options.region,\n        }),\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.profile\n      //  - options.proxy\n      //  - options.caBundlePath\n    });\n\n    // @TODO - similar to the above, but in toolkit-lib these options would go on the IoHost\n    //  - options.quiet\n    //  - options.trace\n    //  - options.verbose\n    //  - options.json\n  }\n\n  /**\n   * Synthesizes the CDK app through the Toolkit\n   */\n  public async synth(options: SynthOptions) {\n    const cx = await this.cx(options);\n    const lock = await this.toolkit.synth(cx, {\n      stacks: this.stackSelector(options),\n      validateStacks: options.validation,\n    });\n    await this.validateRegion(lock);\n    await lock.dispose();\n  }\n\n  /**\n   * Synthesizes the CDK app quickly, by bypassing the Toolkit and just invoking the app command\n   */\n  public async synthFast(options: SynthFastOptions) {\n    const cx = await this.toolkit.fromCdkApp(options.execCmd.join(' '), {\n      workingDirectory: this.options.workingDirectory,\n      outdir: options.output ? path.join(this.options.workingDirectory, options.output) : undefined,\n      contextStore: new MemoryContext(options.context),\n      lookups: false,\n      resolveDefaultEnvironment: false,\n      env: {\n        ...this.options.env,\n        ...options.env,\n      },\n      synthOptions: {\n        versionReporting: false,\n        pathMetadata: false,\n        assetMetadata: false,\n      },\n    });\n\n    try {\n      // @TODO - use produce to mimic the current behavior more closely\n      const lock = await cx.produce();\n      await this.validateRegion(lock);\n      await lock.dispose();\n      // We should fix this once we have stabilized toolkit-lib as engine.\n      // What we really should do is this:\n      // const lock = await this.toolkit.synth(cx, {\n      //   validateStacks: false,\n      // });\n      // await lock.dispose();\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 persevere 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    // @TODO - existing list specific option, doesn't really make sense to support this in the context of integ-runner\n    //  - options.long\n\n    const cx = await this.cx(options);\n    const stacks = await this.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    // @TODO - existing deploy specific option, doesn't really make sense to support this in the context of integ-runner\n    //  - options.progress\n\n    if (options.watch) {\n      return this.watch(options);\n    }\n\n    const cx = await this.cx(options);\n    await this.toolkit.deploy(cx, {\n      roleArn: options.roleArn,\n      traceLogs: options.traceLogs,\n      stacks: this.stackSelector(options),\n      deploymentMethod: this.deploymentMethod(options),\n    });\n  }\n\n  /**\n   * Watches the CDK app for changes and deploys them automatically\n   */\n  public async watch(options: DeployOptions, events?: WatchEvents) {\n    const cx = await this.cx(options);\n    try {\n      const watcher = await this.toolkit.watch(cx, {\n        roleArn: options.roleArn,\n        traceLogs: options.traceLogs,\n        stacks: this.stackSelector(options),\n        deploymentMethod: this.deploymentMethod(options),\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 cx = await this.cx(options);\n\n    await this.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: DefaultCdkOptions): 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      env: this.options.env,\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   * Creates a DeploymentMethod from the provided options.\n   */\n  private deploymentMethod(options: DeployOptions): DeploymentMethod {\n    if (options.hotswap && options.hotswap !== 'full-deployment') {\n      return {\n        method: 'hotswap',\n        fallback: options.hotswap === 'fall-back' ? { method: 'change-set' } : undefined,\n      };\n    }\n\n    return {\n      method: options.deploymentMethod ?? 'change-set',\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) {\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"]}
307
+ //# 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 type { DeployOptions, ICdk, ListOptions, SynthFastOptions, SynthOptions, WatchEvents } from '@aws-cdk/cdk-cli-wrapper';\nimport type { DefaultCdkOptions, DestroyOptions } from '@aws-cdk/cloud-assembly-schema/lib/integ-tests';\nimport { UNKNOWN_REGION } from '@aws-cdk/cx-api';\nimport type { DeploymentMethod, 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';\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 = new Toolkit({\n      ioHost: this.showOutput ? this.ioHost : new NoopIoHost(),\n      sdkConfig: {\n        baseCredentials: BaseCredentials.awsCliCompatible({\n          profile: options.profile,\n          defaultRegion: options.region,\n        }),\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.profile\n      //  - options.proxy\n      //  - options.caBundlePath\n    });\n\n    // @TODO - similar to the above, but in toolkit-lib these options would go on the IoHost\n    //  - options.quiet\n    //  - options.trace\n    //  - options.verbose\n    //  - options.json\n  }\n\n  /**\n   * Synthesizes the CDK app through the Toolkit\n   */\n  public async synth(options: SynthOptions) {\n    const cx = await this.cx(options);\n    const lock = await this.toolkit.synth(cx, {\n      stacks: this.stackSelector(options),\n      validateStacks: options.validation,\n    });\n    await this.validateRegion(lock);\n    await lock.dispose();\n  }\n\n  /**\n   * Synthesizes the CDK app quickly, by bypassing the Toolkit and just invoking the app command\n   */\n  public async synthFast(options: SynthFastOptions) {\n    const cx = await this.toolkit.fromCdkApp(options.execCmd.join(' '), {\n      workingDirectory: this.options.workingDirectory,\n      outdir: options.output ? path.join(this.options.workingDirectory, options.output) : undefined,\n      contextStore: new MemoryContext(options.context),\n      lookups: false,\n      resolveDefaultEnvironment: false,\n      env: {\n        ...this.options.env,\n        ...options.env,\n      },\n      synthOptions: {\n        versionReporting: false,\n        pathMetadata: false,\n        assetMetadata: false,\n      },\n    });\n\n    try {\n      // @TODO - use produce to mimic the current behavior more closely\n      const lock = await cx.produce();\n      await this.validateRegion(lock);\n      await lock.dispose();\n      // We should fix this once we have stabilized toolkit-lib as engine.\n      // What we really should do is this:\n      // const lock = await this.toolkit.synth(cx, {\n      //   validateStacks: false,\n      // });\n      // await lock.dispose();\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 persevere 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    // @TODO - existing list specific option, doesn't really make sense to support this in the context of integ-runner\n    //  - options.long\n\n    const cx = await this.cx(options);\n    const stacks = await this.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    // @TODO - existing deploy specific option, doesn't really make sense to support this in the context of integ-runner\n    //  - options.progress\n\n    if (options.watch) {\n      return this.watch(options);\n    }\n\n    const cx = await this.cx(options);\n    await this.toolkit.deploy(cx, {\n      roleArn: options.roleArn,\n      traceLogs: options.traceLogs,\n      stacks: this.stackSelector(options),\n      deploymentMethod: this.deploymentMethod(options),\n    });\n  }\n\n  /**\n   * Watches the CDK app for changes and deploys them automatically\n   */\n  public async watch(options: DeployOptions, events?: WatchEvents) {\n    const cx = await this.cx(options);\n    try {\n      const watcher = await this.toolkit.watch(cx, {\n        roleArn: options.roleArn,\n        traceLogs: options.traceLogs,\n        stacks: this.stackSelector(options),\n        deploymentMethod: this.deploymentMethod(options),\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 cx = await this.cx(options);\n\n    await this.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: DefaultCdkOptions): 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      env: this.options.env,\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   * Creates a DeploymentMethod from the provided options.\n   */\n  private deploymentMethod(options: DeployOptions): DeploymentMethod {\n    if (options.hotswap && options.hotswap !== 'full-deployment') {\n      return {\n        method: 'hotswap',\n        fallback: options.hotswap === 'fall-back' ? { method: 'change-set' } : undefined,\n      };\n    }\n\n    return {\n      method: options.deploymentMethod ?? 'change-set',\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) {\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"]}
package/lib/index.js CHANGED
@@ -5571,6 +5571,9 @@ function printResults(diagnostic) {
5571
5571
  case "SNAPSHOT_FAILED" /* SNAPSHOT_FAILED */:
5572
5572
  error(" CHANGED %s %s\n%s", diagnostic.testName, chalk2.gray(`${diagnostic.duration}s`), indentLines(diagnostic.message, 6));
5573
5573
  break;
5574
+ case "TEST_WARNING" /* TEST_WARNING */:
5575
+ warning(" WARN %s %s\n%s", diagnostic.testName, chalk2.gray(`${diagnostic.duration}s`), indentLines(diagnostic.message, 6));
5576
+ break;
5574
5577
  case "SNAPSHOT_ERROR" /* SNAPSHOT_ERROR */:
5575
5578
  case "TEST_ERROR" /* TEST_ERROR */:
5576
5579
  error(" ERROR %s %s\n%s", diagnostic.testName, chalk2.gray(`${diagnostic.duration}s`), indentLines(diagnostic.message, 6));
@@ -11,6 +11,7 @@ function makeEngine(options) {
11
11
  showOutput: options.showOutput,
12
12
  env: options.env,
13
13
  region: options.region,
14
+ profile: options.profile,
14
15
  });
15
16
  case 'cli-wrapper':
16
17
  default:
@@ -25,4 +26,4 @@ function makeEngine(options) {
25
26
  });
26
27
  }
27
28
  }
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW5naW5lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZW5naW5lLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBY0EsZ0NBcUJDO0FBbENELDhEQUF5RDtBQUV6RCx3REFBZ0U7QUFXaEUsU0FBZ0IsVUFBVSxDQUFDLE9BQTJCO0lBQ3BELFFBQVEsT0FBTyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ3ZCLEtBQUssYUFBYTtZQUNoQixPQUFPLElBQUksb0NBQXNCLENBQUM7Z0JBQ2hDLGdCQUFnQixFQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsU0FBUztnQkFDeEMsVUFBVSxFQUFFLE9BQU8sQ0FBQyxVQUFVO2dCQUM5QixHQUFHLEVBQUUsT0FBTyxDQUFDLEdBQUc7Z0JBQ2hCLE1BQU0sRUFBRSxPQUFPLENBQUMsTUFBTTthQUN2QixDQUFDLENBQUM7UUFDTCxLQUFLLGFBQWEsQ0FBQztRQUNuQjtZQUNFLE9BQU8sSUFBSSwrQkFBYSxDQUFDO2dCQUN2QixTQUFTLEVBQUUsT0FBTyxDQUFDLElBQUksQ0FBQyxTQUFTO2dCQUNqQyxVQUFVLEVBQUUsT0FBTyxDQUFDLFVBQVU7Z0JBQzlCLEdBQUcsRUFBRTtvQkFDSCxHQUFHLE9BQU8sQ0FBQyxHQUFHO29CQUNkLHNEQUFzRDtvQkFDdEQsVUFBVSxFQUFFLE9BQU8sQ0FBQyxNQUFNO2lCQUMzQjthQUNGLENBQUMsQ0FBQztJQUNQLENBQUM7QUFDSCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBJQ2RrIH0gZnJvbSAnQGF3cy1jZGsvY2RrLWNsaS13cmFwcGVyJztcbmltcG9ydCB7IENka0NsaVdyYXBwZXIgfSBmcm9tICdAYXdzLWNkay9jZGstY2xpLXdyYXBwZXInO1xuaW1wb3J0IHR5cGUgeyBJbnRlZ1J1bm5lck9wdGlvbnMgfSBmcm9tICcuL3J1bm5lci1iYXNlJztcbmltcG9ydCB7IFRvb2xraXRMaWJSdW5uZXJFbmdpbmUgfSBmcm9tICcuLi9lbmdpbmVzL3Rvb2xraXQtbGliJztcblxuZXhwb3J0IGludGVyZmFjZSBFbmdpbmVPcHRpb25zIHtcbiAgLyoqXG4gICAqIFRoZSBDREsgVG9vbGtpdCBlbmdpbmUgdG8gYmUgdXNlZCBieSB0aGUgcnVubmVyLlxuICAgKlxuICAgKiBAZGVmYXVsdCBcImNsaS13cmFwcGVyXCJcbiAgICovXG4gIHJlYWRvbmx5IGVuZ2luZT86ICdjbGktd3JhcHBlcicgfCAndG9vbGtpdC1saWInO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbWFrZUVuZ2luZShvcHRpb25zOiBJbnRlZ1J1bm5lck9wdGlvbnMpOiBJQ2RrIHtcbiAgc3dpdGNoIChvcHRpb25zLmVuZ2luZSkge1xuICAgIGNhc2UgJ3Rvb2xraXQtbGliJzpcbiAgICAgIHJldHVybiBuZXcgVG9vbGtpdExpYlJ1bm5lckVuZ2luZSh7XG4gICAgICAgIHdvcmtpbmdEaXJlY3Rvcnk6IG9wdGlvbnMudGVzdC5kaXJlY3RvcnksXG4gICAgICAgIHNob3dPdXRwdXQ6IG9wdGlvbnMuc2hvd091dHB1dCxcbiAgICAgICAgZW52OiBvcHRpb25zLmVudixcbiAgICAgICAgcmVnaW9uOiBvcHRpb25zLnJlZ2lvbixcbiAgICAgIH0pO1xuICAgIGNhc2UgJ2NsaS13cmFwcGVyJzpcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIG5ldyBDZGtDbGlXcmFwcGVyKHtcbiAgICAgICAgZGlyZWN0b3J5OiBvcHRpb25zLnRlc3QuZGlyZWN0b3J5LFxuICAgICAgICBzaG93T3V0cHV0OiBvcHRpb25zLnNob3dPdXRwdXQsXG4gICAgICAgIGVudjoge1xuICAgICAgICAgIC4uLm9wdGlvbnMuZW52LFxuICAgICAgICAgIC8vIFRoZSBDREsgQ0xJIHdpbGwgaW50ZXJwcmV0IHRoaXMgYW5kIHVzZSBpdCB1c2VmdWxseVxuICAgICAgICAgIEFXU19SRUdJT046IG9wdGlvbnMucmVnaW9uLFxuICAgICAgICB9LFxuICAgICAgfSk7XG4gIH1cbn1cblxuIl19
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW5naW5lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZW5naW5lLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBY0EsZ0NBc0JDO0FBbkNELDhEQUF5RDtBQUV6RCx3REFBZ0U7QUFXaEUsU0FBZ0IsVUFBVSxDQUFDLE9BQTJCO0lBQ3BELFFBQVEsT0FBTyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ3ZCLEtBQUssYUFBYTtZQUNoQixPQUFPLElBQUksb0NBQXNCLENBQUM7Z0JBQ2hDLGdCQUFnQixFQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsU0FBUztnQkFDeEMsVUFBVSxFQUFFLE9BQU8sQ0FBQyxVQUFVO2dCQUM5QixHQUFHLEVBQUUsT0FBTyxDQUFDLEdBQUc7Z0JBQ2hCLE1BQU0sRUFBRSxPQUFPLENBQUMsTUFBTTtnQkFDdEIsT0FBTyxFQUFFLE9BQU8sQ0FBQyxPQUFPO2FBQ3pCLENBQUMsQ0FBQztRQUNMLEtBQUssYUFBYSxDQUFDO1FBQ25CO1lBQ0UsT0FBTyxJQUFJLCtCQUFhLENBQUM7Z0JBQ3ZCLFNBQVMsRUFBRSxPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVM7Z0JBQ2pDLFVBQVUsRUFBRSxPQUFPLENBQUMsVUFBVTtnQkFDOUIsR0FBRyxFQUFFO29CQUNILEdBQUcsT0FBTyxDQUFDLEdBQUc7b0JBQ2Qsc0RBQXNEO29CQUN0RCxVQUFVLEVBQUUsT0FBTyxDQUFDLE1BQU07aUJBQzNCO2FBQ0YsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IElDZGsgfSBmcm9tICdAYXdzLWNkay9jZGstY2xpLXdyYXBwZXInO1xuaW1wb3J0IHsgQ2RrQ2xpV3JhcHBlciB9IGZyb20gJ0Bhd3MtY2RrL2Nkay1jbGktd3JhcHBlcic7XG5pbXBvcnQgdHlwZSB7IEludGVnUnVubmVyT3B0aW9ucyB9IGZyb20gJy4vcnVubmVyLWJhc2UnO1xuaW1wb3J0IHsgVG9vbGtpdExpYlJ1bm5lckVuZ2luZSB9IGZyb20gJy4uL2VuZ2luZXMvdG9vbGtpdC1saWInO1xuXG5leHBvcnQgaW50ZXJmYWNlIEVuZ2luZU9wdGlvbnMge1xuICAvKipcbiAgICogVGhlIENESyBUb29sa2l0IGVuZ2luZSB0byBiZSB1c2VkIGJ5IHRoZSBydW5uZXIuXG4gICAqXG4gICAqIEBkZWZhdWx0IFwiY2xpLXdyYXBwZXJcIlxuICAgKi9cbiAgcmVhZG9ubHkgZW5naW5lPzogJ2NsaS13cmFwcGVyJyB8ICd0b29sa2l0LWxpYic7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBtYWtlRW5naW5lKG9wdGlvbnM6IEludGVnUnVubmVyT3B0aW9ucyk6IElDZGsge1xuICBzd2l0Y2ggKG9wdGlvbnMuZW5naW5lKSB7XG4gICAgY2FzZSAndG9vbGtpdC1saWInOlxuICAgICAgcmV0dXJuIG5ldyBUb29sa2l0TGliUnVubmVyRW5naW5lKHtcbiAgICAgICAgd29ya2luZ0RpcmVjdG9yeTogb3B0aW9ucy50ZXN0LmRpcmVjdG9yeSxcbiAgICAgICAgc2hvd091dHB1dDogb3B0aW9ucy5zaG93T3V0cHV0LFxuICAgICAgICBlbnY6IG9wdGlvbnMuZW52LFxuICAgICAgICByZWdpb246IG9wdGlvbnMucmVnaW9uLFxuICAgICAgICBwcm9maWxlOiBvcHRpb25zLnByb2ZpbGUsXG4gICAgICB9KTtcbiAgICBjYXNlICdjbGktd3JhcHBlcic6XG4gICAgZGVmYXVsdDpcbiAgICAgIHJldHVybiBuZXcgQ2RrQ2xpV3JhcHBlcih7XG4gICAgICAgIGRpcmVjdG9yeTogb3B0aW9ucy50ZXN0LmRpcmVjdG9yeSxcbiAgICAgICAgc2hvd091dHB1dDogb3B0aW9ucy5zaG93T3V0cHV0LFxuICAgICAgICBlbnY6IHtcbiAgICAgICAgICAuLi5vcHRpb25zLmVudixcbiAgICAgICAgICAvLyBUaGUgQ0RLIENMSSB3aWxsIGludGVycHJldCB0aGlzIGFuZCB1c2UgaXQgdXNlZnVsbHlcbiAgICAgICAgICBBV1NfUkVHSU9OOiBvcHRpb25zLnJlZ2lvbixcbiAgICAgICAgfSxcbiAgICAgIH0pO1xuICB9XG59XG5cbiJdfQ==
@@ -167,6 +167,10 @@ export declare enum DiagnosticReason {
167
167
  * There was an error running the integration test
168
168
  */
169
169
  TEST_ERROR = "TEST_ERROR",
170
+ /**
171
+ * A non-failing warning from the integration test run
172
+ */
173
+ TEST_WARNING = "TEST_WARNING",
170
174
  /**
171
175
  * The snapshot test failed because the actual
172
176
  * snapshot was different than the expected snapshot
@@ -27,6 +27,10 @@ var DiagnosticReason;
27
27
  * There was an error running the integration test
28
28
  */
29
29
  DiagnosticReason["TEST_ERROR"] = "TEST_ERROR";
30
+ /**
31
+ * A non-failing warning from the integration test run
32
+ */
33
+ DiagnosticReason["TEST_WARNING"] = "TEST_WARNING";
30
34
  /**
31
35
  * The snapshot test failed because the actual
32
36
  * snapshot was different than the expected snapshot
@@ -83,6 +87,9 @@ function printResults(diagnostic) {
83
87
  case DiagnosticReason.SNAPSHOT_FAILED:
84
88
  logger.error(' CHANGED %s %s\n%s', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`), indentLines(diagnostic.message, 6));
85
89
  break;
90
+ case DiagnosticReason.TEST_WARNING:
91
+ logger.warning(' WARN %s %s\n%s', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`), indentLines(diagnostic.message, 6));
92
+ break;
86
93
  case DiagnosticReason.SNAPSHOT_ERROR:
87
94
  case DiagnosticReason.TEST_ERROR:
88
95
  logger.error(' ERROR %s %s\n%s', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`), indentLines(diagnostic.message, 6));
@@ -120,4 +127,4 @@ function formatError(error) {
120
127
  }
121
128
  return `${name}: ${message}`;
122
129
  }
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["common.ts"],"names":[],"mappings":"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","sourcesContent":["import { format } from 'util';\nimport type { ResourceImpact } from '@aws-cdk/cloudformation-diff';\nimport * as chalk from 'chalk';\nimport * as logger from '../logger';\nimport type { EngineOptions } from '../runner/engine';\nimport type { IntegTestInfo } from '../runner/integration-tests';\n\n/**\n * The aggregate results from running assertions on a test case\n */\nexport type AssertionResults = { [id: string]: AssertionResult };\n\n/**\n * The result of an individual assertion\n */\nexport interface AssertionResult {\n  /**\n   * The assertion message. If the assertion failed, this will\n   * include the reason.\n   */\n  readonly message: string;\n\n  /**\n   * Whether the assertion succeeded or failed\n   */\n  readonly status: 'success' | 'fail';\n}\n\n/**\n * Config for an integration test\n */\nexport interface IntegTestWorkerConfig extends IntegTestInfo {\n  /**\n   * A list of any destructive changes\n   *\n   * @default []\n   */\n  readonly destructiveChanges?: DestructiveChange[];\n}\n\n/**\n * Information on any destructive changes\n */\nexport interface DestructiveChange {\n  /**\n   * The logicalId of the resource with a destructive change\n   */\n  readonly logicalId: string;\n\n  /**\n   * The name of the stack that contains the destructive change\n   */\n  readonly stackName: string;\n\n  /**\n   * The impact of the destructive change\n   */\n  readonly impact: ResourceImpact;\n}\n\n/**\n * Represents integration tests metrics for a given worker\n */\nexport interface IntegRunnerMetrics {\n  /**\n   * The region the test was run in\n   */\n  readonly region: string;\n\n  /**\n   * The total duration of the worker.\n   * This will be the sum of all individual test durations\n   */\n  readonly duration: number;\n\n  /**\n   * Contains the duration of individual tests that the\n   * worker executed.\n   *\n   * Map of testName to duration.\n   */\n  readonly tests: { [testName: string]: number };\n\n  /**\n   * The profile that was used to run the test\n   *\n   * @default - default profile\n   */\n  readonly profile?: string;\n}\n\nexport interface SnapshotVerificationOptions extends EngineOptions {\n  /**\n   * Retain failed snapshot comparisons\n   *\n   * @default false\n   */\n  readonly retain?: boolean;\n\n  /**\n   * Verbose mode\n   *\n   * @default false\n   */\n  readonly verbose?: boolean;\n}\n\n/**\n * Integration test results\n */\nexport interface IntegBatchResponse {\n  /**\n   * List of failed tests\n   */\n  readonly failedTests: IntegTestInfo[];\n\n  /**\n   * List of Integration test metrics. Each entry in the\n   * list represents metrics from a single worker (account + region).\n   */\n  readonly metrics: IntegRunnerMetrics[];\n}\n\n/**\n * Common options for running integration tests\n */\nexport interface IntegTestOptions extends EngineOptions {\n  /**\n   * A list of integration tests to run\n   * in this batch\n   */\n  readonly tests: IntegTestWorkerConfig[];\n\n  /**\n   * Whether or not to destroy the stacks at the\n   * end of the test\n   *\n   * @default true\n   */\n  readonly clean?: boolean;\n\n  /**\n   * When this is set to `true` the snapshot will\n   * be created _without_ running the integration test\n   * The resulting snapshot SHOULD NOT be checked in\n   *\n   * @default false\n   */\n  readonly dryRun?: boolean;\n\n  /**\n   * The level of verbosity for logging.\n   * Higher number means more output.\n   *\n   * @default 0\n   */\n  readonly verbosity?: number;\n\n  /**\n   * If this is set to true then the stack update workflow will be disabled\n   *\n   * @default true\n   */\n  readonly updateWorkflow?: boolean;\n\n  /**\n   * true if running in watch mode\n   *\n   * @default false\n   */\n  readonly watch?: boolean;\n}\n\n/**\n * Represents possible reasons for a diagnostic\n */\nexport enum DiagnosticReason {\n  /**\n   * The integration test failed because there\n   * is not existing snapshot\n   */\n  NO_SNAPSHOT = 'NO_SNAPSHOT',\n\n  /**\n   * The integration test failed\n   */\n  TEST_FAILED = 'TEST_FAILED',\n\n  /**\n   * There was an error running the integration test\n   */\n  TEST_ERROR = 'TEST_ERROR',\n\n  /**\n   * The snapshot test failed because the actual\n   * snapshot was different than the expected snapshot\n   */\n  SNAPSHOT_FAILED = 'SNAPSHOT_FAILED',\n\n  /**\n   * The snapshot test failed because there was an error executing it\n   */\n  SNAPSHOT_ERROR = 'SNAPSHOT_ERROR',\n\n  /**\n   * The snapshot test succeeded\n   */\n  SNAPSHOT_SUCCESS = 'SNAPSHOT_SUCCESS',\n\n  /**\n   * The integration test succeeded\n   */\n  TEST_SUCCESS = 'TEST_SUCCESS',\n\n  /**\n   * The assertion failed\n   */\n  ASSERTION_FAILED = 'ASSERTION_FAILED',\n}\n\n/**\n * Integration test diagnostics\n * This is used to report back the status of each test\n */\nexport interface Diagnostic {\n  /**\n   * The name of the test\n   */\n  readonly testName: string;\n\n  /**\n   * The name of the stack\n   */\n  readonly stackName: string;\n\n  /**\n   * The diagnostic message\n   */\n  readonly message: string;\n\n  /**\n   * The time it took to run the test\n   */\n  readonly duration?: number;\n\n  /**\n   * The reason for the diagnostic\n   */\n  readonly reason: DiagnosticReason;\n\n  /**\n   * Additional messages to print\n   */\n  readonly additionalMessages?: string[];\n\n  /**\n   * Relevant config options that were used for the integ test\n   */\n  readonly config?: Record<string, any>;\n}\n\nexport function printSummary(total: number, failed: number): void {\n  if (failed > 0) {\n    logger.print('%s:    %s %s, %s total', chalk.bold('Tests'), chalk.red(failed), chalk.red('failed'), total);\n  } else {\n    logger.print('%s:    %s %s, %s total', chalk.bold('Tests'), chalk.green(total), chalk.green('passed'), total);\n  }\n}\n\n/**\n * Format the assertion results so that the results can be\n * printed\n */\nexport function formatAssertionResults(results: AssertionResults): string {\n  return Object.entries(results)\n    .map(([id, result]) => format('%s%s', id, result.status === 'success' ? ` - ${result.status}` : `\\n${result.message}`))\n    .join('\\n      ');\n}\n\n/**\n * Print out the results from tests\n */\nexport function printResults(diagnostic: Diagnostic): void {\n  switch (diagnostic.reason) {\n    case DiagnosticReason.SNAPSHOT_SUCCESS:\n      logger.success('  UNCHANGED  %s %s', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`));\n      break;\n    case DiagnosticReason.TEST_SUCCESS:\n      logger.success('  SUCCESS    %s %s\\n      ', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`));\n      break;\n    case DiagnosticReason.NO_SNAPSHOT:\n      logger.error('  NEW        %s %s', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`));\n      break;\n    case DiagnosticReason.SNAPSHOT_FAILED:\n      logger.error('  CHANGED    %s %s\\n%s', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`), indentLines(diagnostic.message, 6));\n      break;\n    case DiagnosticReason.SNAPSHOT_ERROR:\n    case DiagnosticReason.TEST_ERROR:\n      logger.error('  ERROR      %s %s\\n%s', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`), indentLines(diagnostic.message, 6));\n      break;\n    case DiagnosticReason.TEST_FAILED:\n      logger.error('  FAILED     %s %s\\n%s', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`), indentLines(diagnostic.message, 6));\n      break;\n    case DiagnosticReason.ASSERTION_FAILED:\n      logger.error('  ASSERT     %s %s\\n%s', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`), indentLines(diagnostic.message, 6));\n      break;\n  }\n  for (const addl of diagnostic.additionalMessages ?? []) {\n    logger.print(`      ${addl}`);\n  }\n}\n\n/**\n * Takes a multiline string and indents every line with the same number of spaces.\n */\nfunction indentLines(message: string, count = 2): string {\n  return message.split('\\n').map(line => ' '.repeat(count) + line).join('\\n');\n}\n\nexport function printLaggards(testNames: Set<string>) {\n  const parts = [\n    '  ',\n    `Waiting for ${testNames.size} more`,\n    testNames.size < 10 ? ['(', Array.from(testNames).join(', '), ')'].join('') : '',\n  ];\n\n  logger.print(chalk.grey(parts.filter(x => x).join(' ')));\n}\n\nexport function formatError(error: any): string {\n  const name = error.name || 'Error';\n  const message = error.message || String(error);\n\n  if (error.cause) {\n    return `${name}: ${message}\\n${chalk.gray('Cause: ' + formatError(error.cause))}`;\n  }\n\n  return `${name}: ${message}`;\n}\n"]}
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["common.ts"],"names":[],"mappings":"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","sourcesContent":["import { format } from 'util';\nimport type { ResourceImpact } from '@aws-cdk/cloudformation-diff';\nimport * as chalk from 'chalk';\nimport * as logger from '../logger';\nimport type { EngineOptions } from '../runner/engine';\nimport type { IntegTestInfo } from '../runner/integration-tests';\n\n/**\n * The aggregate results from running assertions on a test case\n */\nexport type AssertionResults = { [id: string]: AssertionResult };\n\n/**\n * The result of an individual assertion\n */\nexport interface AssertionResult {\n  /**\n   * The assertion message. If the assertion failed, this will\n   * include the reason.\n   */\n  readonly message: string;\n\n  /**\n   * Whether the assertion succeeded or failed\n   */\n  readonly status: 'success' | 'fail';\n}\n\n/**\n * Config for an integration test\n */\nexport interface IntegTestWorkerConfig extends IntegTestInfo {\n  /**\n   * A list of any destructive changes\n   *\n   * @default []\n   */\n  readonly destructiveChanges?: DestructiveChange[];\n}\n\n/**\n * Information on any destructive changes\n */\nexport interface DestructiveChange {\n  /**\n   * The logicalId of the resource with a destructive change\n   */\n  readonly logicalId: string;\n\n  /**\n   * The name of the stack that contains the destructive change\n   */\n  readonly stackName: string;\n\n  /**\n   * The impact of the destructive change\n   */\n  readonly impact: ResourceImpact;\n}\n\n/**\n * Represents integration tests metrics for a given worker\n */\nexport interface IntegRunnerMetrics {\n  /**\n   * The region the test was run in\n   */\n  readonly region: string;\n\n  /**\n   * The total duration of the worker.\n   * This will be the sum of all individual test durations\n   */\n  readonly duration: number;\n\n  /**\n   * Contains the duration of individual tests that the\n   * worker executed.\n   *\n   * Map of testName to duration.\n   */\n  readonly tests: { [testName: string]: number };\n\n  /**\n   * The profile that was used to run the test\n   *\n   * @default - default profile\n   */\n  readonly profile?: string;\n}\n\nexport interface SnapshotVerificationOptions extends EngineOptions {\n  /**\n   * Retain failed snapshot comparisons\n   *\n   * @default false\n   */\n  readonly retain?: boolean;\n\n  /**\n   * Verbose mode\n   *\n   * @default false\n   */\n  readonly verbose?: boolean;\n}\n\n/**\n * Integration test results\n */\nexport interface IntegBatchResponse {\n  /**\n   * List of failed tests\n   */\n  readonly failedTests: IntegTestInfo[];\n\n  /**\n   * List of Integration test metrics. Each entry in the\n   * list represents metrics from a single worker (account + region).\n   */\n  readonly metrics: IntegRunnerMetrics[];\n}\n\n/**\n * Common options for running integration tests\n */\nexport interface IntegTestOptions extends EngineOptions {\n  /**\n   * A list of integration tests to run\n   * in this batch\n   */\n  readonly tests: IntegTestWorkerConfig[];\n\n  /**\n   * Whether or not to destroy the stacks at the\n   * end of the test\n   *\n   * @default true\n   */\n  readonly clean?: boolean;\n\n  /**\n   * When this is set to `true` the snapshot will\n   * be created _without_ running the integration test\n   * The resulting snapshot SHOULD NOT be checked in\n   *\n   * @default false\n   */\n  readonly dryRun?: boolean;\n\n  /**\n   * The level of verbosity for logging.\n   * Higher number means more output.\n   *\n   * @default 0\n   */\n  readonly verbosity?: number;\n\n  /**\n   * If this is set to true then the stack update workflow will be disabled\n   *\n   * @default true\n   */\n  readonly updateWorkflow?: boolean;\n\n  /**\n   * true if running in watch mode\n   *\n   * @default false\n   */\n  readonly watch?: boolean;\n}\n\n/**\n * Represents possible reasons for a diagnostic\n */\nexport enum DiagnosticReason {\n  /**\n   * The integration test failed because there\n   * is not existing snapshot\n   */\n  NO_SNAPSHOT = 'NO_SNAPSHOT',\n\n  /**\n   * The integration test failed\n   */\n  TEST_FAILED = 'TEST_FAILED',\n\n  /**\n   * There was an error running the integration test\n   */\n  TEST_ERROR = 'TEST_ERROR',\n\n  /**\n   * A non-failing warning from the integration test run\n   */\n  TEST_WARNING = 'TEST_WARNING',\n\n  /**\n   * The snapshot test failed because the actual\n   * snapshot was different than the expected snapshot\n   */\n  SNAPSHOT_FAILED = 'SNAPSHOT_FAILED',\n\n  /**\n   * The snapshot test failed because there was an error executing it\n   */\n  SNAPSHOT_ERROR = 'SNAPSHOT_ERROR',\n\n  /**\n   * The snapshot test succeeded\n   */\n  SNAPSHOT_SUCCESS = 'SNAPSHOT_SUCCESS',\n\n  /**\n   * The integration test succeeded\n   */\n  TEST_SUCCESS = 'TEST_SUCCESS',\n\n  /**\n   * The assertion failed\n   */\n  ASSERTION_FAILED = 'ASSERTION_FAILED',\n}\n\n/**\n * Integration test diagnostics\n * This is used to report back the status of each test\n */\nexport interface Diagnostic {\n  /**\n   * The name of the test\n   */\n  readonly testName: string;\n\n  /**\n   * The name of the stack\n   */\n  readonly stackName: string;\n\n  /**\n   * The diagnostic message\n   */\n  readonly message: string;\n\n  /**\n   * The time it took to run the test\n   */\n  readonly duration?: number;\n\n  /**\n   * The reason for the diagnostic\n   */\n  readonly reason: DiagnosticReason;\n\n  /**\n   * Additional messages to print\n   */\n  readonly additionalMessages?: string[];\n\n  /**\n   * Relevant config options that were used for the integ test\n   */\n  readonly config?: Record<string, any>;\n}\n\nexport function printSummary(total: number, failed: number): void {\n  if (failed > 0) {\n    logger.print('%s:    %s %s, %s total', chalk.bold('Tests'), chalk.red(failed), chalk.red('failed'), total);\n  } else {\n    logger.print('%s:    %s %s, %s total', chalk.bold('Tests'), chalk.green(total), chalk.green('passed'), total);\n  }\n}\n\n/**\n * Format the assertion results so that the results can be\n * printed\n */\nexport function formatAssertionResults(results: AssertionResults): string {\n  return Object.entries(results)\n    .map(([id, result]) => format('%s%s', id, result.status === 'success' ? ` - ${result.status}` : `\\n${result.message}`))\n    .join('\\n      ');\n}\n\n/**\n * Print out the results from tests\n */\nexport function printResults(diagnostic: Diagnostic): void {\n  switch (diagnostic.reason) {\n    case DiagnosticReason.SNAPSHOT_SUCCESS:\n      logger.success('  UNCHANGED  %s %s', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`));\n      break;\n    case DiagnosticReason.TEST_SUCCESS:\n      logger.success('  SUCCESS    %s %s\\n      ', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`));\n      break;\n    case DiagnosticReason.NO_SNAPSHOT:\n      logger.error('  NEW        %s %s', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`));\n      break;\n    case DiagnosticReason.SNAPSHOT_FAILED:\n      logger.error('  CHANGED    %s %s\\n%s', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`), indentLines(diagnostic.message, 6));\n      break;\n    case DiagnosticReason.TEST_WARNING:\n      logger.warning('  WARN       %s %s\\n%s', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`), indentLines(diagnostic.message, 6));\n      break;\n    case DiagnosticReason.SNAPSHOT_ERROR:\n    case DiagnosticReason.TEST_ERROR:\n      logger.error('  ERROR      %s %s\\n%s', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`), indentLines(diagnostic.message, 6));\n      break;\n    case DiagnosticReason.TEST_FAILED:\n      logger.error('  FAILED     %s %s\\n%s', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`), indentLines(diagnostic.message, 6));\n      break;\n    case DiagnosticReason.ASSERTION_FAILED:\n      logger.error('  ASSERT     %s %s\\n%s', diagnostic.testName, chalk.gray(`${diagnostic.duration}s`), indentLines(diagnostic.message, 6));\n      break;\n  }\n  for (const addl of diagnostic.additionalMessages ?? []) {\n    logger.print(`      ${addl}`);\n  }\n}\n\n/**\n * Takes a multiline string and indents every line with the same number of spaces.\n */\nfunction indentLines(message: string, count = 2): string {\n  return message.split('\\n').map(line => ' '.repeat(count) + line).join('\\n');\n}\n\nexport function printLaggards(testNames: Set<string>) {\n  const parts = [\n    '  ',\n    `Waiting for ${testNames.size} more`,\n    testNames.size < 10 ? ['(', Array.from(testNames).join(', '), ')'].join('') : '',\n  ];\n\n  logger.print(chalk.grey(parts.filter(x => x).join(' ')));\n}\n\nexport function formatError(error: any): string {\n  const name = error.name || 'Error';\n  const message = error.message || String(error);\n\n  if (error.cause) {\n    return `${name}: ${message}\\n${chalk.gray('Cause: ' + formatError(error.cause))}`;\n  }\n\n  return `${name}: ${message}`;\n}\n"]}
@@ -126,7 +126,7 @@ async function snapshotTestWorker(testInfo, options = {}) {
126
126
  const test = new integration_tests_1.IntegTest(testInfo); // Hydrate the data record again
127
127
  const timer = setTimeout(() => {
128
128
  workerpool.workerEmit({
129
- reason: common_1.DiagnosticReason.SNAPSHOT_ERROR,
129
+ reason: common_1.DiagnosticReason.TEST_WARNING,
130
130
  testName: test.testName,
131
131
  message: 'Test is taking a very long time',
132
132
  duration: (Date.now() - start) / 1000,
@@ -188,4 +188,4 @@ workerpool.worker({
188
188
  integTestWorker,
189
189
  watchTestWorker,
190
190
  });
191
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"extract_worker.js","sourceRoot":"","sources":["extract_worker.ts"],"names":[],"mappings":";;AAiBA,0CA2EC;AAED,0CAyBC;AAQD,gDA6DC;AA5LD,yCAAyC;AACzC,yCAAoE;AAEpE,sEAA2D;AAE3D,sCAAkF;AAIlF;;;;;;;GAOG;AACI,KAAK,UAAU,eAAe,CAAC,OAA8B;IAClE,MAAM,QAAQ,GAAoB,EAAE,CAAC;IACrC,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,CAAC,CAAC;IAEzC,KAAK,MAAM,QAAQ,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;QACrC,MAAM,IAAI,GAAG,IAAI,6BAAS,CAAC;YACzB,GAAG,QAAQ;YACX,KAAK,EAAE,OAAO,CAAC,KAAK;SACrB,CAAC,CAAC,CAAC,oBAAoB;QACxB,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAEzB,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,wBAAe,CAAC;gBACjC,MAAM,EAAE,OAAO,CAAC,MAAM;gBACtB,IAAI;gBACJ,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,MAAM,EAAE,OAAO,CAAC,MAAM;gBACtB,GAAG,EAAE;oBACH,UAAU,EAAE,OAAO,CAAC,GAAG,CAAC,UAAU,IAAI,QAAQ;iBAC/C;gBACD,UAAU,EAAE,SAAS,IAAI,CAAC;aAC3B,EAAE,QAAQ,CAAC,kBAAkB,CAAC,CAAC;YAEhC,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC,WAAW,EAAE,CAAC;YAEzC,IAAI,CAAC,KAAK,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC9C,MAAM,IAAI,KAAK,CAAC,wBAAwB,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;YAC7D,CAAC;YACD,KAAK,MAAM,YAAY,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;gBAC9C,IAAI,CAAC;oBACH,MAAM,OAAO,GAAG,MAAM,MAAM,CAAC,gBAAgB,CAAC;wBAC5C,YAAY;wBACZ,KAAK,EAAE,OAAO,CAAC,KAAK;wBACpB,MAAM,EAAE,OAAO,CAAC,MAAM;wBACtB,cAAc,EAAE,OAAO,CAAC,cAAc;wBACtC,SAAS;qBACV,CAAC,CAAC;oBACH,IAAI,OAAO,IAAI,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,KAAK,MAAM,CAAC,EAAE,CAAC;wBAC/E,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;wBACxB,UAAU,CAAC,UAAU,CAAC;4BACpB,MAAM,EAAE,yBAAgB,CAAC,gBAAgB;4BACzC,QAAQ,EAAE,GAAG,MAAM,CAAC,QAAQ,IAAI,YAAY,KAAK,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG;4BACrF,OAAO,EAAE,IAAA,+BAAsB,EAAC,OAAO,CAAC;4BACxC,QAAQ,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,GAAG,IAAI;yBACtC,CAAC,CAAC;oBACL,CAAC;yBAAM,CAAC;wBACN,UAAU,CAAC,UAAU,CAAC;4BACpB,MAAM,EAAE,yBAAgB,CAAC,YAAY;4BACrC,QAAQ,EAAE,GAAG,MAAM,CAAC,QAAQ,IAAI,YAAY,EAAE;4BAC9C,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,IAAA,+BAAsB,EAAC,OAAO,CAAC,CAAC,CAAC,CAAC,eAAe;4BACpE,QAAQ,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,GAAG,IAAI;yBACtC,CAAC,CAAC;oBACL,CAAC;gBACH,CAAC;gBAAC,OAAO,CAAC,EAAE,CAAC;oBACX,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;oBACxB,UAAU,CAAC,UAAU,CAAC;wBACpB,MAAM,EAAE,yBAAgB,CAAC,WAAW;wBACpC,QAAQ,EAAE,GAAG,MAAM,CAAC,QAAQ,IAAI,YAAY,KAAK,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG;wBACrF,OAAO,EAAE,4BAA4B,IAAA,oBAAW,EAAC,CAAC,CAAC,EAAE;wBACrD,QAAQ,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,GAAG,IAAI;qBACtC,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;QACH,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACxB,UAAU,CAAC,UAAU,CAAC;gBACpB,MAAM,EAAE,yBAAgB,CAAC,UAAU;gBACnC,QAAQ,EAAE,GAAG,QAAQ,CAAC,QAAQ,KAAK,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG;gBACvE,OAAO,EAAE,kCAAkC,IAAA,oBAAW,EAAC,CAAC,CAAC,EAAE;gBAC3D,QAAQ,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,GAAG,IAAI;aACtC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC;AAEM,KAAK,UAAU,eAAe,CAAC,OAA0B;IAC9D,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,CAAC,CAAC;IACzC,MAAM,IAAI,GAAG,IAAI,6BAAS,CAAC,OAAO,CAAC,CAAC;IACpC,MAAM,MAAM,GAAG,IAAI,wBAAe,CAAC;QACjC,MAAM,EAAE,OAAO,CAAC,MAAM;QACtB,IAAI;QACJ,OAAO,EAAE,OAAO,CAAC,OAAO;QACxB,MAAM,EAAE,OAAO,CAAC,MAAM;QACtB,GAAG,EAAE;YACH,UAAU,EAAE,OAAO,CAAC,GAAG,CAAC,UAAU,IAAI,QAAQ;SAC/C;QACD,UAAU,EAAE,SAAS,IAAI,CAAC;KAC3B,CAAC,CAAC;IACH,MAAM,CAAC,oBAAoB,EAAE,CAAC;IAC9B,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC,WAAW,EAAE,CAAC;IAEzC,IAAI,CAAC,KAAK,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC9C,MAAM,IAAI,KAAK,CAAC,wBAAwB,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;IAC7D,CAAC;IACD,KAAK,MAAM,YAAY,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;QAC9C,MAAM,MAAM,CAAC,cAAc,CAAC;YAC1B,YAAY;YACZ,SAAS;SACV,CAAC,CAAC;IACL,CAAC;AACH,CAAC;AAED;;;;;GAKG;AACI,KAAK,UAAU,kBAAkB,CAAC,QAAuB,EAAE,UAAuC,EAAE;IACzG,MAAM,WAAW,GAAG,IAAI,KAAK,EAAyB,CAAC;IACvD,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACzB,MAAM,IAAI,GAAG,IAAI,6BAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,gCAAgC;IAEtE,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE;QAC5B,UAAU,CAAC,UAAU,CAAC;YACpB,MAAM,EAAE,yBAAgB,CAAC,cAAc;YACvC,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,OAAO,EAAE,iCAAiC;YAC1C,QAAQ,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,GAAG,IAAI;SACtC,CAAC,CAAC;IACL,CAAC,EAAE,KAAM,CAAC,CAAC;IAEX,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,IAAI,4BAAmB,CAAC;YACrC,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,IAAI;YACJ,UAAU,EAAE,OAAO,CAAC,OAAO,IAAI,KAAK;SACrC,CAAC,CAAC;QACH,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,EAAE,CAAC;YAC1B,UAAU,CAAC,UAAU,CAAC;gBACpB,MAAM,EAAE,yBAAgB,CAAC,WAAW;gBACpC,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,OAAO,EAAE,aAAa;gBACtB,QAAQ,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,GAAG,IAAI;aACtC,CAAC,CAAC;YACH,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9B,CAAC;aAAM,CAAC;YACN,MAAM,EAAE,WAAW,EAAE,kBAAkB,EAAE,GAAG,MAAM,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;YAC/E,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC3B,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC,UAAU,CAAC,UAAU,CAAC;oBACtD,GAAG,UAAU;oBACb,QAAQ,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,GAAG,IAAI;iBACxB,CAAC,CAAC,CAAC;gBAClB,WAAW,CAAC,IAAI,CAAC;oBACf,GAAG,IAAI,CAAC,IAAI;oBACZ,kBAAkB;iBACnB,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,UAAU,CAAC,UAAU,CAAC;oBACpB,MAAM,EAAE,yBAAgB,CAAC,gBAAgB;oBACzC,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,OAAO,EAAE,SAAS;oBAClB,QAAQ,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,GAAG,IAAI;iBACxB,CAAC,CAAC;YACnB,CAAC;QACH,CAAC;IACH,CAAC;IAAC,OAAO,CAAM,EAAE,CAAC;QAChB,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5B,UAAU,CAAC,UAAU,CAAC;YACpB,OAAO,EAAE,IAAA,oBAAW,EAAC,CAAC,CAAC;YACvB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,MAAM,EAAE,yBAAgB,CAAC,cAAc;YACvC,QAAQ,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,GAAG,IAAI;SACxB,CAAC,CAAC;IACnB,CAAC;YAAS,CAAC;QACT,YAAY,CAAC,KAAK,CAAC,CAAC;IACtB,CAAC;IAED,OAAO,WAAW,CAAC;AACrB,CAAC;AAED,UAAU,CAAC,MAAM,CAAC;IAChB,kBAAkB;IAClB,eAAe;IACf,eAAe;CAChB,CAAC,CAAC","sourcesContent":["import * as workerpool from 'workerpool';\nimport { IntegSnapshotRunner, IntegTestRunner } from '../../runner';\nimport type { IntegTestInfo } from '../../runner/integration-tests';\nimport { IntegTest } from '../../runner/integration-tests';\nimport type { IntegTestWorkerConfig, SnapshotVerificationOptions, Diagnostic } from '../common';\nimport { DiagnosticReason, formatAssertionResults, formatError } from '../common';\nimport type { IntegTestBatchRequest } from '../integ-test-worker';\nimport type { IntegWatchOptions } from '../integ-watch-worker';\n\n/**\n * Runs a single integration test batch request.\n * If the test does not have an existing snapshot,\n * this will first generate a snapshot and then execute\n * the integration tests.\n *\n * If the tests succeed it will then save the snapshot\n */\nexport async function integTestWorker(request: IntegTestBatchRequest): Promise<IntegTestWorkerConfig[]> {\n  const failures: IntegTestInfo[] = [];\n  const verbosity = request.verbosity ?? 0;\n\n  for (const testInfo of request.tests) {\n    const test = new IntegTest({\n      ...testInfo,\n      watch: request.watch,\n    }); // Hydrate from data\n    const start = Date.now();\n\n    try {\n      const runner = new IntegTestRunner({\n        engine: request.engine,\n        test,\n        profile: request.profile,\n        region: request.region,\n        env: {\n          CDK_DOCKER: process.env.CDK_DOCKER ?? 'docker',\n        },\n        showOutput: verbosity >= 2,\n      }, testInfo.destructiveChanges);\n\n      const tests = await runner.actualTests();\n\n      if (!tests || Object.keys(tests).length === 0) {\n        throw new Error(`No tests defined for ${runner.testName}`);\n      }\n      for (const testCaseName of Object.keys(tests)) {\n        try {\n          const results = await runner.runIntegTestCase({\n            testCaseName,\n            clean: request.clean,\n            dryRun: request.dryRun,\n            updateWorkflow: request.updateWorkflow,\n            verbosity,\n          });\n          if (results && Object.values(results).some(result => result.status === 'fail')) {\n            failures.push(testInfo);\n            workerpool.workerEmit({\n              reason: DiagnosticReason.ASSERTION_FAILED,\n              testName: `${runner.testName}-${testCaseName} (${request.profile}/${request.region})`,\n              message: formatAssertionResults(results),\n              duration: (Date.now() - start) / 1000,\n            });\n          } else {\n            workerpool.workerEmit({\n              reason: DiagnosticReason.TEST_SUCCESS,\n              testName: `${runner.testName}-${testCaseName}`,\n              message: results ? formatAssertionResults(results) : 'NO ASSERTIONS',\n              duration: (Date.now() - start) / 1000,\n            });\n          }\n        } catch (e) {\n          failures.push(testInfo);\n          workerpool.workerEmit({\n            reason: DiagnosticReason.TEST_FAILED,\n            testName: `${runner.testName}-${testCaseName} (${request.profile}/${request.region})`,\n            message: `Integration test failed: ${formatError(e)}`,\n            duration: (Date.now() - start) / 1000,\n          });\n        }\n      }\n    } catch (e) {\n      failures.push(testInfo);\n      workerpool.workerEmit({\n        reason: DiagnosticReason.TEST_ERROR,\n        testName: `${testInfo.fileName} (${request.profile}/${request.region})`,\n        message: `Error during integration test: ${formatError(e)}`,\n        duration: (Date.now() - start) / 1000,\n      });\n    }\n  }\n\n  return failures;\n}\n\nexport async function watchTestWorker(options: IntegWatchOptions): Promise<void> {\n  const verbosity = options.verbosity ?? 0;\n  const test = new IntegTest(options);\n  const runner = new IntegTestRunner({\n    engine: options.engine,\n    test,\n    profile: options.profile,\n    region: options.region,\n    env: {\n      CDK_DOCKER: process.env.CDK_DOCKER ?? 'docker',\n    },\n    showOutput: verbosity >= 2,\n  });\n  runner.createCdkContextJson();\n  const tests = await runner.actualTests();\n\n  if (!tests || Object.keys(tests).length === 0) {\n    throw new Error(`No tests defined for ${runner.testName}`);\n  }\n  for (const testCaseName of Object.keys(tests)) {\n    await runner.watchIntegTest({\n      testCaseName,\n      verbosity,\n    });\n  }\n}\n\n/**\n * Runs a single snapshot test batch request.\n * For each integration test this will check to see\n * if there is an existing snapshot, and if there is will\n * check if there are any changes\n */\nexport async function snapshotTestWorker(testInfo: IntegTestInfo, options: SnapshotVerificationOptions = {}): Promise<IntegTestWorkerConfig[]> {\n  const failedTests = new Array<IntegTestWorkerConfig>();\n  const start = Date.now();\n  const test = new IntegTest(testInfo); // Hydrate the data record again\n\n  const timer = setTimeout(() => {\n    workerpool.workerEmit({\n      reason: DiagnosticReason.SNAPSHOT_ERROR,\n      testName: test.testName,\n      message: 'Test is taking a very long time',\n      duration: (Date.now() - start) / 1000,\n    });\n  }, 60_000);\n\n  try {\n    const runner = new IntegSnapshotRunner({\n      engine: options.engine,\n      test,\n      showOutput: options.verbose ?? false,\n    });\n    if (!runner.hasSnapshot()) {\n      workerpool.workerEmit({\n        reason: DiagnosticReason.NO_SNAPSHOT,\n        testName: test.testName,\n        message: 'No Snapshot',\n        duration: (Date.now() - start) / 1000,\n      });\n      failedTests.push(test.info);\n    } else {\n      const { diagnostics, destructiveChanges } = await runner.testSnapshot(options);\n      if (diagnostics.length > 0) {\n        diagnostics.forEach(diagnostic => workerpool.workerEmit({\n          ...diagnostic,\n          duration: (Date.now() - start) / 1000,\n        } as Diagnostic));\n        failedTests.push({\n          ...test.info,\n          destructiveChanges,\n        });\n      } else {\n        workerpool.workerEmit({\n          reason: DiagnosticReason.SNAPSHOT_SUCCESS,\n          testName: test.testName,\n          message: 'Success',\n          duration: (Date.now() - start) / 1000,\n        } as Diagnostic);\n      }\n    }\n  } catch (e: any) {\n    failedTests.push(test.info);\n    workerpool.workerEmit({\n      message: formatError(e),\n      testName: test.testName,\n      reason: DiagnosticReason.SNAPSHOT_ERROR,\n      duration: (Date.now() - start) / 1000,\n    } as Diagnostic);\n  } finally {\n    clearTimeout(timer);\n  }\n\n  return failedTests;\n}\n\nworkerpool.worker({\n  snapshotTestWorker,\n  integTestWorker,\n  watchTestWorker,\n});\n"]}
191
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"extract_worker.js","sourceRoot":"","sources":["extract_worker.ts"],"names":[],"mappings":"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","sourcesContent":["import * as workerpool from 'workerpool';\nimport { IntegSnapshotRunner, IntegTestRunner } from '../../runner';\nimport type { IntegTestInfo } from '../../runner/integration-tests';\nimport { IntegTest } from '../../runner/integration-tests';\nimport type { IntegTestWorkerConfig, SnapshotVerificationOptions, Diagnostic } from '../common';\nimport { DiagnosticReason, formatAssertionResults, formatError } from '../common';\nimport type { IntegTestBatchRequest } from '../integ-test-worker';\nimport type { IntegWatchOptions } from '../integ-watch-worker';\n\n/**\n * Runs a single integration test batch request.\n * If the test does not have an existing snapshot,\n * this will first generate a snapshot and then execute\n * the integration tests.\n *\n * If the tests succeed it will then save the snapshot\n */\nexport async function integTestWorker(request: IntegTestBatchRequest): Promise<IntegTestWorkerConfig[]> {\n  const failures: IntegTestInfo[] = [];\n  const verbosity = request.verbosity ?? 0;\n\n  for (const testInfo of request.tests) {\n    const test = new IntegTest({\n      ...testInfo,\n      watch: request.watch,\n    }); // Hydrate from data\n    const start = Date.now();\n\n    try {\n      const runner = new IntegTestRunner({\n        engine: request.engine,\n        test,\n        profile: request.profile,\n        region: request.region,\n        env: {\n          CDK_DOCKER: process.env.CDK_DOCKER ?? 'docker',\n        },\n        showOutput: verbosity >= 2,\n      }, testInfo.destructiveChanges);\n\n      const tests = await runner.actualTests();\n\n      if (!tests || Object.keys(tests).length === 0) {\n        throw new Error(`No tests defined for ${runner.testName}`);\n      }\n      for (const testCaseName of Object.keys(tests)) {\n        try {\n          const results = await runner.runIntegTestCase({\n            testCaseName,\n            clean: request.clean,\n            dryRun: request.dryRun,\n            updateWorkflow: request.updateWorkflow,\n            verbosity,\n          });\n          if (results && Object.values(results).some(result => result.status === 'fail')) {\n            failures.push(testInfo);\n            workerpool.workerEmit({\n              reason: DiagnosticReason.ASSERTION_FAILED,\n              testName: `${runner.testName}-${testCaseName} (${request.profile}/${request.region})`,\n              message: formatAssertionResults(results),\n              duration: (Date.now() - start) / 1000,\n            });\n          } else {\n            workerpool.workerEmit({\n              reason: DiagnosticReason.TEST_SUCCESS,\n              testName: `${runner.testName}-${testCaseName}`,\n              message: results ? formatAssertionResults(results) : 'NO ASSERTIONS',\n              duration: (Date.now() - start) / 1000,\n            });\n          }\n        } catch (e) {\n          failures.push(testInfo);\n          workerpool.workerEmit({\n            reason: DiagnosticReason.TEST_FAILED,\n            testName: `${runner.testName}-${testCaseName} (${request.profile}/${request.region})`,\n            message: `Integration test failed: ${formatError(e)}`,\n            duration: (Date.now() - start) / 1000,\n          });\n        }\n      }\n    } catch (e) {\n      failures.push(testInfo);\n      workerpool.workerEmit({\n        reason: DiagnosticReason.TEST_ERROR,\n        testName: `${testInfo.fileName} (${request.profile}/${request.region})`,\n        message: `Error during integration test: ${formatError(e)}`,\n        duration: (Date.now() - start) / 1000,\n      });\n    }\n  }\n\n  return failures;\n}\n\nexport async function watchTestWorker(options: IntegWatchOptions): Promise<void> {\n  const verbosity = options.verbosity ?? 0;\n  const test = new IntegTest(options);\n  const runner = new IntegTestRunner({\n    engine: options.engine,\n    test,\n    profile: options.profile,\n    region: options.region,\n    env: {\n      CDK_DOCKER: process.env.CDK_DOCKER ?? 'docker',\n    },\n    showOutput: verbosity >= 2,\n  });\n  runner.createCdkContextJson();\n  const tests = await runner.actualTests();\n\n  if (!tests || Object.keys(tests).length === 0) {\n    throw new Error(`No tests defined for ${runner.testName}`);\n  }\n  for (const testCaseName of Object.keys(tests)) {\n    await runner.watchIntegTest({\n      testCaseName,\n      verbosity,\n    });\n  }\n}\n\n/**\n * Runs a single snapshot test batch request.\n * For each integration test this will check to see\n * if there is an existing snapshot, and if there is will\n * check if there are any changes\n */\nexport async function snapshotTestWorker(testInfo: IntegTestInfo, options: SnapshotVerificationOptions = {}): Promise<IntegTestWorkerConfig[]> {\n  const failedTests = new Array<IntegTestWorkerConfig>();\n  const start = Date.now();\n  const test = new IntegTest(testInfo); // Hydrate the data record again\n\n  const timer = setTimeout(() => {\n    workerpool.workerEmit({\n      reason: DiagnosticReason.TEST_WARNING,\n      testName: test.testName,\n      message: 'Test is taking a very long time',\n      duration: (Date.now() - start) / 1000,\n    });\n  }, 60_000);\n\n  try {\n    const runner = new IntegSnapshotRunner({\n      engine: options.engine,\n      test,\n      showOutput: options.verbose ?? false,\n    });\n    if (!runner.hasSnapshot()) {\n      workerpool.workerEmit({\n        reason: DiagnosticReason.NO_SNAPSHOT,\n        testName: test.testName,\n        message: 'No Snapshot',\n        duration: (Date.now() - start) / 1000,\n      });\n      failedTests.push(test.info);\n    } else {\n      const { diagnostics, destructiveChanges } = await runner.testSnapshot(options);\n      if (diagnostics.length > 0) {\n        diagnostics.forEach(diagnostic => workerpool.workerEmit({\n          ...diagnostic,\n          duration: (Date.now() - start) / 1000,\n        } as Diagnostic));\n        failedTests.push({\n          ...test.info,\n          destructiveChanges,\n        });\n      } else {\n        workerpool.workerEmit({\n          reason: DiagnosticReason.SNAPSHOT_SUCCESS,\n          testName: test.testName,\n          message: 'Success',\n          duration: (Date.now() - start) / 1000,\n        } as Diagnostic);\n      }\n    }\n  } catch (e: any) {\n    failedTests.push(test.info);\n    workerpool.workerEmit({\n      message: formatError(e),\n      testName: test.testName,\n      reason: DiagnosticReason.SNAPSHOT_ERROR,\n      duration: (Date.now() - start) / 1000,\n    } as Diagnostic);\n  } finally {\n    clearTimeout(timer);\n  }\n\n  return failedTests;\n}\n\nworkerpool.worker({\n  snapshotTestWorker,\n  integTestWorker,\n  watchTestWorker,\n});\n"]}
@@ -4900,7 +4900,7 @@ var require_semver2 = __commonJS({
4900
4900
  // ../cloud-assembly-schema/cli-version.json
4901
4901
  var require_cli_version = __commonJS({
4902
4902
  "../cloud-assembly-schema/cli-version.json"(exports2, module2) {
4903
- module2.exports = { version: "2.1034.0" };
4903
+ module2.exports = { version: "2.1100.1" };
4904
4904
  }
4905
4905
  });
4906
4906
 
@@ -269229,7 +269229,8 @@ var init_early_validation = __esm({
269229
269229
  }
269230
269230
  return `The template cannot be deployed because of early validation errors, but retrieving more details about those
269231
269231
  errors failed (${error4}). Make sure you have permissions to call the DescribeEvents API, or re-bootstrap
269232
- your environment with the latest version of the CLI (need at least version 30, current version ${currentVersion ?? "unknown"}).`;
269232
+ your environment by running 'cdk bootstrap' to update the Bootstrap CDK Toolkit stack.
269233
+ Bootstrap toolkit stack version 30 or later is needed; current version: ${currentVersion ?? "unknown"}.`;
269233
269234
  }
269234
269235
  let message2 = `ChangeSet '${changeSetName}' on stack '${stackName}' failed early validation`;
269235
269236
  if (operationEvents.length > 0) {
@@ -275375,6 +275376,7 @@ var init_toolkit_lib = __esm({
275375
275376
  ioHost: this.showOutput ? this.ioHost : new NoopIoHost(),
275376
275377
  sdkConfig: {
275377
275378
  baseCredentials: import_toolkit_lib.BaseCredentials.awsCliCompatible({
275379
+ profile: options.profile,
275378
275380
  defaultRegion: options.region
275379
275381
  })
275380
275382
  }
@@ -275645,7 +275647,8 @@ function makeEngine(options) {
275645
275647
  workingDirectory: options.test.directory,
275646
275648
  showOutput: options.showOutput,
275647
275649
  env: options.env,
275648
- region: options.region
275650
+ region: options.region,
275651
+ profile: options.profile
275649
275652
  });
275650
275653
  case "cli-wrapper":
275651
275654
  default:
@@ -277201,7 +277204,7 @@ async function snapshotTestWorker(testInfo, options = {}) {
277201
277204
  const test = new IntegTest(testInfo);
277202
277205
  const timer = setTimeout(() => {
277203
277206
  workerpool2.workerEmit({
277204
- reason: "SNAPSHOT_ERROR" /* SNAPSHOT_ERROR */,
277207
+ reason: "TEST_WARNING" /* TEST_WARNING */,
277205
277208
  testName: test.testName,
277206
277209
  message: "Test is taking a very long time",
277207
277210
  duration: (Date.now() - start) / 1e3
package/package.json CHANGED
@@ -66,12 +66,12 @@
66
66
  "@aws-cdk/aws-service-spec": "^0.1.130",
67
67
  "@aws-cdk/cdk-assets-lib": "1.1.0",
68
68
  "@aws-cdk/cdk-cli-wrapper": "0.0.0",
69
- "@aws-cdk/cloud-assembly-schema": ">=49.0.0",
69
+ "@aws-cdk/cloud-assembly-schema": ">=49.2.0",
70
70
  "@aws-cdk/cloudformation-diff": "2.185.0",
71
71
  "@aws-cdk/cx-api": "^2.232.1",
72
- "@aws-cdk/toolkit-lib": "1.12.0",
72
+ "@aws-cdk/toolkit-lib": "1.12.2",
73
73
  "@aws-sdk/client-cloudformation": "^3",
74
- "aws-cdk": "2.1034.0",
74
+ "aws-cdk": "2.1100.1",
75
75
  "chalk": "^4",
76
76
  "chokidar": "^3",
77
77
  "fs-extra": "^9",
@@ -80,7 +80,7 @@
80
80
  },
81
81
  "dependencies": {
82
82
  "@aws-cdk/aws-service-spec": "0.1.130",
83
- "aws-cdk": "2.1034.0"
83
+ "aws-cdk": "2.1100.1"
84
84
  },
85
85
  "keywords": [
86
86
  "aws",
@@ -95,7 +95,7 @@
95
95
  "publishConfig": {
96
96
  "access": "public"
97
97
  },
98
- "version": "2.193.0",
98
+ "version": "2.193.2",
99
99
  "types": "lib/index.d.ts",
100
100
  "//": "~~ Generated by projen. To modify, edit .projenrc.js and run \"npx projen\".",
101
101
  "optionalDependencies": {