@aws-cdk/integ-runner 2.194.2 → 2.196.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -305,4 +305,4 @@ class NoopIoHost {
305
305
  return msg.defaultResponse;
306
306
  }
307
307
  }
308
- //# 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 { UNKNOWN_REGION } from '@aws-cdk/cloud-assembly-api';\nimport type { DefaultCdkOptions, DestroyOptions } from '@aws-cdk/cloud-assembly-schema/lib/integ-tests';\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      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: 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"]}
308
+ //# 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, DestroyOptions } from '@aws-cdk/cloud-assembly-schema/lib/integ-tests';\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';\nimport type { DeployOptions, ICdk, ListOptions, SynthFastOptions, SynthOptions, WatchEvents } 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 = 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      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: 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
@@ -5549,6 +5549,62 @@ var init_integration_tests = __esm({
5549
5549
  }
5550
5550
  });
5551
5551
 
5552
+ // lib/unstable-features.ts
5553
+ function processUnstableFeatures(unstableFeatures = []) {
5554
+ const validFeatures = [];
5555
+ for (const featureName of unstableFeatures) {
5556
+ const feature = UNSTABLE_FEATURES[featureName];
5557
+ if (!feature) {
5558
+ warning(`Unknown unstable feature: '${featureName}'. This option will be ignored.`);
5559
+ continue;
5560
+ }
5561
+ switch (feature.status) {
5562
+ case "removed" /* REMOVED */:
5563
+ warning(`[Removed] ${feature.deprecationMessage}`);
5564
+ if (feature.removalMessage) {
5565
+ warning(feature.removalMessage);
5566
+ }
5567
+ break;
5568
+ case "deprecated" /* DEPRECATED */:
5569
+ warning(`[Deprecated] ${feature.deprecationMessage}`);
5570
+ validFeatures.push(featureName);
5571
+ break;
5572
+ case "supported" /* SUPPORTED */:
5573
+ validFeatures.push(featureName);
5574
+ break;
5575
+ }
5576
+ }
5577
+ return validFeatures;
5578
+ }
5579
+ function availableFeaturesDescription() {
5580
+ const availableFeatures = Object.entries(UNSTABLE_FEATURES).filter(([_, feature]) => feature.status === "supported" /* SUPPORTED */).map(([name]) => name);
5581
+ if (availableFeatures.length === 0) {
5582
+ return "Currently no unstable features are available.";
5583
+ }
5584
+ return `Available features: ${availableFeatures.join(", ")}.`;
5585
+ }
5586
+ var UNSTABLE_FEATURES;
5587
+ var init_unstable_features = __esm({
5588
+ "lib/unstable-features.ts"() {
5589
+ "use strict";
5590
+ init_logger();
5591
+ UNSTABLE_FEATURES = {
5592
+ "deprecated-cli-engine": {
5593
+ status: "removed" /* REMOVED */,
5594
+ deprecationMessage: "You have opted-in to use the deprecated CLI engine which is scheduled to be removed in January 2026. If you have encountered blockers while using the new default engine, please let us know by opening an issue: https://github.com/aws/aws-cdk-cli/issues/new/choose\n\nTo use the new default engine, remove the `--unstable=deprecated-cli-engine` option.",
5595
+ removalMessage: "The CLI engine has been removed. The toolkit-lib engine is now the only supported engine. Please remove this flag."
5596
+ },
5597
+ "toolkit-lib-engine": {
5598
+ status: "removed" /* REMOVED */,
5599
+ deprecationMessage: "The toolkit-lib engine is now the default engine. This flag can be safely removed. You may choose to temporarily revert to the old engine by adding the `--unstable=deprecated-cli-engine` option.",
5600
+ removalMessage: "The toolkit-lib engine is now the default and only engine. This flag can be safely removed."
5601
+ }
5602
+ };
5603
+ __name(processUnstableFeatures, "processUnstableFeatures");
5604
+ __name(availableFeaturesDescription, "availableFeaturesDescription");
5605
+ }
5606
+ });
5607
+
5552
5608
  // lib/workers/common.ts
5553
5609
  function printSummary(total, failed) {
5554
5610
  if (failed > 0) {
@@ -5720,8 +5776,7 @@ async function runIntegrationTestsInParallel(options) {
5720
5776
  clean: options.clean,
5721
5777
  dryRun: options.dryRun,
5722
5778
  verbosity: options.verbosity,
5723
- updateWorkflow: options.updateWorkflow,
5724
- engine: options.engine
5779
+ updateWorkflow: options.updateWorkflow
5725
5780
  }], {
5726
5781
  on: printResults
5727
5782
  });
@@ -10493,14 +10548,14 @@ function parseCliArgs(args = []) {
10493
10548
  configParser: configFromFile,
10494
10549
  default: "integ.config.json",
10495
10550
  desc: "Load options from a JSON config file. Options provided as CLI arguments take precedent."
10496
- }).option("watch", { type: "boolean", default: false, desc: "Perform integ tests in watch mode" }).option("list", { type: "boolean", default: false, desc: "List tests instead of running them" }).option("clean", { type: "boolean", default: true, desc: "Clean up and delete stack after test is completed (use --no-clean to negate)" }).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)" }).option("dry-run", { type: "boolean", default: false, desc: "do not actually deploy the stack. just update the snapshot (not recommended!)" }).option("update-on-failed", { type: "boolean", default: false, desc: "rerun integration tests and update snapshots for failed tests." }).option("force", { type: "boolean", default: false, desc: "Rerun all integration tests even if tests are passing" }).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: [] }).options("directory", { type: "string", default: "test", desc: "starting directory to discover integration tests. Tests will be discovered recursively from this directory" }).options("profiles", { type: "array", desc: "list of AWS profiles to use. Tests will be run in parallel across each profile+regions", default: [] }).options("max-workers", { type: "number", desc: "The max number of workerpool workers to use when running integration tests in parallel", default: 16 }).options("exclude", { type: "boolean", desc: "Run all tests in the directory, except the specified TESTs", default: false }).option("strict", { type: "boolean", default: false, desc: "Fail if any specified tests are not found" }).options("from-file", { type: "string", desc: "Read TEST names from a file (one TEST per line)" }).option("inspect-failures", { type: "boolean", desc: "Keep the integ test cloud assembly if a failure occurs for inspection", default: false }).option("disable-update-workflow", { type: "boolean", default: void 0, desc: "DEPRECATED, use --[no]-update-workflow instead" }).option("update-workflow", { type: "boolean", default: void 0, desc: "Deploys the committed snapshot before the updated application. Only works if snapshots are region-agnostic." }).option("language", {
10551
+ }).option("watch", { type: "boolean", default: false, desc: "Perform integ tests in watch mode" }).option("list", { type: "boolean", default: false, desc: "List tests instead of running them" }).option("clean", { type: "boolean", default: true, desc: "Clean up and delete stack after test is completed (use --no-clean to negate)" }).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)" }).option("dry-run", { type: "boolean", default: false, desc: "do not actually deploy the stack. just update the snapshot (not recommended!)" }).option("update-on-failed", { type: "boolean", default: false, desc: "rerun integration tests and update snapshots for failed tests." }).option("force", { type: "boolean", default: false, desc: "Rerun all integration tests even if tests are passing" }).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 }).options("directory", { type: "string", default: "test", desc: "starting directory to discover integration tests. Tests will be discovered recursively from this directory" }).options("profiles", { type: "array", desc: "list of AWS profiles to use. Tests will be run in parallel across each profile+regions", default: [], coerce: splitByComma }).options("max-workers", { type: "number", desc: "The max number of workerpool workers to use when running integration tests in parallel", default: 16 }).options("exclude", { type: "boolean", desc: "Run all tests in the directory, except the specified TESTs", default: false }).option("strict", { type: "boolean", default: false, desc: "Fail if any specified tests are not found" }).options("from-file", { type: "string", desc: "Read TEST names from a file (one TEST per line)" }).option("inspect-failures", { type: "boolean", desc: "Keep the integ test cloud assembly if a failure occurs for inspection", default: false }).option("disable-update-workflow", { type: "boolean", default: void 0, desc: "DEPRECATED, use --[no]-update-workflow instead" }).option("update-workflow", { type: "boolean", default: void 0, desc: "Deploys the committed snapshot before the updated application. Only works if snapshots are region-agnostic." }).option("language", {
10497
10552
  alias: "l",
10498
10553
  default: ["javascript", "typescript", "python", "go"],
10499
10554
  choices: ["javascript", "typescript", "python", "go"],
10500
10555
  type: "array",
10501
10556
  nargs: 1,
10502
10557
  desc: "Use these presets to run integration tests for the selected languages"
10503
- }).option("app", { type: "string", default: void 0, 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}".' }).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: [] }).option("unstable", { type: "array", desc: "Opt-in to using unstable features. By using these flags you acknowledges that scope and APIs of unstable features may change without notice. Specify multiple times for each unstable feature you want to opt-in to.", nargs: 1, choices: ["toolkit-lib-engine", "deprecated-cli-engine"], default: [] }).strict().parse(args);
10558
+ }).option("app", { type: "string", default: void 0, 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}".' }).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: [] }).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: [] }).strict().parse(args);
10504
10559
  const tests = argv._;
10505
10560
  const parallelRegions = arrayFromYargs(argv["parallel-regions"]);
10506
10561
  const testRegions = parallelRegions ?? ["us-east-1", "us-east-2", "us-west-2"];
@@ -10519,7 +10574,7 @@ function parseCliArgs(args = []) {
10519
10574
  if (argv.strict && argv.exclude) {
10520
10575
  throw new Error("Cannot use --strict with --exclude");
10521
10576
  }
10522
- const requestedTests = fromFile ? fs2.readFileSync(fromFile, { encoding: "utf8" }).split("\n").filter((x) => x) : tests.length > 0 ? tests : void 0;
10577
+ const requestedTests = fromFile ? fs2.readFileSync(fromFile, { encoding: "utf8" }).split("\n").filter((x) => x).filter((x) => !x.startsWith("#")) : tests.length > 0 ? tests : void 0;
10523
10578
  if (argv["disable-update-workflow"] !== void 0 && argv["update-workflow"] !== void 0) {
10524
10579
  throw new Error("--disable-update-workflow and --[no-]update-workflow cannot be used together");
10525
10580
  }
@@ -10551,21 +10606,16 @@ function parseCliArgs(args = []) {
10551
10606
  };
10552
10607
  }
10553
10608
  async function main(args) {
10554
- let engineForError;
10555
10609
  try {
10556
10610
  const options = parseCliArgs(args);
10557
- const engine = engineFromOptions(options);
10558
- engineForError = engine.engine;
10559
- await run(options, engine);
10611
+ options.unstable = processUnstableFeatures(options.unstable);
10612
+ await run(options);
10560
10613
  } catch (err) {
10561
10614
  error(err);
10562
- if (engineForError === "toolkit-lib") {
10563
- warning("\n[Notice] You are using the new default engine to run integration tests. If you think the above failure has been caused by the new engine, you may choose to temporarily revert to the old engine by adding the `--unstable=deprecated-cli-engine` option. Please note that this engine is deprecated and scheduled to be removed in January 2026.\n\nIf reverting to the old engine resolves an issue for you, please let us know so we can address this in the new engine. Report issues here: https://github.com/aws/aws-cdk-cli/issues/new/choose");
10564
- }
10565
10615
  throw err;
10566
10616
  }
10567
10617
  }
10568
- async function run(options, { engine }) {
10618
+ async function run(options) {
10569
10619
  const testsFromArgs = await new IntegrationTests(path2.resolve(options.directory)).fromCliOptions(options);
10570
10620
  if (options.list) {
10571
10621
  process.stdout.write(testsFromArgs.map((t) => t.discoveryRelativeFileName).join("\n") + "\n");
@@ -10587,8 +10637,7 @@ async function run(options, { engine }) {
10587
10637
  if (!options.watch) {
10588
10638
  failedSnapshots = await runSnapshotTests(pool2, testsFromArgs, {
10589
10639
  retain: options.inspectFailures,
10590
- verbose: options.verbose,
10591
- engine
10640
+ verbose: options.verbose
10592
10641
  });
10593
10642
  for (const failure of failedSnapshots) {
10594
10643
  warning(`Failed: ${failure.fileName}`);
@@ -10608,7 +10657,6 @@ async function run(options, { engine }) {
10608
10657
  if (options.runUpdateOnFailed || options.force) {
10609
10658
  const { success: success2, metrics } = await runIntegrationTests({
10610
10659
  pool: pool2,
10611
- engine,
10612
10660
  tests: testsToRun,
10613
10661
  regions: options.testRegions,
10614
10662
  profiles: options.profiles,
@@ -10631,7 +10679,6 @@ async function run(options, { engine }) {
10631
10679
  } else if (options.watch) {
10632
10680
  await watchIntegrationTest(pool2, {
10633
10681
  watch: true,
10634
- engine,
10635
10682
  verbosity: options.verbosity,
10636
10683
  ...testsToRun[0],
10637
10684
  profile: options.profiles ? options.profiles[0] : void 0,
@@ -10710,12 +10757,8 @@ function configFromFile(fileName) {
10710
10757
  return {};
10711
10758
  }
10712
10759
  }
10713
- function engineFromOptions(options) {
10714
- if (options.unstable?.includes("deprecated-cli-engine")) {
10715
- warning("[Deprecation Notice] You have opted-in to use the deprecated CLI engine which is scheduled to be removed in January 2026. If you have encountered blockers while using the new default engine, please let us know by opening an issue: https://github.com/aws/aws-cdk-cli/issues/new/choose\n\nTo use the new default engine, remove the `--unstable=deprecated-cli-engine` option.");
10716
- return { engine: "cli-wrapper" };
10717
- }
10718
- return { engine: "toolkit-lib" };
10760
+ function splitByComma(xs) {
10761
+ return xs.flatMap((x) => x.split(",")).map((x) => x.trim());
10719
10762
  }
10720
10763
  var fs2, path2, chalk3, workerpool, yargs;
10721
10764
  var init_cli = __esm({
@@ -10727,6 +10770,7 @@ var init_cli = __esm({
10727
10770
  workerpool = __toESM(require_src());
10728
10771
  init_logger();
10729
10772
  init_integration_tests();
10773
+ init_unstable_features();
10730
10774
  init_workers();
10731
10775
  init_integ_watch_worker();
10732
10776
  yargs = require_yargs();
@@ -10740,7 +10784,7 @@ var init_cli = __esm({
10740
10784
  __name(mergeTests, "mergeTests");
10741
10785
  __name(cli, "cli");
10742
10786
  __name(configFromFile, "configFromFile");
10743
- __name(engineFromOptions, "engineFromOptions");
10787
+ __name(splitByComma, "splitByComma");
10744
10788
  }
10745
10789
  });
10746
10790
 
@@ -1,11 +1,8 @@
1
- import type { ICdk } from '@aws-cdk/cdk-cli-wrapper';
2
1
  import type { IntegRunnerOptions } from './runner-base';
3
- export interface EngineOptions {
4
- /**
5
- * The CDK Toolkit engine to be used by the runner.
6
- *
7
- * @default "cli-wrapper"
8
- */
9
- readonly engine?: 'cli-wrapper' | 'toolkit-lib';
10
- }
11
- export declare function makeEngine(options: IntegRunnerOptions): ICdk;
2
+ import { ToolkitLibRunnerEngine } from '../engines/toolkit-lib';
3
+ /**
4
+ * Creates the engine for running integration tests.
5
+ *
6
+ * Only the toolkit-lib engine is supported.
7
+ */
8
+ export declare function makeEngine(options: IntegRunnerOptions): ToolkitLibRunnerEngine;
@@ -1,29 +1,19 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.makeEngine = makeEngine;
4
- const cdk_cli_wrapper_1 = require("@aws-cdk/cdk-cli-wrapper");
5
4
  const toolkit_lib_1 = require("../engines/toolkit-lib");
5
+ /**
6
+ * Creates the engine for running integration tests.
7
+ *
8
+ * Only the toolkit-lib engine is supported.
9
+ */
6
10
  function makeEngine(options) {
7
- switch (options.engine) {
8
- case 'toolkit-lib':
9
- return new toolkit_lib_1.ToolkitLibRunnerEngine({
10
- workingDirectory: options.test.directory,
11
- showOutput: options.showOutput,
12
- env: options.env,
13
- region: options.region,
14
- profile: options.profile,
15
- });
16
- case 'cli-wrapper':
17
- default:
18
- return new cdk_cli_wrapper_1.CdkCliWrapper({
19
- directory: options.test.directory,
20
- showOutput: options.showOutput,
21
- env: {
22
- ...options.env,
23
- // The CDK CLI will interpret this and use it usefully
24
- AWS_REGION: options.region,
25
- },
26
- });
27
- }
11
+ return new toolkit_lib_1.ToolkitLibRunnerEngine({
12
+ workingDirectory: options.test.directory,
13
+ showOutput: options.showOutput,
14
+ env: options.env,
15
+ region: options.region,
16
+ profile: options.profile,
17
+ });
28
18
  }
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW5naW5lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZW5naW5lLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBY0EsZ0NBc0JDO0FBbkNELDhEQUF5RDtBQUV6RCx3REFBZ0U7QUFXaEUsU0FBZ0IsVUFBVSxDQUFDLE9BQTJCO0lBQ3BELFFBQVEsT0FBTyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ3ZCLEtBQUssYUFBYTtZQUNoQixPQUFPLElBQUksb0NBQXNCLENBQUM7Z0JBQ2hDLGdCQUFnQixFQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsU0FBUztnQkFDeEMsVUFBVSxFQUFFLE9BQU8sQ0FBQyxVQUFVO2dCQUM5QixHQUFHLEVBQUUsT0FBTyxDQUFDLEdBQUc7Z0JBQ2hCLE1BQU0sRUFBRSxPQUFPLENBQUMsTUFBTTtnQkFDdEIsT0FBTyxFQUFFLE9BQU8sQ0FBQyxPQUFPO2FBQ3pCLENBQUMsQ0FBQztRQUNMLEtBQUssYUFBYSxDQUFDO1FBQ25CO1lBQ0UsT0FBTyxJQUFJLCtCQUFhLENBQUM7Z0JBQ3ZCLFNBQVMsRUFBRSxPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVM7Z0JBQ2pDLFVBQVUsRUFBRSxPQUFPLENBQUMsVUFBVTtnQkFDOUIsR0FBRyxFQUFFO29CQUNILEdBQUcsT0FBTyxDQUFDLEdBQUc7b0JBQ2Qsc0RBQXNEO29CQUN0RCxVQUFVLEVBQUUsT0FBTyxDQUFDLE1BQU07aUJBQzNCO2FBQ0YsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IElDZGsgfSBmcm9tICdAYXdzLWNkay9jZGstY2xpLXdyYXBwZXInO1xuaW1wb3J0IHsgQ2RrQ2xpV3JhcHBlciB9IGZyb20gJ0Bhd3MtY2RrL2Nkay1jbGktd3JhcHBlcic7XG5pbXBvcnQgdHlwZSB7IEludGVnUnVubmVyT3B0aW9ucyB9IGZyb20gJy4vcnVubmVyLWJhc2UnO1xuaW1wb3J0IHsgVG9vbGtpdExpYlJ1bm5lckVuZ2luZSB9IGZyb20gJy4uL2VuZ2luZXMvdG9vbGtpdC1saWInO1xuXG5leHBvcnQgaW50ZXJmYWNlIEVuZ2luZU9wdGlvbnMge1xuICAvKipcbiAgICogVGhlIENESyBUb29sa2l0IGVuZ2luZSB0byBiZSB1c2VkIGJ5IHRoZSBydW5uZXIuXG4gICAqXG4gICAqIEBkZWZhdWx0IFwiY2xpLXdyYXBwZXJcIlxuICAgKi9cbiAgcmVhZG9ubHkgZW5naW5lPzogJ2NsaS13cmFwcGVyJyB8ICd0b29sa2l0LWxpYic7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBtYWtlRW5naW5lKG9wdGlvbnM6IEludGVnUnVubmVyT3B0aW9ucyk6IElDZGsge1xuICBzd2l0Y2ggKG9wdGlvbnMuZW5naW5lKSB7XG4gICAgY2FzZSAndG9vbGtpdC1saWInOlxuICAgICAgcmV0dXJuIG5ldyBUb29sa2l0TGliUnVubmVyRW5naW5lKHtcbiAgICAgICAgd29ya2luZ0RpcmVjdG9yeTogb3B0aW9ucy50ZXN0LmRpcmVjdG9yeSxcbiAgICAgICAgc2hvd091dHB1dDogb3B0aW9ucy5zaG93T3V0cHV0LFxuICAgICAgICBlbnY6IG9wdGlvbnMuZW52LFxuICAgICAgICByZWdpb246IG9wdGlvbnMucmVnaW9uLFxuICAgICAgICBwcm9maWxlOiBvcHRpb25zLnByb2ZpbGUsXG4gICAgICB9KTtcbiAgICBjYXNlICdjbGktd3JhcHBlcic6XG4gICAgZGVmYXVsdDpcbiAgICAgIHJldHVybiBuZXcgQ2RrQ2xpV3JhcHBlcih7XG4gICAgICAgIGRpcmVjdG9yeTogb3B0aW9ucy50ZXN0LmRpcmVjdG9yeSxcbiAgICAgICAgc2hvd091dHB1dDogb3B0aW9ucy5zaG93T3V0cHV0LFxuICAgICAgICBlbnY6IHtcbiAgICAgICAgICAuLi5vcHRpb25zLmVudixcbiAgICAgICAgICAvLyBUaGUgQ0RLIENMSSB3aWxsIGludGVycHJldCB0aGlzIGFuZCB1c2UgaXQgdXNlZnVsbHlcbiAgICAgICAgICBBV1NfUkVHSU9OOiBvcHRpb25zLnJlZ2lvbixcbiAgICAgICAgfSxcbiAgICAgIH0pO1xuICB9XG59XG5cbiJdfQ==
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW5naW5lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZW5naW5lLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBUUEsZ0NBUUM7QUFmRCx3REFBZ0U7QUFFaEU7Ozs7R0FJRztBQUNILFNBQWdCLFVBQVUsQ0FBQyxPQUEyQjtJQUNwRCxPQUFPLElBQUksb0NBQXNCLENBQUM7UUFDaEMsZ0JBQWdCLEVBQUUsT0FBTyxDQUFDLElBQUksQ0FBQyxTQUFTO1FBQ3hDLFVBQVUsRUFBRSxPQUFPLENBQUMsVUFBVTtRQUM5QixHQUFHLEVBQUUsT0FBTyxDQUFDLEdBQUc7UUFDaEIsTUFBTSxFQUFFLE9BQU8sQ0FBQyxNQUFNO1FBQ3RCLE9BQU8sRUFBRSxPQUFPLENBQUMsT0FBTztLQUN6QixDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBJbnRlZ1J1bm5lck9wdGlvbnMgfSBmcm9tICcuL3J1bm5lci1iYXNlJztcbmltcG9ydCB7IFRvb2xraXRMaWJSdW5uZXJFbmdpbmUgfSBmcm9tICcuLi9lbmdpbmVzL3Rvb2xraXQtbGliJztcblxuLyoqXG4gKiBDcmVhdGVzIHRoZSBlbmdpbmUgZm9yIHJ1bm5pbmcgaW50ZWdyYXRpb24gdGVzdHMuXG4gKlxuICogT25seSB0aGUgdG9vbGtpdC1saWIgZW5naW5lIGlzIHN1cHBvcnRlZC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIG1ha2VFbmdpbmUob3B0aW9uczogSW50ZWdSdW5uZXJPcHRpb25zKTogVG9vbGtpdExpYlJ1bm5lckVuZ2luZSB7XG4gIHJldHVybiBuZXcgVG9vbGtpdExpYlJ1bm5lckVuZ2luZSh7XG4gICAgd29ya2luZ0RpcmVjdG9yeTogb3B0aW9ucy50ZXN0LmRpcmVjdG9yeSxcbiAgICBzaG93T3V0cHV0OiBvcHRpb25zLnNob3dPdXRwdXQsXG4gICAgZW52OiBvcHRpb25zLmVudixcbiAgICByZWdpb246IG9wdGlvbnMucmVnaW9uLFxuICAgIHByb2ZpbGU6IG9wdGlvbnMucHJvZmlsZSxcbiAgfSk7XG59XG4iXX0=