@aws-cdk/integ-runner 2.187.1 → 2.187.3

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.
@@ -80,7 +80,7 @@ class LegacyIntegTestSuite extends IntegTestSuite {
80
80
  * /// !cdk-integ <stack-name>
81
81
  *
82
82
  */
83
- static fromLegacy(config) {
83
+ static async fromLegacy(config) {
84
84
  const pragmas = this.pragmas(config.integSourceFilePath);
85
85
  const tests = {
86
86
  stacks: [],
@@ -96,7 +96,7 @@ class LegacyIntegTestSuite extends IntegTestSuite {
96
96
  ...config.listOptions,
97
97
  notices: false,
98
98
  };
99
- const stacks = (config.cdk.list(options)).split('\n');
99
+ const stacks = await config.cdk.list(options);
100
100
  if (stacks.length !== 1) {
101
101
  throw new Error('"cdk-integ" can only operate on apps with a single stack.\n\n' +
102
102
  ' If your app has multiple stacks, specify which stack to select by adding this to your test source:\n\n' +
@@ -195,4 +195,4 @@ class LegacyIntegTestSuite extends IntegTestSuite {
195
195
  }
196
196
  }
197
197
  exports.LegacyIntegTestSuite = LegacyIntegTestSuite;
198
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"integ-test-suite.js","sourceRoot":"","sources":["integ-test-suite.ts"],"names":[],"mappings":"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","sourcesContent":["import * as osPath from 'path';\nimport type { ICdk, ListOptions } from '@aws-cdk/cdk-cli-wrapper';\nimport type { TestCase, TestOptions, IntegManifest } from '@aws-cdk/cloud-assembly-schema';\nimport { Manifest } from '@aws-cdk/cloud-assembly-schema';\nimport * as fs from 'fs-extra';\nimport { IntegManifestReader } from './private/integ-manifest';\n\nconst CDK_INTEG_STACK_PRAGMA = '/// !cdk-integ';\nconst PRAGMA_PREFIX = 'pragma:';\nconst SET_CONTEXT_PRAGMA_PREFIX = 'pragma:set-context:';\nconst VERIFY_ASSET_HASHES = 'pragma:include-assets-hashes';\nconst DISABLE_UPDATE_WORKFLOW = 'pragma:disable-update-workflow';\nconst ENABLE_LOOKUPS_PRAGMA = 'pragma:enable-lookups';\n\n/**\n * Represents an integration test\n */\nexport type TestSuite = { [testName: string]: TestCase };\n\nexport type TestSuiteType = 'test-suite' | 'legacy-test-suite';\n\n/**\n * Helper class for working with Integration tests\n * This requires an `integ.json` file in the snapshot\n * directory. For legacy test cases use LegacyIntegTestCases\n */\nexport class IntegTestSuite {\n  /**\n   * Loads integ tests from a snapshot directory\n   */\n  public static fromPath(path: string): IntegTestSuite {\n    const reader = IntegManifestReader.fromPath(path);\n    return new IntegTestSuite(\n      reader.tests.enableLookups,\n      reader.tests.testCases,\n      reader.tests.synthContext,\n    );\n  }\n\n  public readonly type: TestSuiteType = 'test-suite';\n\n  constructor(\n    public readonly enableLookups: boolean,\n    public readonly testSuite: TestSuite,\n    public readonly synthContext?: { [name: string]: string },\n  ) {\n  }\n\n  /**\n   * Returns a list of stacks that have stackUpdateWorkflow disabled\n   */\n  public getStacksWithoutUpdateWorkflow(): string[] {\n    return Object.values(this.testSuite)\n      .filter(testCase => !(testCase.stackUpdateWorkflow ?? true))\n      .flatMap((testCase: TestCase) => testCase.stacks);\n  }\n\n  /**\n   * Returns test case options for a given stack\n   */\n  public getOptionsForStack(stackId: string): TestOptions | undefined {\n    for (const testCase of Object.values(this.testSuite ?? {})) {\n      if (testCase.stacks.includes(stackId)) {\n        return {\n          hooks: testCase.hooks,\n          regions: testCase.regions,\n          diffAssets: testCase.diffAssets ?? false,\n          allowDestroy: testCase.allowDestroy,\n          cdkCommandOptions: testCase.cdkCommandOptions,\n          stackUpdateWorkflow: testCase.stackUpdateWorkflow ?? true,\n        };\n      }\n    }\n    return undefined;\n  }\n\n  /**\n   * Get a list of stacks in the test suite\n   */\n  public get stacks(): string[] {\n    return Object.values(this.testSuite).flatMap(testCase => testCase.stacks);\n  }\n}\n\n/**\n * Options for a reading a legacy test case manifest\n */\nexport interface LegacyTestCaseConfig {\n  /**\n   * The name of the test case\n   */\n  readonly testName: string;\n\n  /**\n   * Options to use when performing `cdk list`\n   * This is used to determine the name of the stacks\n   * in the test case\n   */\n  readonly listOptions: ListOptions;\n\n  /**\n   * An instance of the CDK CLI (e.g. CdkCliWrapper)\n   */\n  readonly cdk: ICdk;\n\n  /**\n   * The path to the integration test file\n   * i.e. integ.test.js\n   */\n  readonly integSourceFilePath: string;\n}\n\n/**\n * Helper class for creating an integ manifest for legacy\n * test cases, i.e. tests without a `integ.json`.\n */\nexport class LegacyIntegTestSuite extends IntegTestSuite {\n  /**\n   * Returns the single test stack to use.\n   *\n   * If the test has a single stack, it will be chosen. Otherwise a pragma is expected within the\n   * test file the name of the stack:\n   *\n   * @example\n   *\n   *    /// !cdk-integ <stack-name>\n   *\n   */\n  public static fromLegacy(config: LegacyTestCaseConfig): LegacyIntegTestSuite {\n    const pragmas = this.pragmas(config.integSourceFilePath);\n    const tests: TestCase = {\n      stacks: [],\n      diffAssets: pragmas.includes(VERIFY_ASSET_HASHES),\n      stackUpdateWorkflow: !pragmas.includes(DISABLE_UPDATE_WORKFLOW),\n    };\n    const pragma = this.readStackPragma(config.integSourceFilePath);\n    if (pragma.length > 0) {\n      tests.stacks.push(...pragma);\n    } else {\n      const options: ListOptions = {\n        ...config.listOptions,\n        notices: false,\n      };\n      const stacks = (config.cdk.list(options)).split('\\n');\n      if (stacks.length !== 1) {\n        throw new Error('\"cdk-integ\" can only operate on apps with a single stack.\\n\\n' +\n          '  If your app has multiple stacks, specify which stack to select by adding this to your test source:\\n\\n' +\n          `      ${CDK_INTEG_STACK_PRAGMA} STACK ...\\n\\n` +\n          `  Available stacks: ${stacks.join(' ')} (wildcards are also supported)\\n`);\n      }\n      if (stacks.length === 1 && stacks[0] === '') {\n        throw new Error(`No stack found for test ${config.testName}`);\n      }\n      tests.stacks.push(...stacks);\n    }\n\n    return new LegacyIntegTestSuite(\n      pragmas.includes(ENABLE_LOOKUPS_PRAGMA),\n      {\n        [config.testName]: tests,\n      },\n      LegacyIntegTestSuite.getPragmaContext(config.integSourceFilePath),\n    );\n  }\n\n  public static getPragmaContext(integSourceFilePath: string): Record<string, any> {\n    const ctxPragmaContext: Record<string, any> = {};\n\n    // apply context from set-context pragma\n    // usage: pragma:set-context:key=value\n    const ctxPragmas = (this.pragmas(integSourceFilePath)).filter(p => p.startsWith(SET_CONTEXT_PRAGMA_PREFIX));\n    for (const p of ctxPragmas) {\n      const instruction = p.substring(SET_CONTEXT_PRAGMA_PREFIX.length);\n      const [key, value] = instruction.split('=');\n      if (key == null || value == null) {\n        throw new Error(`invalid \"set-context\" pragma syntax. example: \"pragma:set-context:@aws-cdk/core:newStyleStackSynthesis=true\" got: ${p}`);\n      }\n\n      ctxPragmaContext[key] = value;\n    }\n    return {\n      ...ctxPragmaContext,\n    };\n  }\n\n  /**\n   * Reads stack names from the \"!cdk-integ\" pragma.\n   *\n   * Every word that's NOT prefixed by \"pragma:\" is considered a stack name.\n   *\n   * @example\n   *\n   *    /// !cdk-integ <stack-name>\n   */\n  private static readStackPragma(integSourceFilePath: string): string[] {\n    return (this.readIntegPragma(integSourceFilePath)).filter(p => !p.startsWith(PRAGMA_PREFIX));\n  }\n\n  /**\n   * Read arbitrary cdk-integ pragma directives\n   *\n   * Reads the test source file and looks for the \"!cdk-integ\" pragma. If it exists, returns it's\n   * contents. This allows integ tests to supply custom command line arguments to \"cdk deploy\" and \"cdk synth\".\n   *\n   * @example\n   *\n   *    /// !cdk-integ [...]\n   */\n  private static readIntegPragma(integSourceFilePath: string): string[] {\n    const source = fs.readFileSync(integSourceFilePath, { encoding: 'utf-8' });\n    const pragmaLine = source.split('\\n').find(x => x.startsWith(CDK_INTEG_STACK_PRAGMA + ' '));\n    if (!pragmaLine) {\n      return [];\n    }\n\n    const args = pragmaLine.substring(CDK_INTEG_STACK_PRAGMA.length).trim().split(' ');\n    if (args.length === 0) {\n      throw new Error(`Invalid syntax for cdk-integ pragma. Usage: \"${CDK_INTEG_STACK_PRAGMA} [STACK] [pragma:PRAGMA] [...]\"`);\n    }\n    return args;\n  }\n\n  /**\n   * Return the non-stack pragmas\n   *\n   * These are all pragmas that start with \"pragma:\".\n   *\n   * For backwards compatibility reasons, all pragmas that DON'T start with this\n   * string are considered to be stack names.\n   */\n  private static pragmas(integSourceFilePath: string): string[] {\n    return (this.readIntegPragma(integSourceFilePath)).filter(p => p.startsWith(PRAGMA_PREFIX));\n  }\n\n  public readonly type: TestSuiteType = 'legacy-test-suite';\n\n  constructor(\n    public readonly enableLookups: boolean,\n    public readonly testSuite: TestSuite,\n    public readonly synthContext?: { [name: string]: string },\n  ) {\n    super(enableLookups, testSuite);\n  }\n\n  /**\n   * Save the integ manifest to a directory\n   */\n  public saveManifest(directory: string, context?: Record<string, any>): void {\n    const manifest: IntegManifest = {\n      version: Manifest.version(),\n      testCases: this.testSuite,\n      synthContext: context,\n      enableLookups: this.enableLookups,\n    };\n    Manifest.saveIntegManifest(manifest, osPath.join(directory, IntegManifestReader.DEFAULT_FILENAME));\n  }\n}\n"]}
198
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"integ-test-suite.js","sourceRoot":"","sources":["integ-test-suite.ts"],"names":[],"mappings":"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","sourcesContent":["import * as osPath from 'path';\nimport type { ICdk, ListOptions } from '@aws-cdk/cdk-cli-wrapper';\nimport type { TestCase, TestOptions, IntegManifest } from '@aws-cdk/cloud-assembly-schema';\nimport { Manifest } from '@aws-cdk/cloud-assembly-schema';\nimport * as fs from 'fs-extra';\nimport { IntegManifestReader } from './private/integ-manifest';\n\nconst CDK_INTEG_STACK_PRAGMA = '/// !cdk-integ';\nconst PRAGMA_PREFIX = 'pragma:';\nconst SET_CONTEXT_PRAGMA_PREFIX = 'pragma:set-context:';\nconst VERIFY_ASSET_HASHES = 'pragma:include-assets-hashes';\nconst DISABLE_UPDATE_WORKFLOW = 'pragma:disable-update-workflow';\nconst ENABLE_LOOKUPS_PRAGMA = 'pragma:enable-lookups';\n\n/**\n * Represents an integration test\n */\nexport type TestSuite = { [testName: string]: TestCase };\n\nexport type TestSuiteType = 'test-suite' | 'legacy-test-suite';\n\n/**\n * Helper class for working with Integration tests\n * This requires an `integ.json` file in the snapshot\n * directory. For legacy test cases use LegacyIntegTestCases\n */\nexport class IntegTestSuite {\n  /**\n   * Loads integ tests from a snapshot directory\n   */\n  public static fromPath(path: string): IntegTestSuite {\n    const reader = IntegManifestReader.fromPath(path);\n    return new IntegTestSuite(\n      reader.tests.enableLookups,\n      reader.tests.testCases,\n      reader.tests.synthContext,\n    );\n  }\n\n  public readonly type: TestSuiteType = 'test-suite';\n\n  constructor(\n    public readonly enableLookups: boolean,\n    public readonly testSuite: TestSuite,\n    public readonly synthContext?: { [name: string]: string },\n  ) {\n  }\n\n  /**\n   * Returns a list of stacks that have stackUpdateWorkflow disabled\n   */\n  public getStacksWithoutUpdateWorkflow(): string[] {\n    return Object.values(this.testSuite)\n      .filter(testCase => !(testCase.stackUpdateWorkflow ?? true))\n      .flatMap((testCase: TestCase) => testCase.stacks);\n  }\n\n  /**\n   * Returns test case options for a given stack\n   */\n  public getOptionsForStack(stackId: string): TestOptions | undefined {\n    for (const testCase of Object.values(this.testSuite ?? {})) {\n      if (testCase.stacks.includes(stackId)) {\n        return {\n          hooks: testCase.hooks,\n          regions: testCase.regions,\n          diffAssets: testCase.diffAssets ?? false,\n          allowDestroy: testCase.allowDestroy,\n          cdkCommandOptions: testCase.cdkCommandOptions,\n          stackUpdateWorkflow: testCase.stackUpdateWorkflow ?? true,\n        };\n      }\n    }\n    return undefined;\n  }\n\n  /**\n   * Get a list of stacks in the test suite\n   */\n  public get stacks(): string[] {\n    return Object.values(this.testSuite).flatMap(testCase => testCase.stacks);\n  }\n}\n\n/**\n * Options for a reading a legacy test case manifest\n */\nexport interface LegacyTestCaseConfig {\n  /**\n   * The name of the test case\n   */\n  readonly testName: string;\n\n  /**\n   * Options to use when performing `cdk list`\n   * This is used to determine the name of the stacks\n   * in the test case\n   */\n  readonly listOptions: ListOptions;\n\n  /**\n   * An instance of the CDK CLI (e.g. CdkCliWrapper)\n   */\n  readonly cdk: ICdk;\n\n  /**\n   * The path to the integration test file\n   * i.e. integ.test.js\n   */\n  readonly integSourceFilePath: string;\n}\n\n/**\n * Helper class for creating an integ manifest for legacy\n * test cases, i.e. tests without a `integ.json`.\n */\nexport class LegacyIntegTestSuite extends IntegTestSuite {\n  /**\n   * Returns the single test stack to use.\n   *\n   * If the test has a single stack, it will be chosen. Otherwise a pragma is expected within the\n   * test file the name of the stack:\n   *\n   * @example\n   *\n   *    /// !cdk-integ <stack-name>\n   *\n   */\n  public static async fromLegacy(config: LegacyTestCaseConfig): Promise<LegacyIntegTestSuite> {\n    const pragmas = this.pragmas(config.integSourceFilePath);\n    const tests: TestCase = {\n      stacks: [],\n      diffAssets: pragmas.includes(VERIFY_ASSET_HASHES),\n      stackUpdateWorkflow: !pragmas.includes(DISABLE_UPDATE_WORKFLOW),\n    };\n    const pragma = this.readStackPragma(config.integSourceFilePath);\n    if (pragma.length > 0) {\n      tests.stacks.push(...pragma);\n    } else {\n      const options: ListOptions = {\n        ...config.listOptions,\n        notices: false,\n      };\n      const stacks = await config.cdk.list(options);\n      if (stacks.length !== 1) {\n        throw new Error('\"cdk-integ\" can only operate on apps with a single stack.\\n\\n' +\n          '  If your app has multiple stacks, specify which stack to select by adding this to your test source:\\n\\n' +\n          `      ${CDK_INTEG_STACK_PRAGMA} STACK ...\\n\\n` +\n          `  Available stacks: ${stacks.join(' ')} (wildcards are also supported)\\n`);\n      }\n      if (stacks.length === 1 && stacks[0] === '') {\n        throw new Error(`No stack found for test ${config.testName}`);\n      }\n      tests.stacks.push(...stacks);\n    }\n\n    return new LegacyIntegTestSuite(\n      pragmas.includes(ENABLE_LOOKUPS_PRAGMA),\n      {\n        [config.testName]: tests,\n      },\n      LegacyIntegTestSuite.getPragmaContext(config.integSourceFilePath),\n    );\n  }\n\n  public static getPragmaContext(integSourceFilePath: string): Record<string, any> {\n    const ctxPragmaContext: Record<string, any> = {};\n\n    // apply context from set-context pragma\n    // usage: pragma:set-context:key=value\n    const ctxPragmas = (this.pragmas(integSourceFilePath)).filter(p => p.startsWith(SET_CONTEXT_PRAGMA_PREFIX));\n    for (const p of ctxPragmas) {\n      const instruction = p.substring(SET_CONTEXT_PRAGMA_PREFIX.length);\n      const [key, value] = instruction.split('=');\n      if (key == null || value == null) {\n        throw new Error(`invalid \"set-context\" pragma syntax. example: \"pragma:set-context:@aws-cdk/core:newStyleStackSynthesis=true\" got: ${p}`);\n      }\n\n      ctxPragmaContext[key] = value;\n    }\n    return {\n      ...ctxPragmaContext,\n    };\n  }\n\n  /**\n   * Reads stack names from the \"!cdk-integ\" pragma.\n   *\n   * Every word that's NOT prefixed by \"pragma:\" is considered a stack name.\n   *\n   * @example\n   *\n   *    /// !cdk-integ <stack-name>\n   */\n  private static readStackPragma(integSourceFilePath: string): string[] {\n    return (this.readIntegPragma(integSourceFilePath)).filter(p => !p.startsWith(PRAGMA_PREFIX));\n  }\n\n  /**\n   * Read arbitrary cdk-integ pragma directives\n   *\n   * Reads the test source file and looks for the \"!cdk-integ\" pragma. If it exists, returns it's\n   * contents. This allows integ tests to supply custom command line arguments to \"cdk deploy\" and \"cdk synth\".\n   *\n   * @example\n   *\n   *    /// !cdk-integ [...]\n   */\n  private static readIntegPragma(integSourceFilePath: string): string[] {\n    const source = fs.readFileSync(integSourceFilePath, { encoding: 'utf-8' });\n    const pragmaLine = source.split('\\n').find(x => x.startsWith(CDK_INTEG_STACK_PRAGMA + ' '));\n    if (!pragmaLine) {\n      return [];\n    }\n\n    const args = pragmaLine.substring(CDK_INTEG_STACK_PRAGMA.length).trim().split(' ');\n    if (args.length === 0) {\n      throw new Error(`Invalid syntax for cdk-integ pragma. Usage: \"${CDK_INTEG_STACK_PRAGMA} [STACK] [pragma:PRAGMA] [...]\"`);\n    }\n    return args;\n  }\n\n  /**\n   * Return the non-stack pragmas\n   *\n   * These are all pragmas that start with \"pragma:\".\n   *\n   * For backwards compatibility reasons, all pragmas that DON'T start with this\n   * string are considered to be stack names.\n   */\n  private static pragmas(integSourceFilePath: string): string[] {\n    return (this.readIntegPragma(integSourceFilePath)).filter(p => p.startsWith(PRAGMA_PREFIX));\n  }\n\n  public readonly type: TestSuiteType = 'legacy-test-suite';\n\n  constructor(\n    public readonly enableLookups: boolean,\n    public readonly testSuite: TestSuite,\n    public readonly synthContext?: { [name: string]: string },\n  ) {\n    super(enableLookups, testSuite);\n  }\n\n  /**\n   * Save the integ manifest to a directory\n   */\n  public saveManifest(directory: string, context?: Record<string, any>): void {\n    const manifest: IntegManifest = {\n      version: Manifest.version(),\n      testCases: this.testSuite,\n      synthContext: context,\n      enableLookups: this.enableLookups,\n    };\n    Manifest.saveIntegManifest(manifest, osPath.join(directory, IntegManifestReader.DEFAULT_FILENAME));\n  }\n}\n"]}
@@ -75,14 +75,6 @@ export declare abstract class IntegRunner {
75
75
  * will be created
76
76
  */
77
77
  protected readonly cdkContextPath: string;
78
- /**
79
- * The test suite from the existing snapshot
80
- */
81
- protected readonly expectedTestSuite?: IntegTestSuite | LegacyIntegTestSuite;
82
- /**
83
- * The test suite from the new "actual" snapshot
84
- */
85
- protected readonly actualTestSuite: IntegTestSuite | LegacyIntegTestSuite;
86
78
  /**
87
79
  * The working directory that the integration tests will be
88
80
  * executed from
@@ -102,33 +94,45 @@ export declare abstract class IntegRunner {
102
94
  * Relative to cwd.
103
95
  */
104
96
  protected readonly cdkOutDir: string;
97
+ /**
98
+ * The profile to use for the CDK CLI calls
99
+ */
105
100
  protected readonly profile?: string;
106
101
  protected _destructiveChanges?: DestructiveChange[];
107
102
  private legacyContext?;
108
- protected isLegacyTest?: boolean;
103
+ private _expectedTestSuite?;
104
+ private _actualTestSuite?;
109
105
  constructor(options: IntegRunnerOptions);
110
106
  /**
111
107
  * Return the list of expected (i.e. existing) test cases for this integration test
112
108
  */
113
- expectedTests(): {
109
+ expectedTests(): Promise<{
114
110
  [testName: string]: TestCase;
115
- } | undefined;
111
+ } | undefined>;
116
112
  /**
117
113
  * Return the list of actual (i.e. new) test cases for this integration test
118
114
  */
119
- actualTests(): {
115
+ actualTests(): Promise<{
120
116
  [testName: string]: TestCase;
121
- } | undefined;
117
+ } | undefined>;
122
118
  /**
123
119
  * Generate a new "actual" snapshot which will be compared to the
124
120
  * existing "expected" snapshot
125
121
  * This will synth and then load the integration test manifest
126
122
  */
127
- generateActualSnapshot(): IntegTestSuite | LegacyIntegTestSuite;
123
+ generateActualSnapshot(): Promise<IntegTestSuite | LegacyIntegTestSuite>;
128
124
  /**
129
125
  * Returns true if a snapshot already exists for this test
130
126
  */
131
127
  hasSnapshot(): boolean;
128
+ /**
129
+ * The test suite from the existing snapshot
130
+ */
131
+ protected expectedTestSuite(): Promise<IntegTestSuite | LegacyIntegTestSuite | undefined>;
132
+ /**
133
+ * The test suite from the new "actual" snapshot
134
+ */
135
+ protected actualTestSuite(): Promise<IntegTestSuite | LegacyIntegTestSuite>;
132
136
  /**
133
137
  * Load the integ manifest which contains information
134
138
  * on how to execute the tests
@@ -136,7 +140,7 @@ export declare abstract class IntegRunner {
136
140
  * from the cloud assembly. If it doesn't exist, then we fallback to the
137
141
  * "legacy mode" and create a manifest from pragma
138
142
  */
139
- protected loadManifest(dir?: string): IntegTestSuite | LegacyIntegTestSuite;
143
+ protected loadManifest(dir?: string): Promise<IntegTestSuite | LegacyIntegTestSuite>;
140
144
  protected cleanup(): void;
141
145
  /**
142
146
  * If there are any destructive changes to a stack then this will record
@@ -152,7 +156,7 @@ export declare abstract class IntegRunner {
152
156
  * disabled and then delete assets that relate to that stack. It does that
153
157
  * by reading the asset manifest for the stack and deleting the asset source
154
158
  */
155
- protected removeAssetsFromSnapshot(): void;
159
+ protected removeAssetsFromSnapshot(): Promise<void>;
156
160
  /**
157
161
  * Remove the asset cache (.cache/) files from the snapshot.
158
162
  * These are a cache of the asset zips, but we are fine with
@@ -169,7 +173,7 @@ export declare abstract class IntegRunner {
169
173
  * If lookups are disabled (which means the stack is env agnostic) then just copy
170
174
  * the assembly that was output by the deployment
171
175
  */
172
- protected createSnapshot(): void;
176
+ protected createSnapshot(): Promise<void>;
173
177
  /**
174
178
  * Perform some cleanup steps after the snapshot is created
175
179
  * Anytime the snapshot needs to be modified after creation
@@ -44,40 +44,36 @@ class IntegRunner {
44
44
  const testRunCommand = this.test.appCommand;
45
45
  this.cdkApp = testRunCommand.replace('{filePath}', path.relative(this.directory, this.test.fileName));
46
46
  this.profile = options.profile;
47
- if (this.hasSnapshot()) {
48
- this.expectedTestSuite = this.loadManifest();
49
- }
50
- this.actualTestSuite = this.generateActualSnapshot();
51
47
  }
52
48
  /**
53
49
  * Return the list of expected (i.e. existing) test cases for this integration test
54
50
  */
55
- expectedTests() {
56
- return this.expectedTestSuite?.testSuite;
51
+ async expectedTests() {
52
+ return (await this.expectedTestSuite())?.testSuite;
57
53
  }
58
54
  /**
59
55
  * Return the list of actual (i.e. new) test cases for this integration test
60
56
  */
61
- actualTests() {
62
- return this.actualTestSuite.testSuite;
57
+ async actualTests() {
58
+ return (await this.actualTestSuite()).testSuite;
63
59
  }
64
60
  /**
65
61
  * Generate a new "actual" snapshot which will be compared to the
66
62
  * existing "expected" snapshot
67
63
  * This will synth and then load the integration test manifest
68
64
  */
69
- generateActualSnapshot() {
70
- this.cdk.synthFast({
65
+ async generateActualSnapshot() {
66
+ await this.cdk.synthFast({
71
67
  execCmd: this.cdkApp.split(' '),
72
68
  env: {
73
69
  ...exports.DEFAULT_SYNTH_OPTIONS.env,
74
70
  // we don't know the "actual" context yet (this method is what generates it) so just
75
71
  // use the "expected" context. This is only run in order to read the manifest
76
- CDK_CONTEXT_JSON: JSON.stringify(this.getContext(this.expectedTestSuite?.synthContext)),
72
+ CDK_CONTEXT_JSON: JSON.stringify(this.getContext((await this.expectedTestSuite())?.synthContext)),
77
73
  },
78
74
  output: path.relative(this.directory, this.cdkOutDir),
79
75
  });
80
- const manifest = this.loadManifest(this.cdkOutDir);
76
+ const manifest = await this.loadManifest(this.cdkOutDir);
81
77
  // after we load the manifest remove the tmp snapshot
82
78
  // so that it doesn't mess up the real snapshot created later
83
79
  this.cleanup();
@@ -89,6 +85,24 @@ class IntegRunner {
89
85
  hasSnapshot() {
90
86
  return fs.existsSync(this.snapshotDir);
91
87
  }
88
+ /**
89
+ * The test suite from the existing snapshot
90
+ */
91
+ async expectedTestSuite() {
92
+ if (!this._expectedTestSuite && this.hasSnapshot()) {
93
+ this._expectedTestSuite = await this.loadManifest();
94
+ }
95
+ return this._expectedTestSuite;
96
+ }
97
+ /**
98
+ * The test suite from the new "actual" snapshot
99
+ */
100
+ async actualTestSuite() {
101
+ if (!this._actualTestSuite) {
102
+ this._actualTestSuite = await this.generateActualSnapshot();
103
+ }
104
+ return this._actualTestSuite;
105
+ }
92
106
  /**
93
107
  * Load the integ manifest which contains information
94
108
  * on how to execute the tests
@@ -96,13 +110,13 @@ class IntegRunner {
96
110
  * from the cloud assembly. If it doesn't exist, then we fallback to the
97
111
  * "legacy mode" and create a manifest from pragma
98
112
  */
99
- loadManifest(dir) {
113
+ async loadManifest(dir) {
100
114
  try {
101
115
  const testSuite = integ_test_suite_1.IntegTestSuite.fromPath(dir ?? this.snapshotDir);
102
116
  return testSuite;
103
117
  }
104
118
  catch {
105
- const testCases = integ_test_suite_1.LegacyIntegTestSuite.fromLegacy({
119
+ const testCases = await integ_test_suite_1.LegacyIntegTestSuite.fromLegacy({
106
120
  cdk: this.cdk,
107
121
  testName: this.test.normalizedTestName,
108
122
  integSourceFilePath: this.test.fileName,
@@ -115,7 +129,6 @@ class IntegRunner {
115
129
  },
116
130
  });
117
131
  this.legacyContext = integ_test_suite_1.LegacyIntegTestSuite.getPragmaContext(this.test.fileName);
118
- this.isLegacyTest = true;
119
132
  return testCases;
120
133
  }
121
134
  }
@@ -154,8 +167,8 @@ class IntegRunner {
154
167
  * disabled and then delete assets that relate to that stack. It does that
155
168
  * by reading the asset manifest for the stack and deleting the asset source
156
169
  */
157
- removeAssetsFromSnapshot() {
158
- const stacks = this.actualTestSuite.getStacksWithoutUpdateWorkflow() ?? [];
170
+ async removeAssetsFromSnapshot() {
171
+ const stacks = (await this.actualTestSuite()).getStacksWithoutUpdateWorkflow() ?? [];
159
172
  const manifest = cloud_assembly_1.AssemblyManifestReader.fromPath(this.snapshotDir);
160
173
  const assets = (0, utils_1.flatten)(stacks.map(stack => {
161
174
  return manifest.getAssetLocationsForStack(stack) ?? [];
@@ -197,14 +210,14 @@ class IntegRunner {
197
210
  * If lookups are disabled (which means the stack is env agnostic) then just copy
198
211
  * the assembly that was output by the deployment
199
212
  */
200
- createSnapshot() {
213
+ async createSnapshot() {
201
214
  if (fs.existsSync(this.snapshotDir)) {
202
215
  fs.removeSync(this.snapshotDir);
203
216
  }
204
217
  // if lookups are enabled then we need to synth again
205
218
  // using dummy context and save that as the snapshot
206
- if (this.actualTestSuite.enableLookups) {
207
- this.cdk.synthFast({
219
+ if ((await this.actualTestSuite()).enableLookups) {
220
+ await this.cdk.synthFast({
208
221
  execCmd: this.cdkApp.split(' '),
209
222
  env: {
210
223
  ...exports.DEFAULT_SYNTH_OPTIONS.env,
@@ -216,16 +229,16 @@ class IntegRunner {
216
229
  else {
217
230
  fs.moveSync(this.cdkOutDir, this.snapshotDir, { overwrite: true });
218
231
  }
219
- this.cleanupSnapshot();
232
+ await this.cleanupSnapshot();
220
233
  }
221
234
  /**
222
235
  * Perform some cleanup steps after the snapshot is created
223
236
  * Anytime the snapshot needs to be modified after creation
224
237
  * the logic should live here.
225
238
  */
226
- cleanupSnapshot() {
239
+ async cleanupSnapshot() {
227
240
  if (fs.existsSync(this.snapshotDir)) {
228
- this.removeAssetsFromSnapshot();
241
+ await this.removeAssetsFromSnapshot();
229
242
  this.removeAssetsCacheFromSnapshot();
230
243
  const assembly = cloud_assembly_1.AssemblyManifestReader.fromPath(this.snapshotDir);
231
244
  assembly.cleanManifest();
@@ -235,8 +248,9 @@ class IntegRunner {
235
248
  // in the snapshot directory which can be used for the
236
249
  // update workflow. Save any legacyContext as well so that it can be read
237
250
  // the next time
238
- if (this.actualTestSuite.type === 'legacy-test-suite') {
239
- this.actualTestSuite.saveManifest(this.snapshotDir, this.legacyContext);
251
+ const actualTestSuite = await this.actualTestSuite();
252
+ if (actualTestSuite.type === 'legacy-test-suite') {
253
+ actualTestSuite.saveManifest(this.snapshotDir, this.legacyContext);
240
254
  }
241
255
  }
242
256
  getContext(additionalContext) {
@@ -316,4 +330,4 @@ exports.DEFAULT_SYNTH_OPTIONS = {
316
330
  function currentlyRecommendedAwsCdkLibFlags() {
317
331
  return recommendedFlagsFile;
318
332
  }
319
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runner-base.js","sourceRoot":"","sources":["runner-base.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @cdklabs/no-literal-partition */\nimport * as path from 'path';\nimport type { ICdk } from '@aws-cdk/cdk-cli-wrapper';\nimport { CdkCliWrapper } from '@aws-cdk/cdk-cli-wrapper';\nimport type { TestCase, DefaultCdkOptions } from '@aws-cdk/cloud-assembly-schema';\nimport { AVAILABILITY_ZONE_FALLBACK_CONTEXT_KEY, TARGET_PARTITIONS } from '@aws-cdk/cx-api';\nimport * as fs from 'fs-extra';\nimport { IntegTestSuite, LegacyIntegTestSuite } from './integ-test-suite';\nimport type { IntegTest } from './integration-tests';\nimport * as recommendedFlagsFile from '../recommended-feature-flags.json';\nimport { flatten } from '../utils';\nimport type { ManifestTrace } from './private/cloud-assembly';\nimport { AssemblyManifestReader } from './private/cloud-assembly';\nimport type { DestructiveChange } from '../workers/common';\n\nconst DESTRUCTIVE_CHANGES = '!!DESTRUCTIVE_CHANGES:';\n\n/**\n * Options for creating an integration test runner\n */\nexport interface IntegRunnerOptions {\n  /**\n   * Information about the test to run\n   */\n  readonly test: IntegTest;\n\n  /**\n   * The AWS profile to use when invoking the CDK CLI\n   *\n   * @default - no profile is passed, the default profile is used\n   */\n  readonly profile?: string;\n\n  /**\n   * Additional environment variables that will be available\n   * to the CDK CLI\n   *\n   * @default - no additional environment variables\n   */\n  readonly env?: { [name: string]: string };\n\n  /**\n   * tmp cdk.out directory\n   *\n   * @default - directory will be `cdk-integ.out.${testName}`\n   */\n  readonly integOutDir?: string;\n\n  /**\n   * Instance of the CDK CLI to use\n   *\n   * @default - CdkCliWrapper\n   */\n  readonly cdk?: ICdk;\n\n  /**\n   * Show output from running integration tests\n   *\n   * @default false\n   */\n  readonly showOutput?: boolean;\n}\n\n/**\n * The different components of a test name\n */\n/**\n * Represents an Integration test runner\n */\nexport abstract class IntegRunner {\n  /**\n   * The directory where the snapshot will be stored\n   */\n  public readonly snapshotDir: string;\n\n  /**\n   * An instance of the CDK  CLI\n   */\n  public readonly cdk: ICdk;\n\n  /**\n   * Pretty name of the test\n   */\n  public readonly testName: string;\n\n  /**\n   * The value used in the '--app' CLI parameter\n   *\n   * Path to the integ test source file, relative to `this.directory`.\n   */\n  protected readonly cdkApp: string;\n\n  /**\n   * The path where the `cdk.context.json` file\n   * will be created\n   */\n  protected readonly cdkContextPath: string;\n\n  /**\n   * The test suite from the existing snapshot\n   */\n  protected readonly expectedTestSuite?: IntegTestSuite | LegacyIntegTestSuite;\n\n  /**\n   * The test suite from the new \"actual\" snapshot\n   */\n  protected readonly actualTestSuite: IntegTestSuite | LegacyIntegTestSuite;\n\n  /**\n   * The working directory that the integration tests will be\n   * executed from\n   */\n  protected readonly directory: string;\n\n  /**\n   * The test to run\n   */\n  protected readonly test: IntegTest;\n\n  /**\n   * Default options to pass to the CDK CLI\n   */\n  protected readonly defaultArgs: DefaultCdkOptions = {\n    pathMetadata: false,\n    assetMetadata: false,\n    versionReporting: false,\n  };\n\n  /**\n   * The directory where the CDK will be synthed to\n   *\n   * Relative to cwd.\n   */\n  protected readonly cdkOutDir: string;\n\n  protected readonly profile?: string;\n\n  protected _destructiveChanges?: DestructiveChange[];\n  private legacyContext?: Record<string, any>;\n  protected isLegacyTest?: boolean;\n\n  constructor(options: IntegRunnerOptions) {\n    this.test = options.test;\n    this.directory = this.test.directory;\n    this.testName = this.test.testName;\n    this.snapshotDir = this.test.snapshotDir;\n    this.cdkContextPath = path.join(this.directory, 'cdk.context.json');\n\n    this.cdk = options.cdk ?? new CdkCliWrapper({\n      directory: this.directory,\n      showOutput: options.showOutput,\n      env: {\n        ...options.env,\n      },\n    });\n    this.cdkOutDir = options.integOutDir ?? this.test.temporaryOutputDir;\n\n    const testRunCommand = this.test.appCommand;\n    this.cdkApp = testRunCommand.replace('{filePath}', path.relative(this.directory, this.test.fileName));\n\n    this.profile = options.profile;\n    if (this.hasSnapshot()) {\n      this.expectedTestSuite = this.loadManifest();\n    }\n    this.actualTestSuite = this.generateActualSnapshot();\n  }\n\n  /**\n   * Return the list of expected (i.e. existing) test cases for this integration test\n   */\n  public expectedTests(): { [testName: string]: TestCase } | undefined {\n    return this.expectedTestSuite?.testSuite;\n  }\n\n  /**\n   * Return the list of actual (i.e. new) test cases for this integration test\n   */\n  public actualTests(): { [testName: string]: TestCase } | undefined {\n    return this.actualTestSuite.testSuite;\n  }\n\n  /**\n   * Generate a new \"actual\" snapshot which will be compared to the\n   * existing \"expected\" snapshot\n   * This will synth and then load the integration test manifest\n   */\n  public generateActualSnapshot(): IntegTestSuite | LegacyIntegTestSuite {\n    this.cdk.synthFast({\n      execCmd: this.cdkApp.split(' '),\n      env: {\n        ...DEFAULT_SYNTH_OPTIONS.env,\n        // we don't know the \"actual\" context yet (this method is what generates it) so just\n        // use the \"expected\" context. This is only run in order to read the manifest\n        CDK_CONTEXT_JSON: JSON.stringify(this.getContext(this.expectedTestSuite?.synthContext)),\n      },\n      output: path.relative(this.directory, this.cdkOutDir),\n    });\n    const manifest = this.loadManifest(this.cdkOutDir);\n    // after we load the manifest remove the tmp snapshot\n    // so that it doesn't mess up the real snapshot created later\n    this.cleanup();\n    return manifest;\n  }\n\n  /**\n   * Returns true if a snapshot already exists for this test\n   */\n  public hasSnapshot(): boolean {\n    return fs.existsSync(this.snapshotDir);\n  }\n\n  /**\n   * Load the integ manifest which contains information\n   * on how to execute the tests\n   * First we try and load the manifest from the integ manifest (i.e. integ.json)\n   * from the cloud assembly. If it doesn't exist, then we fallback to the\n   * \"legacy mode\" and create a manifest from pragma\n   */\n  protected loadManifest(dir?: string): IntegTestSuite | LegacyIntegTestSuite {\n    try {\n      const testSuite = IntegTestSuite.fromPath(dir ?? this.snapshotDir);\n      return testSuite;\n    } catch {\n      const testCases = LegacyIntegTestSuite.fromLegacy({\n        cdk: this.cdk,\n        testName: this.test.normalizedTestName,\n        integSourceFilePath: this.test.fileName,\n        listOptions: {\n          ...this.defaultArgs,\n          all: true,\n          app: this.cdkApp,\n          profile: this.profile,\n          output: path.relative(this.directory, this.cdkOutDir),\n        },\n      });\n      this.legacyContext = LegacyIntegTestSuite.getPragmaContext(this.test.fileName);\n      this.isLegacyTest = true;\n      return testCases;\n    }\n  }\n\n  protected cleanup(): void {\n    const cdkOutPath = this.cdkOutDir;\n    if (fs.existsSync(cdkOutPath)) {\n      fs.removeSync(cdkOutPath);\n    }\n  }\n\n  /**\n   * If there are any destructive changes to a stack then this will record\n   * those in the manifest.json file\n   */\n  private renderTraceData(): ManifestTrace {\n    const traceData: ManifestTrace = new Map();\n    const destructiveChanges = this._destructiveChanges ?? [];\n    destructiveChanges.forEach(change => {\n      const trace = traceData.get(change.stackName);\n      if (trace) {\n        trace.set(change.logicalId, `${DESTRUCTIVE_CHANGES} ${change.impact}`);\n      } else {\n        traceData.set(change.stackName, new Map([\n          [change.logicalId, `${DESTRUCTIVE_CHANGES} ${change.impact}`],\n        ]));\n      }\n    });\n    return traceData;\n  }\n\n  /**\n   * In cases where we do not want to retain the assets,\n   * for example, if the assets are very large.\n   *\n   * Since it is possible to disable the update workflow for individual test\n   * cases, this needs to first get a list of stacks that have the update workflow\n   * disabled and then delete assets that relate to that stack. It does that\n   * by reading the asset manifest for the stack and deleting the asset source\n   */\n  protected removeAssetsFromSnapshot(): void {\n    const stacks = this.actualTestSuite.getStacksWithoutUpdateWorkflow() ?? [];\n    const manifest = AssemblyManifestReader.fromPath(this.snapshotDir);\n    const assets = flatten(stacks.map(stack => {\n      return manifest.getAssetLocationsForStack(stack) ?? [];\n    }));\n\n    assets.forEach(asset => {\n      const fileName = path.join(this.snapshotDir, asset);\n      if (fs.existsSync(fileName)) {\n        if (fs.lstatSync(fileName).isDirectory()) {\n          fs.removeSync(fileName);\n        } else {\n          fs.unlinkSync(fileName);\n        }\n      }\n    });\n  }\n\n  /**\n   * Remove the asset cache (.cache/) files from the snapshot.\n   * These are a cache of the asset zips, but we are fine with\n   * re-zipping on deploy\n   */\n  protected removeAssetsCacheFromSnapshot(): void {\n    const files = fs.readdirSync(this.snapshotDir);\n    files.forEach(file => {\n      const fileName = path.join(this.snapshotDir, file);\n      if (fs.lstatSync(fileName).isDirectory() && file === '.cache') {\n        fs.emptyDirSync(fileName);\n        fs.rmdirSync(fileName);\n      }\n    });\n  }\n\n  /**\n   * Create the new snapshot.\n   *\n   * If lookups are enabled, then we need create the snapshot by synthing again\n   * with the dummy context so that each time the test is run on different machines\n   * (and with different context/env) the diff will not change.\n   *\n   * If lookups are disabled (which means the stack is env agnostic) then just copy\n   * the assembly that was output by the deployment\n   */\n  protected createSnapshot(): void {\n    if (fs.existsSync(this.snapshotDir)) {\n      fs.removeSync(this.snapshotDir);\n    }\n\n    // if lookups are enabled then we need to synth again\n    // using dummy context and save that as the snapshot\n    if (this.actualTestSuite.enableLookups) {\n      this.cdk.synthFast({\n        execCmd: this.cdkApp.split(' '),\n        env: {\n          ...DEFAULT_SYNTH_OPTIONS.env,\n          CDK_CONTEXT_JSON: JSON.stringify(this.getContext(DEFAULT_SYNTH_OPTIONS.context)),\n        },\n        output: path.relative(this.directory, this.snapshotDir),\n      });\n    } else {\n      fs.moveSync(this.cdkOutDir, this.snapshotDir, { overwrite: true });\n    }\n\n    this.cleanupSnapshot();\n  }\n\n  /**\n   * Perform some cleanup steps after the snapshot is created\n   * Anytime the snapshot needs to be modified after creation\n   * the logic should live here.\n   */\n  private cleanupSnapshot(): void {\n    if (fs.existsSync(this.snapshotDir)) {\n      this.removeAssetsFromSnapshot();\n      this.removeAssetsCacheFromSnapshot();\n      const assembly = AssemblyManifestReader.fromPath(this.snapshotDir);\n      assembly.cleanManifest();\n      assembly.recordTrace(this.renderTraceData());\n    }\n\n    // if this is a legacy test then create an integ manifest\n    // in the snapshot directory which can be used for the\n    // update workflow. Save any legacyContext as well so that it can be read\n    // the next time\n    if (this.actualTestSuite.type === 'legacy-test-suite') {\n      (this.actualTestSuite as LegacyIntegTestSuite).saveManifest(this.snapshotDir, this.legacyContext);\n    }\n  }\n\n  protected getContext(additionalContext?: Record<string, any>): Record<string, any> {\n    return {\n      ...currentlyRecommendedAwsCdkLibFlags(),\n      ...this.legacyContext,\n      ...additionalContext,\n\n      // We originally had PLANNED to set this to ['aws', 'aws-cn'], but due to a programming mistake\n      // it was set to everything. In this PR, set it to everything to not mess up all the snapshots.\n      [TARGET_PARTITIONS]: undefined,\n\n      /* ---------------- THE FUTURE LIVES BELOW----------------------------\n      // Restricting to these target partitions makes most service principals synthesize to\n      // `service.${URL_SUFFIX}`, which is technically *incorrect* (it's only `amazonaws.com`\n      // or `amazonaws.com.cn`, never UrlSuffix for any of the restricted regions) but it's what\n      // most existing integ tests contain, and we want to disturb as few as possible.\n      // [TARGET_PARTITIONS]: ['aws', 'aws-cn'],\n      /* ---------------- END OF THE FUTURE ------------------------------- */\n    };\n  }\n}\n\n// Default context we run all integ tests with, so they don't depend on the\n// account of the exercising user.\nexport const DEFAULT_SYNTH_OPTIONS = {\n  context: {\n    [AVAILABILITY_ZONE_FALLBACK_CONTEXT_KEY]: ['test-region-1a', 'test-region-1b', 'test-region-1c'],\n    'availability-zones:account=12345678:region=test-region': ['test-region-1a', 'test-region-1b', 'test-region-1c'],\n    'ssm:account=12345678:parameterName=/aws/service/ami-amazon-linux-latest/amzn-ami-hvm-x86_64-gp2:region=test-region': 'ami-1234',\n    'ssm:account=12345678:parameterName=/aws/service/ami-amazon-linux-latest/amzn2-ami-hvm-x86_64-gp2:region=test-region': 'ami-1234',\n    'ssm:account=12345678:parameterName=/aws/service/ecs/optimized-ami/amazon-linux/recommended:region=test-region': '{\"image_id\": \"ami-1234\"}',\n    // eslint-disable-next-line @stylistic/max-len\n    'ami:account=12345678:filters.image-type.0=machine:filters.name.0=amzn-ami-vpc-nat-*:filters.state.0=available:owners.0=amazon:region=test-region': 'ami-1234',\n    'vpc-provider:account=12345678:filter.isDefault=true:region=test-region:returnAsymmetricSubnets=true': {\n      vpcId: 'vpc-60900905',\n      subnetGroups: [\n        {\n          type: 'Public',\n          name: 'Public',\n          subnets: [\n            {\n              subnetId: 'subnet-e19455ca',\n              availabilityZone: 'us-east-1a',\n              routeTableId: 'rtb-e19455ca',\n            },\n            {\n              subnetId: 'subnet-e0c24797',\n              availabilityZone: 'us-east-1b',\n              routeTableId: 'rtb-e0c24797',\n            },\n            {\n              subnetId: 'subnet-ccd77395',\n              availabilityZone: 'us-east-1c',\n              routeTableId: 'rtb-ccd77395',\n            },\n          ],\n        },\n      ],\n    },\n  },\n  env: {\n    CDK_INTEG_ACCOUNT: '12345678',\n    CDK_INTEG_REGION: 'test-region',\n    CDK_INTEG_HOSTED_ZONE_ID: 'Z23ABC4XYZL05B',\n    CDK_INTEG_HOSTED_ZONE_NAME: 'example.com',\n    CDK_INTEG_DOMAIN_NAME: '*.example.com',\n    CDK_INTEG_CERT_ARN: 'arn:aws:acm:test-region:12345678:certificate/86468209-a272-595d-b831-0efb6421265z',\n    CDK_INTEG_SUBNET_ID: 'subnet-0dff1a399d8f6f92c',\n  },\n};\n\n/**\n * Return the currently recommended flags for `aws-cdk-lib`.\n *\n * These have been built into the CLI at build time. If this ever gets changed\n * back to a dynamic load, remember that this source file may be bundled into\n * a JavaScript bundle, and `__dirname` might not point where you think it does.\n */\nexport function currentlyRecommendedAwsCdkLibFlags() {\n  return recommendedFlagsFile;\n}\n"]}
333
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runner-base.js","sourceRoot":"","sources":["runner-base.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @cdklabs/no-literal-partition */\nimport * as path from 'path';\nimport type { ICdk } from '@aws-cdk/cdk-cli-wrapper';\nimport { CdkCliWrapper } from '@aws-cdk/cdk-cli-wrapper';\nimport type { TestCase, DefaultCdkOptions } from '@aws-cdk/cloud-assembly-schema';\nimport { AVAILABILITY_ZONE_FALLBACK_CONTEXT_KEY, TARGET_PARTITIONS } from '@aws-cdk/cx-api';\nimport * as fs from 'fs-extra';\nimport { IntegTestSuite, LegacyIntegTestSuite } from './integ-test-suite';\nimport type { IntegTest } from './integration-tests';\nimport * as recommendedFlagsFile from '../recommended-feature-flags.json';\nimport { flatten } from '../utils';\nimport type { ManifestTrace } from './private/cloud-assembly';\nimport { AssemblyManifestReader } from './private/cloud-assembly';\nimport type { DestructiveChange } from '../workers/common';\n\nconst DESTRUCTIVE_CHANGES = '!!DESTRUCTIVE_CHANGES:';\n\n/**\n * Options for creating an integration test runner\n */\nexport interface IntegRunnerOptions {\n  /**\n   * Information about the test to run\n   */\n  readonly test: IntegTest;\n\n  /**\n   * The AWS profile to use when invoking the CDK CLI\n   *\n   * @default - no profile is passed, the default profile is used\n   */\n  readonly profile?: string;\n\n  /**\n   * Additional environment variables that will be available\n   * to the CDK CLI\n   *\n   * @default - no additional environment variables\n   */\n  readonly env?: { [name: string]: string };\n\n  /**\n   * tmp cdk.out directory\n   *\n   * @default - directory will be `cdk-integ.out.${testName}`\n   */\n  readonly integOutDir?: string;\n\n  /**\n   * Instance of the CDK CLI to use\n   *\n   * @default - CdkCliWrapper\n   */\n  readonly cdk?: ICdk;\n\n  /**\n   * Show output from running integration tests\n   *\n   * @default false\n   */\n  readonly showOutput?: boolean;\n}\n\n/**\n * The different components of a test name\n */\n/**\n * Represents an Integration test runner\n */\nexport abstract class IntegRunner {\n  /**\n   * The directory where the snapshot will be stored\n   */\n  public readonly snapshotDir: string;\n\n  /**\n   * An instance of the CDK  CLI\n   */\n  public readonly cdk: ICdk;\n\n  /**\n   * Pretty name of the test\n   */\n  public readonly testName: string;\n\n  /**\n   * The value used in the '--app' CLI parameter\n   *\n   * Path to the integ test source file, relative to `this.directory`.\n   */\n  protected readonly cdkApp: string;\n\n  /**\n   * The path where the `cdk.context.json` file\n   * will be created\n   */\n  protected readonly cdkContextPath: string;\n\n  /**\n   * The working directory that the integration tests will be\n   * executed from\n   */\n  protected readonly directory: string;\n\n  /**\n   * The test to run\n   */\n  protected readonly test: IntegTest;\n\n  /**\n   * Default options to pass to the CDK CLI\n   */\n  protected readonly defaultArgs: DefaultCdkOptions = {\n    pathMetadata: false,\n    assetMetadata: false,\n    versionReporting: false,\n  };\n\n  /**\n   * The directory where the CDK will be synthed to\n   *\n   * Relative to cwd.\n   */\n  protected readonly cdkOutDir: string;\n\n  /**\n   * The profile to use for the CDK CLI calls\n   */\n  protected readonly profile?: string;\n\n  protected _destructiveChanges?: DestructiveChange[];\n  private legacyContext?: Record<string, any>;\n  private _expectedTestSuite?: IntegTestSuite | LegacyIntegTestSuite;\n  private _actualTestSuite?: IntegTestSuite | LegacyIntegTestSuite;\n\n  constructor(options: IntegRunnerOptions) {\n    this.test = options.test;\n    this.directory = this.test.directory;\n    this.testName = this.test.testName;\n    this.snapshotDir = this.test.snapshotDir;\n    this.cdkContextPath = path.join(this.directory, 'cdk.context.json');\n\n    this.cdk = options.cdk ?? new CdkCliWrapper({\n      directory: this.directory,\n      showOutput: options.showOutput,\n      env: {\n        ...options.env,\n      },\n    });\n    this.cdkOutDir = options.integOutDir ?? this.test.temporaryOutputDir;\n\n    const testRunCommand = this.test.appCommand;\n    this.cdkApp = testRunCommand.replace('{filePath}', path.relative(this.directory, this.test.fileName));\n\n    this.profile = options.profile;\n  }\n\n  /**\n   * Return the list of expected (i.e. existing) test cases for this integration test\n   */\n  public async expectedTests(): Promise<{ [testName: string]: TestCase } | undefined> {\n    return (await this.expectedTestSuite())?.testSuite;\n  }\n\n  /**\n   * Return the list of actual (i.e. new) test cases for this integration test\n   */\n  public async actualTests(): Promise<{ [testName: string]: TestCase } | undefined> {\n    return (await this.actualTestSuite()).testSuite;\n  }\n\n  /**\n   * Generate a new \"actual\" snapshot which will be compared to the\n   * existing \"expected\" snapshot\n   * This will synth and then load the integration test manifest\n   */\n  public async generateActualSnapshot(): Promise<IntegTestSuite | LegacyIntegTestSuite> {\n    await this.cdk.synthFast({\n      execCmd: this.cdkApp.split(' '),\n      env: {\n        ...DEFAULT_SYNTH_OPTIONS.env,\n        // we don't know the \"actual\" context yet (this method is what generates it) so just\n        // use the \"expected\" context. This is only run in order to read the manifest\n        CDK_CONTEXT_JSON: JSON.stringify(this.getContext((await this.expectedTestSuite())?.synthContext)),\n      },\n      output: path.relative(this.directory, this.cdkOutDir),\n    });\n    const manifest = await this.loadManifest(this.cdkOutDir);\n    // after we load the manifest remove the tmp snapshot\n    // so that it doesn't mess up the real snapshot created later\n    this.cleanup();\n    return manifest;\n  }\n\n  /**\n   * Returns true if a snapshot already exists for this test\n   */\n  public hasSnapshot(): boolean {\n    return fs.existsSync(this.snapshotDir);\n  }\n\n  /**\n   * The test suite from the existing snapshot\n   */\n  protected async expectedTestSuite(): Promise<IntegTestSuite | LegacyIntegTestSuite | undefined> {\n    if (!this._expectedTestSuite && this.hasSnapshot()) {\n      this._expectedTestSuite = await this.loadManifest();\n    }\n    return this._expectedTestSuite;\n  }\n\n  /**\n   * The test suite from the new \"actual\" snapshot\n   */\n  protected async actualTestSuite(): Promise<IntegTestSuite | LegacyIntegTestSuite> {\n    if (!this._actualTestSuite) {\n      this._actualTestSuite = await this.generateActualSnapshot();\n    }\n    return this._actualTestSuite;\n  }\n\n  /**\n   * Load the integ manifest which contains information\n   * on how to execute the tests\n   * First we try and load the manifest from the integ manifest (i.e. integ.json)\n   * from the cloud assembly. If it doesn't exist, then we fallback to the\n   * \"legacy mode\" and create a manifest from pragma\n   */\n  protected async loadManifest(dir?: string): Promise<IntegTestSuite | LegacyIntegTestSuite> {\n    try {\n      const testSuite = IntegTestSuite.fromPath(dir ?? this.snapshotDir);\n      return testSuite;\n    } catch {\n      const testCases = await LegacyIntegTestSuite.fromLegacy({\n        cdk: this.cdk,\n        testName: this.test.normalizedTestName,\n        integSourceFilePath: this.test.fileName,\n        listOptions: {\n          ...this.defaultArgs,\n          all: true,\n          app: this.cdkApp,\n          profile: this.profile,\n          output: path.relative(this.directory, this.cdkOutDir),\n        },\n      });\n      this.legacyContext = LegacyIntegTestSuite.getPragmaContext(this.test.fileName);\n      return testCases;\n    }\n  }\n\n  protected cleanup(): void {\n    const cdkOutPath = this.cdkOutDir;\n    if (fs.existsSync(cdkOutPath)) {\n      fs.removeSync(cdkOutPath);\n    }\n  }\n\n  /**\n   * If there are any destructive changes to a stack then this will record\n   * those in the manifest.json file\n   */\n  private renderTraceData(): ManifestTrace {\n    const traceData: ManifestTrace = new Map();\n    const destructiveChanges = this._destructiveChanges ?? [];\n    destructiveChanges.forEach(change => {\n      const trace = traceData.get(change.stackName);\n      if (trace) {\n        trace.set(change.logicalId, `${DESTRUCTIVE_CHANGES} ${change.impact}`);\n      } else {\n        traceData.set(change.stackName, new Map([\n          [change.logicalId, `${DESTRUCTIVE_CHANGES} ${change.impact}`],\n        ]));\n      }\n    });\n    return traceData;\n  }\n\n  /**\n   * In cases where we do not want to retain the assets,\n   * for example, if the assets are very large.\n   *\n   * Since it is possible to disable the update workflow for individual test\n   * cases, this needs to first get a list of stacks that have the update workflow\n   * disabled and then delete assets that relate to that stack. It does that\n   * by reading the asset manifest for the stack and deleting the asset source\n   */\n  protected async removeAssetsFromSnapshot(): Promise<void> {\n    const stacks = (await this.actualTestSuite()).getStacksWithoutUpdateWorkflow() ?? [];\n    const manifest = AssemblyManifestReader.fromPath(this.snapshotDir);\n    const assets = flatten(stacks.map(stack => {\n      return manifest.getAssetLocationsForStack(stack) ?? [];\n    }));\n\n    assets.forEach(asset => {\n      const fileName = path.join(this.snapshotDir, asset);\n      if (fs.existsSync(fileName)) {\n        if (fs.lstatSync(fileName).isDirectory()) {\n          fs.removeSync(fileName);\n        } else {\n          fs.unlinkSync(fileName);\n        }\n      }\n    });\n  }\n\n  /**\n   * Remove the asset cache (.cache/) files from the snapshot.\n   * These are a cache of the asset zips, but we are fine with\n   * re-zipping on deploy\n   */\n  protected removeAssetsCacheFromSnapshot(): void {\n    const files = fs.readdirSync(this.snapshotDir);\n    files.forEach(file => {\n      const fileName = path.join(this.snapshotDir, file);\n      if (fs.lstatSync(fileName).isDirectory() && file === '.cache') {\n        fs.emptyDirSync(fileName);\n        fs.rmdirSync(fileName);\n      }\n    });\n  }\n\n  /**\n   * Create the new snapshot.\n   *\n   * If lookups are enabled, then we need create the snapshot by synthing again\n   * with the dummy context so that each time the test is run on different machines\n   * (and with different context/env) the diff will not change.\n   *\n   * If lookups are disabled (which means the stack is env agnostic) then just copy\n   * the assembly that was output by the deployment\n   */\n  protected async createSnapshot(): Promise<void> {\n    if (fs.existsSync(this.snapshotDir)) {\n      fs.removeSync(this.snapshotDir);\n    }\n\n    // if lookups are enabled then we need to synth again\n    // using dummy context and save that as the snapshot\n    if ((await this.actualTestSuite()).enableLookups) {\n      await this.cdk.synthFast({\n        execCmd: this.cdkApp.split(' '),\n        env: {\n          ...DEFAULT_SYNTH_OPTIONS.env,\n          CDK_CONTEXT_JSON: JSON.stringify(this.getContext(DEFAULT_SYNTH_OPTIONS.context)),\n        },\n        output: path.relative(this.directory, this.snapshotDir),\n      });\n    } else {\n      fs.moveSync(this.cdkOutDir, this.snapshotDir, { overwrite: true });\n    }\n\n    await this.cleanupSnapshot();\n  }\n\n  /**\n   * Perform some cleanup steps after the snapshot is created\n   * Anytime the snapshot needs to be modified after creation\n   * the logic should live here.\n   */\n  private async cleanupSnapshot(): Promise<void> {\n    if (fs.existsSync(this.snapshotDir)) {\n      await this.removeAssetsFromSnapshot();\n      this.removeAssetsCacheFromSnapshot();\n      const assembly = AssemblyManifestReader.fromPath(this.snapshotDir);\n      assembly.cleanManifest();\n      assembly.recordTrace(this.renderTraceData());\n    }\n\n    // if this is a legacy test then create an integ manifest\n    // in the snapshot directory which can be used for the\n    // update workflow. Save any legacyContext as well so that it can be read\n    // the next time\n    const actualTestSuite = await this.actualTestSuite();\n    if (actualTestSuite.type === 'legacy-test-suite') {\n      (actualTestSuite as LegacyIntegTestSuite).saveManifest(this.snapshotDir, this.legacyContext);\n    }\n  }\n\n  protected getContext(additionalContext?: Record<string, any>): Record<string, any> {\n    return {\n      ...currentlyRecommendedAwsCdkLibFlags(),\n      ...this.legacyContext,\n      ...additionalContext,\n\n      // We originally had PLANNED to set this to ['aws', 'aws-cn'], but due to a programming mistake\n      // it was set to everything. In this PR, set it to everything to not mess up all the snapshots.\n      [TARGET_PARTITIONS]: undefined,\n\n      /* ---------------- THE FUTURE LIVES BELOW----------------------------\n      // Restricting to these target partitions makes most service principals synthesize to\n      // `service.${URL_SUFFIX}`, which is technically *incorrect* (it's only `amazonaws.com`\n      // or `amazonaws.com.cn`, never UrlSuffix for any of the restricted regions) but it's what\n      // most existing integ tests contain, and we want to disturb as few as possible.\n      // [TARGET_PARTITIONS]: ['aws', 'aws-cn'],\n      /* ---------------- END OF THE FUTURE ------------------------------- */\n    };\n  }\n}\n\n// Default context we run all integ tests with, so they don't depend on the\n// account of the exercising user.\nexport const DEFAULT_SYNTH_OPTIONS = {\n  context: {\n    [AVAILABILITY_ZONE_FALLBACK_CONTEXT_KEY]: ['test-region-1a', 'test-region-1b', 'test-region-1c'],\n    'availability-zones:account=12345678:region=test-region': ['test-region-1a', 'test-region-1b', 'test-region-1c'],\n    'ssm:account=12345678:parameterName=/aws/service/ami-amazon-linux-latest/amzn-ami-hvm-x86_64-gp2:region=test-region': 'ami-1234',\n    'ssm:account=12345678:parameterName=/aws/service/ami-amazon-linux-latest/amzn2-ami-hvm-x86_64-gp2:region=test-region': 'ami-1234',\n    'ssm:account=12345678:parameterName=/aws/service/ecs/optimized-ami/amazon-linux/recommended:region=test-region': '{\"image_id\": \"ami-1234\"}',\n    // eslint-disable-next-line @stylistic/max-len\n    'ami:account=12345678:filters.image-type.0=machine:filters.name.0=amzn-ami-vpc-nat-*:filters.state.0=available:owners.0=amazon:region=test-region': 'ami-1234',\n    'vpc-provider:account=12345678:filter.isDefault=true:region=test-region:returnAsymmetricSubnets=true': {\n      vpcId: 'vpc-60900905',\n      subnetGroups: [\n        {\n          type: 'Public',\n          name: 'Public',\n          subnets: [\n            {\n              subnetId: 'subnet-e19455ca',\n              availabilityZone: 'us-east-1a',\n              routeTableId: 'rtb-e19455ca',\n            },\n            {\n              subnetId: 'subnet-e0c24797',\n              availabilityZone: 'us-east-1b',\n              routeTableId: 'rtb-e0c24797',\n            },\n            {\n              subnetId: 'subnet-ccd77395',\n              availabilityZone: 'us-east-1c',\n              routeTableId: 'rtb-ccd77395',\n            },\n          ],\n        },\n      ],\n    },\n  },\n  env: {\n    CDK_INTEG_ACCOUNT: '12345678',\n    CDK_INTEG_REGION: 'test-region',\n    CDK_INTEG_HOSTED_ZONE_ID: 'Z23ABC4XYZL05B',\n    CDK_INTEG_HOSTED_ZONE_NAME: 'example.com',\n    CDK_INTEG_DOMAIN_NAME: '*.example.com',\n    CDK_INTEG_CERT_ARN: 'arn:aws:acm:test-region:12345678:certificate/86468209-a272-595d-b831-0efb6421265z',\n    CDK_INTEG_SUBNET_ID: 'subnet-0dff1a399d8f6f92c',\n  },\n};\n\n/**\n * Return the currently recommended flags for `aws-cdk-lib`.\n *\n * These have been built into the CLI at build time. If this ever gets changed\n * back to a dynamic load, remember that this source file may be bundled into\n * a JavaScript bundle, and `__dirname` might not point where you think it does.\n */\nexport function currentlyRecommendedAwsCdkLibFlags() {\n  return recommendedFlagsFile;\n}\n"]}
@@ -13,10 +13,10 @@ export declare class IntegSnapshotRunner extends IntegRunner {
13
13
  *
14
14
  * @returns any diagnostics and any destructive changes
15
15
  */
16
- testSnapshot(options?: SnapshotVerificationOptions): {
16
+ testSnapshot(options?: SnapshotVerificationOptions): Promise<{
17
17
  diagnostics: Diagnostic[];
18
18
  destructiveChanges: DestructiveChange[];
19
- };
19
+ }>;
20
20
  /**
21
21
  * For a given cloud assembly return a collection of all templates
22
22
  * that should be part of the snapshot and any required meta data.