@aws-cdk-testing/cli-integ 3.15.1 → 3.16.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -39,9 +39,9 @@
39
39
  "organization": true
40
40
  },
41
41
  "devDependencies": {
42
- "@aws-cdk/toolkit-lib": "1.6.0",
42
+ "@aws-cdk/toolkit-lib": "1.8.2",
43
43
  "@aws-cdk/yarn-cling": "0.0.0",
44
- "@cdklabs/eslint-plugin": "^1.3.3",
44
+ "@cdklabs/eslint-plugin": "^1.3.4",
45
45
  "@stylistic/eslint-plugin": "^3",
46
46
  "@types/fs-extra": "^9",
47
47
  "@types/jest": "^29.5.14",
@@ -67,23 +67,23 @@
67
67
  "typescript": "5.8"
68
68
  },
69
69
  "dependencies": {
70
- "@aws-sdk/client-cloudformation": "^3.864.0",
71
- "@aws-sdk/client-codeartifact": "^3.864.0",
72
- "@aws-sdk/client-ecr": "^3.864.0",
73
- "@aws-sdk/client-ecr-public": "^3.864.0",
74
- "@aws-sdk/client-ecs": "^3.864.0",
75
- "@aws-sdk/client-iam": "^3.864.0",
76
- "@aws-sdk/client-lambda": "^3.865.0",
77
- "@aws-sdk/client-s3": "^3.864.0",
78
- "@aws-sdk/client-secrets-manager": "^3.864.0",
79
- "@aws-sdk/client-sns": "^3.864.0",
80
- "@aws-sdk/client-sso": "^3.864.0",
81
- "@aws-sdk/client-sts": "^3.864.0",
82
- "@aws-sdk/credential-providers": "^3.864.0",
83
- "@cdklabs/cdk-atmosphere-client": "^0.0.61",
70
+ "@aws-sdk/client-cloudformation": "^3.888.0",
71
+ "@aws-sdk/client-codeartifact": "^3.888.0",
72
+ "@aws-sdk/client-ecr": "^3.888.0",
73
+ "@aws-sdk/client-ecr-public": "^3.888.0",
74
+ "@aws-sdk/client-ecs": "^3.888.0",
75
+ "@aws-sdk/client-iam": "^3.888.0",
76
+ "@aws-sdk/client-lambda": "^3.888.0",
77
+ "@aws-sdk/client-s3": "^3.888.0",
78
+ "@aws-sdk/client-secrets-manager": "^3.888.0",
79
+ "@aws-sdk/client-sns": "^3.888.0",
80
+ "@aws-sdk/client-sso": "^3.888.0",
81
+ "@aws-sdk/client-sts": "^3.888.0",
82
+ "@aws-sdk/credential-providers": "^3.888.0",
83
+ "@cdklabs/cdk-atmosphere-client": "^0.0.64",
84
84
  "@octokit/rest": "^20",
85
- "@smithy/types": "^4.3.2",
86
- "@smithy/util-retry": "^4.0.7",
85
+ "@smithy/types": "^4.5.0",
86
+ "@smithy/util-retry": "^4.1.1",
87
87
  "axios": "^1",
88
88
  "chalk": "^4",
89
89
  "fs-extra": "^9",
@@ -116,7 +116,7 @@
116
116
  "publishConfig": {
117
117
  "access": "public"
118
118
  },
119
- "version": "3.15.1",
119
+ "version": "3.16.1",
120
120
  "types": "lib/index.d.ts",
121
121
  "//": "~~ Generated by projen. To modify, edit .projenrc.js and run \"npx projen\"."
122
122
  }
@@ -1,18 +1,37 @@
1
1
  const cdk = require('aws-cdk-lib');
2
2
  const sqs = require('aws-cdk-lib/aws-sqs');
3
-
4
- class BasicStack extends cdk.Stack {
5
- constructor(parent, id, props) {
6
- super(parent, id, props);
7
- new sqs.Queue(this, props.queueName);
8
- }
9
- }
3
+ const lambda = require('aws-cdk-lib/aws-lambda');
4
+ const s3 = require('aws-cdk-lib/aws-s3');
10
5
 
11
6
  const stackPrefix = process.env.STACK_NAME_PREFIX;
12
7
  const app = new cdk.App();
13
8
 
14
- new BasicStack(app, `${stackPrefix}-basic`, {
15
- queueName: process.env.BASIC_QUEUE_LOGICAL_ID ?? 'BasicQueue',
9
+ const mainStack = new cdk.Stack(app, `${stackPrefix}-basic`);
10
+ new sqs.Queue(mainStack, process.env.BASIC_QUEUE_LOGICAL_ID ?? 'BasicQueue');
11
+
12
+ const bucketStack = new cdk.Stack(app, `${stackPrefix}-bucket-stack`);
13
+ const dummy = new s3.Bucket(bucketStack, 'DummyBucket', {
14
+ bucketName: `dummy-bucket-for-${stackPrefix}`
16
15
  });
17
16
 
17
+ // This part is to test adding a resource to an existing stack
18
+
19
+ if (process.env.ADDITIONAL_QUEUE_LOGICAL_ID) {
20
+ new sqs.Queue(mainStack, process.env.ADDITIONAL_QUEUE_LOGICAL_ID);
21
+ }
22
+
23
+ // This part is to test moving a resource to a separate stack
24
+ const bucket = new s3.Bucket(process.env.BUCKET_IN_SEPARATE_STACK ? bucketStack : mainStack, 'Bucket');
25
+
26
+ new lambda.Function(mainStack, 'Func', {
27
+ runtime: lambda.Runtime.NODEJS_22_X,
28
+ code: lambda.Code.fromInline(`exports.handler = handler.toString()`),
29
+ handler: 'index.handler',
30
+ environment: {
31
+ BUCKET: bucket.bucketName
32
+ }
33
+ });
34
+
35
+
36
+
18
37
  app.synth();
@@ -0,0 +1,7 @@
1
+ {
2
+ "app": "node refactoring.js",
3
+ "versionReporting": false,
4
+ "context": {
5
+ "aws-cdk:enableDiffNoFail": "true"
6
+ }
7
+ }
@@ -0,0 +1,26 @@
1
+ const cdk = require('aws-cdk-lib');
2
+ const s3 = require('aws-cdk-lib/aws-s3');
3
+
4
+ const BUCKET_ID = process.env.BUCKET_ID ?? 'OldName';
5
+ const stackPrefix = process.env.STACK_NAME_PREFIX;
6
+
7
+ const app = new cdk.App();
8
+
9
+ let gamma = {
10
+ region: 'eu-central-1',
11
+ };
12
+ let prod = {
13
+ region: 'us-east-1',
14
+ };
15
+
16
+ class MyStack extends cdk.Stack {
17
+ constructor(scope, id) {
18
+ super(scope, id);
19
+ new s3.Bucket(this, BUCKET_ID);
20
+ }
21
+ }
22
+
23
+ new MyStack(app, `${stackPrefix}-gamma-stack`, { env: gamma });
24
+ new MyStack(app, `${stackPrefix}-prod-stack`, { env: prod });
25
+
26
+ app.synth();
@@ -1,8 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const lib_1 = require("../../../lib");
4
- (0, lib_1.integTest)('detects refactoring changes and prints the result', (0, lib_1.withSpecificFixture)('refactoring', async (fixture) => {
5
- // First, deploy a stack
4
+ (0, lib_1.integTest)('cdk refactor - detects refactoring changes and prints the result', (0, lib_1.withSpecificFixture)('refactoring', async (fixture) => {
5
+ // First, deploy the stacks
6
+ await fixture.cdkDeploy('bucket-stack');
6
7
  await fixture.cdkDeploy('basic', {
7
8
  modEnv: {
8
9
  BASIC_QUEUE_LOGICAL_ID: 'OldName',
@@ -12,8 +13,8 @@ const lib_1 = require("../../../lib");
12
13
  const stdErr = await fixture.cdkRefactor({
13
14
  options: ['--dry-run', '--unstable=refactor'],
14
15
  allowErrExit: true,
15
- // Making sure the synthesized stack has the new name
16
- // so that a refactor is detected
16
+ // Making sure the synthesized stack has a queue with
17
+ // the new name so that a refactor is detected
17
18
  modEnv: {
18
19
  BASIC_QUEUE_LOGICAL_ID: 'NewName',
19
20
  },
@@ -21,11 +22,12 @@ const lib_1 = require("../../../lib");
21
22
  expect(stdErr).toContain('The following resources were moved or renamed:');
22
23
  expect(removeColor(stdErr)).toMatch(/│ AWS::SQS::Queue │ .*\/OldName\/Resource │ .*\/NewName\/Resource │/);
23
24
  }));
24
- (0, lib_1.integTest)('no refactoring changes detected', (0, lib_1.withSpecificFixture)('refactoring', async (fixture) => {
25
+ (0, lib_1.integTest)('cdk refactor - no refactoring changes detected', (0, lib_1.withSpecificFixture)('refactoring', async (fixture) => {
25
26
  const modEnv = {
26
27
  BASIC_QUEUE_LOGICAL_ID: 'OldName',
27
28
  };
28
- // First, deploy a stack
29
+ // First, deploy the stacks
30
+ await fixture.cdkDeploy('bucket-stack');
29
31
  await fixture.cdkDeploy('basic', { modEnv });
30
32
  // Then see if the refactoring tool detects the change
31
33
  const stdErr = await fixture.cdkRefactor({
@@ -35,7 +37,33 @@ const lib_1 = require("../../../lib");
35
37
  });
36
38
  expect(stdErr).toContain('Nothing to refactor');
37
39
  }));
40
+ (0, lib_1.integTest)('cdk refactor - filters stacks by pattern', (0, lib_1.withSpecificFixture)('refactoring-multiple-envs', async (fixture) => {
41
+ // First, deploy the stacks
42
+ await fixture.cdkDeploy('gamma-stack', {
43
+ modEnv: {
44
+ BUCKET_ID: 'OldName',
45
+ },
46
+ });
47
+ await fixture.cdkDeploy('prod-stack', {
48
+ modEnv: {
49
+ BUCKET_ID: 'OldName',
50
+ },
51
+ });
52
+ // Then see if the refactoring tool detects the change
53
+ const stdErr = await fixture.cdkRefactor({
54
+ options: ['*-gamma-stack', '--dry-run', '--unstable=refactor'],
55
+ allowErrExit: true,
56
+ captureStderr: true,
57
+ // Making sure the synthesized stack has a queue with
58
+ // the new name so that a refactor is detected
59
+ modEnv: {
60
+ BUCKET_ID: 'NewName',
61
+ },
62
+ });
63
+ const numberOfEnvironments = (stdErr.match(/Resource Type/g) || []).length;
64
+ expect(numberOfEnvironments).toEqual(1);
65
+ }));
38
66
  function removeColor(str) {
39
67
  return str.replace(/\x1B[[(?);]{0,2}(;?\d)*./g, '');
40
68
  }
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2RrLXJlZmFjdG9yLWRyeS1ydW4uaW50ZWd0ZXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiY2RrLXJlZmFjdG9yLWRyeS1ydW4uaW50ZWd0ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsc0NBQThEO0FBRTlELElBQUEsZUFBUyxFQUNQLG1EQUFtRCxFQUNuRCxJQUFBLHlCQUFtQixFQUFDLGFBQWEsRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLEVBQUU7SUFDbkQsd0JBQXdCO0lBQ3hCLE1BQU0sT0FBTyxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUU7UUFDL0IsTUFBTSxFQUFFO1lBQ04sc0JBQXNCLEVBQUUsU0FBUztTQUNsQztLQUNGLENBQUMsQ0FBQztJQUVILHNEQUFzRDtJQUN0RCxNQUFNLE1BQU0sR0FBRyxNQUFNLE9BQU8sQ0FBQyxXQUFXLENBQUM7UUFDdkMsT0FBTyxFQUFFLENBQUMsV0FBVyxFQUFFLHFCQUFxQixDQUFDO1FBQzdDLFlBQVksRUFBRSxJQUFJO1FBQ2xCLHFEQUFxRDtRQUNyRCxpQ0FBaUM7UUFDakMsTUFBTSxFQUFFO1lBQ04sc0JBQXNCLEVBQUUsU0FBUztTQUNsQztLQUNGLENBQUMsQ0FBQztJQUVILE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxTQUFTLENBQUMsZ0RBQWdELENBQUMsQ0FBQztJQUMzRSxNQUFNLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLHFFQUFxRSxDQUFDLENBQUM7QUFDN0csQ0FBQyxDQUFDLENBQ0gsQ0FBQztBQUVGLElBQUEsZUFBUyxFQUNQLGlDQUFpQyxFQUNqQyxJQUFBLHlCQUFtQixFQUFDLGFBQWEsRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLEVBQUU7SUFDbkQsTUFBTSxNQUFNLEdBQUc7UUFDYixzQkFBc0IsRUFBRSxTQUFTO0tBQ2xDLENBQUM7SUFFRix3QkFBd0I7SUFDeEIsTUFBTSxPQUFPLENBQUMsU0FBUyxDQUFDLE9BQU8sRUFBRSxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7SUFFN0Msc0RBQXNEO0lBQ3RELE1BQU0sTUFBTSxHQUFHLE1BQU0sT0FBTyxDQUFDLFdBQVcsQ0FBQztRQUN2QyxPQUFPLEVBQUUsQ0FBQyxXQUFXLEVBQUUscUJBQXFCLENBQUM7UUFDN0MsWUFBWSxFQUFFLElBQUk7UUFDbEIsTUFBTTtLQUNQLENBQUMsQ0FBQztJQUVILE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxTQUFTLENBQUMscUJBQXFCLENBQUMsQ0FBQztBQUNsRCxDQUFDLENBQUMsQ0FDSCxDQUFDO0FBRUYsU0FBUyxXQUFXLENBQUMsR0FBVztJQUM5QixPQUFPLEdBQUcsQ0FBQyxPQUFPLENBQUMsMkJBQTJCLEVBQUUsRUFBRSxDQUFDLENBQUM7QUFDdEQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGludGVnVGVzdCwgd2l0aFNwZWNpZmljRml4dHVyZSB9IGZyb20gJy4uLy4uLy4uL2xpYic7XG5cbmludGVnVGVzdChcbiAgJ2RldGVjdHMgcmVmYWN0b3JpbmcgY2hhbmdlcyBhbmQgcHJpbnRzIHRoZSByZXN1bHQnLFxuICB3aXRoU3BlY2lmaWNGaXh0dXJlKCdyZWZhY3RvcmluZycsIGFzeW5jIChmaXh0dXJlKSA9PiB7XG4gICAgLy8gRmlyc3QsIGRlcGxveSBhIHN0YWNrXG4gICAgYXdhaXQgZml4dHVyZS5jZGtEZXBsb3koJ2Jhc2ljJywge1xuICAgICAgbW9kRW52OiB7XG4gICAgICAgIEJBU0lDX1FVRVVFX0xPR0lDQUxfSUQ6ICdPbGROYW1lJyxcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICAvLyBUaGVuIHNlZSBpZiB0aGUgcmVmYWN0b3JpbmcgdG9vbCBkZXRlY3RzIHRoZSBjaGFuZ2VcbiAgICBjb25zdCBzdGRFcnIgPSBhd2FpdCBmaXh0dXJlLmNka1JlZmFjdG9yKHtcbiAgICAgIG9wdGlvbnM6IFsnLS1kcnktcnVuJywgJy0tdW5zdGFibGU9cmVmYWN0b3InXSxcbiAgICAgIGFsbG93RXJyRXhpdDogdHJ1ZSxcbiAgICAgIC8vIE1ha2luZyBzdXJlIHRoZSBzeW50aGVzaXplZCBzdGFjayBoYXMgdGhlIG5ldyBuYW1lXG4gICAgICAvLyBzbyB0aGF0IGEgcmVmYWN0b3IgaXMgZGV0ZWN0ZWRcbiAgICAgIG1vZEVudjoge1xuICAgICAgICBCQVNJQ19RVUVVRV9MT0dJQ0FMX0lEOiAnTmV3TmFtZScsXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgZXhwZWN0KHN0ZEVycikudG9Db250YWluKCdUaGUgZm9sbG93aW5nIHJlc291cmNlcyB3ZXJlIG1vdmVkIG9yIHJlbmFtZWQ6Jyk7XG4gICAgZXhwZWN0KHJlbW92ZUNvbG9yKHN0ZEVycikpLnRvTWF0Y2goL+KUgiBBV1M6OlNRUzo6UXVldWUg4pSCIC4qXFwvT2xkTmFtZVxcL1Jlc291cmNlIOKUgiAuKlxcL05ld05hbWVcXC9SZXNvdXJjZSDilIIvKTtcbiAgfSksXG4pO1xuXG5pbnRlZ1Rlc3QoXG4gICdubyByZWZhY3RvcmluZyBjaGFuZ2VzIGRldGVjdGVkJyxcbiAgd2l0aFNwZWNpZmljRml4dHVyZSgncmVmYWN0b3JpbmcnLCBhc3luYyAoZml4dHVyZSkgPT4ge1xuICAgIGNvbnN0IG1vZEVudiA9IHtcbiAgICAgIEJBU0lDX1FVRVVFX0xPR0lDQUxfSUQ6ICdPbGROYW1lJyxcbiAgICB9O1xuXG4gICAgLy8gRmlyc3QsIGRlcGxveSBhIHN0YWNrXG4gICAgYXdhaXQgZml4dHVyZS5jZGtEZXBsb3koJ2Jhc2ljJywgeyBtb2RFbnYgfSk7XG5cbiAgICAvLyBUaGVuIHNlZSBpZiB0aGUgcmVmYWN0b3JpbmcgdG9vbCBkZXRlY3RzIHRoZSBjaGFuZ2VcbiAgICBjb25zdCBzdGRFcnIgPSBhd2FpdCBmaXh0dXJlLmNka1JlZmFjdG9yKHtcbiAgICAgIG9wdGlvbnM6IFsnLS1kcnktcnVuJywgJy0tdW5zdGFibGU9cmVmYWN0b3InXSxcbiAgICAgIGFsbG93RXJyRXhpdDogdHJ1ZSxcbiAgICAgIG1vZEVudixcbiAgICB9KTtcblxuICAgIGV4cGVjdChzdGRFcnIpLnRvQ29udGFpbignTm90aGluZyB0byByZWZhY3RvcicpO1xuICB9KSxcbik7XG5cbmZ1bmN0aW9uIHJlbW92ZUNvbG9yKHN0cjogc3RyaW5nKTogc3RyaW5nIHtcbiAgcmV0dXJuIHN0ci5yZXBsYWNlKC9cXHgxQltbKD8pO117MCwyfSg7P1xcZCkqLi9nLCAnJyk7XG59XG5cbiJdfQ==
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2RrLXJlZmFjdG9yLWRyeS1ydW4uaW50ZWd0ZXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiY2RrLXJlZmFjdG9yLWRyeS1ydW4uaW50ZWd0ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsc0NBQThEO0FBRTlELElBQUEsZUFBUyxFQUNQLGtFQUFrRSxFQUNsRSxJQUFBLHlCQUFtQixFQUFDLGFBQWEsRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLEVBQUU7SUFDbkQsMkJBQTJCO0lBQzNCLE1BQU0sT0FBTyxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUN4QyxNQUFNLE9BQU8sQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFO1FBQy9CLE1BQU0sRUFBRTtZQUNOLHNCQUFzQixFQUFFLFNBQVM7U0FDbEM7S0FDRixDQUFDLENBQUM7SUFFSCxzREFBc0Q7SUFDdEQsTUFBTSxNQUFNLEdBQUcsTUFBTSxPQUFPLENBQUMsV0FBVyxDQUFDO1FBQ3ZDLE9BQU8sRUFBRSxDQUFDLFdBQVcsRUFBRSxxQkFBcUIsQ0FBQztRQUM3QyxZQUFZLEVBQUUsSUFBSTtRQUNsQixxREFBcUQ7UUFDckQsOENBQThDO1FBQzlDLE1BQU0sRUFBRTtZQUNOLHNCQUFzQixFQUFFLFNBQVM7U0FDbEM7S0FDRixDQUFDLENBQUM7SUFFSCxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsU0FBUyxDQUFDLGdEQUFnRCxDQUFDLENBQUM7SUFDM0UsTUFBTSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxxRUFBcUUsQ0FBQyxDQUFDO0FBQzdHLENBQUMsQ0FBQyxDQUNILENBQUM7QUFFRixJQUFBLGVBQVMsRUFDUCxnREFBZ0QsRUFDaEQsSUFBQSx5QkFBbUIsRUFBQyxhQUFhLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxFQUFFO0lBQ25ELE1BQU0sTUFBTSxHQUFHO1FBQ2Isc0JBQXNCLEVBQUUsU0FBUztLQUNsQyxDQUFDO0lBRUYsMkJBQTJCO0lBQzNCLE1BQU0sT0FBTyxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUN4QyxNQUFNLE9BQU8sQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztJQUU3QyxzREFBc0Q7SUFDdEQsTUFBTSxNQUFNLEdBQUcsTUFBTSxPQUFPLENBQUMsV0FBVyxDQUFDO1FBQ3ZDLE9BQU8sRUFBRSxDQUFDLFdBQVcsRUFBRSxxQkFBcUIsQ0FBQztRQUM3QyxZQUFZLEVBQUUsSUFBSTtRQUNsQixNQUFNO0tBQ1AsQ0FBQyxDQUFDO0lBRUgsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLFNBQVMsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO0FBQ2xELENBQUMsQ0FBQyxDQUNILENBQUM7QUFFRixJQUFBLGVBQVMsRUFDUCwwQ0FBMEMsRUFDMUMsSUFBQSx5QkFBbUIsRUFBQywyQkFBMkIsRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLEVBQUU7SUFDakUsMkJBQTJCO0lBQzNCLE1BQU0sT0FBTyxDQUFDLFNBQVMsQ0FBQyxhQUFhLEVBQUU7UUFDckMsTUFBTSxFQUFFO1lBQ04sU0FBUyxFQUFFLFNBQVM7U0FDckI7S0FDRixDQUFDLENBQUM7SUFDSCxNQUFNLE9BQU8sQ0FBQyxTQUFTLENBQUMsWUFBWSxFQUFFO1FBQ3BDLE1BQU0sRUFBRTtZQUNOLFNBQVMsRUFBRSxTQUFTO1NBQ3JCO0tBQ0YsQ0FBQyxDQUFDO0lBRUgsc0RBQXNEO0lBQ3RELE1BQU0sTUFBTSxHQUFHLE1BQU0sT0FBTyxDQUFDLFdBQVcsQ0FBQztRQUN2QyxPQUFPLEVBQUUsQ0FBQyxlQUFlLEVBQUUsV0FBVyxFQUFFLHFCQUFxQixDQUFDO1FBQzlELFlBQVksRUFBRSxJQUFJO1FBQ2xCLGFBQWEsRUFBRSxJQUFJO1FBQ25CLHFEQUFxRDtRQUNyRCw4Q0FBOEM7UUFDOUMsTUFBTSxFQUFFO1lBQ04sU0FBUyxFQUFFLFNBQVM7U0FDckI7S0FDRixDQUFDLENBQUM7SUFFSCxNQUFNLG9CQUFvQixHQUFHLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQztJQUMzRSxNQUFNLENBQUMsb0JBQW9CLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDMUMsQ0FBQyxDQUFDLENBQ0gsQ0FBQztBQUVGLFNBQVMsV0FBVyxDQUFDLEdBQVc7SUFDOUIsT0FBTyxHQUFHLENBQUMsT0FBTyxDQUFDLDJCQUEyQixFQUFFLEVBQUUsQ0FBQyxDQUFDO0FBQ3RELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbnRlZ1Rlc3QsIHdpdGhTcGVjaWZpY0ZpeHR1cmUgfSBmcm9tICcuLi8uLi8uLi9saWInO1xuXG5pbnRlZ1Rlc3QoXG4gICdjZGsgcmVmYWN0b3IgLSBkZXRlY3RzIHJlZmFjdG9yaW5nIGNoYW5nZXMgYW5kIHByaW50cyB0aGUgcmVzdWx0JyxcbiAgd2l0aFNwZWNpZmljRml4dHVyZSgncmVmYWN0b3JpbmcnLCBhc3luYyAoZml4dHVyZSkgPT4ge1xuICAgIC8vIEZpcnN0LCBkZXBsb3kgdGhlIHN0YWNrc1xuICAgIGF3YWl0IGZpeHR1cmUuY2RrRGVwbG95KCdidWNrZXQtc3RhY2snKTtcbiAgICBhd2FpdCBmaXh0dXJlLmNka0RlcGxveSgnYmFzaWMnLCB7XG4gICAgICBtb2RFbnY6IHtcbiAgICAgICAgQkFTSUNfUVVFVUVfTE9HSUNBTF9JRDogJ09sZE5hbWUnLFxuICAgICAgfSxcbiAgICB9KTtcblxuICAgIC8vIFRoZW4gc2VlIGlmIHRoZSByZWZhY3RvcmluZyB0b29sIGRldGVjdHMgdGhlIGNoYW5nZVxuICAgIGNvbnN0IHN0ZEVyciA9IGF3YWl0IGZpeHR1cmUuY2RrUmVmYWN0b3Ioe1xuICAgICAgb3B0aW9uczogWyctLWRyeS1ydW4nLCAnLS11bnN0YWJsZT1yZWZhY3RvciddLFxuICAgICAgYWxsb3dFcnJFeGl0OiB0cnVlLFxuICAgICAgLy8gTWFraW5nIHN1cmUgdGhlIHN5bnRoZXNpemVkIHN0YWNrIGhhcyBhIHF1ZXVlIHdpdGhcbiAgICAgIC8vIHRoZSBuZXcgbmFtZSBzbyB0aGF0IGEgcmVmYWN0b3IgaXMgZGV0ZWN0ZWRcbiAgICAgIG1vZEVudjoge1xuICAgICAgICBCQVNJQ19RVUVVRV9MT0dJQ0FMX0lEOiAnTmV3TmFtZScsXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgZXhwZWN0KHN0ZEVycikudG9Db250YWluKCdUaGUgZm9sbG93aW5nIHJlc291cmNlcyB3ZXJlIG1vdmVkIG9yIHJlbmFtZWQ6Jyk7XG4gICAgZXhwZWN0KHJlbW92ZUNvbG9yKHN0ZEVycikpLnRvTWF0Y2goL+KUgiBBV1M6OlNRUzo6UXVldWUg4pSCIC4qXFwvT2xkTmFtZVxcL1Jlc291cmNlIOKUgiAuKlxcL05ld05hbWVcXC9SZXNvdXJjZSDilIIvKTtcbiAgfSksXG4pO1xuXG5pbnRlZ1Rlc3QoXG4gICdjZGsgcmVmYWN0b3IgLSBubyByZWZhY3RvcmluZyBjaGFuZ2VzIGRldGVjdGVkJyxcbiAgd2l0aFNwZWNpZmljRml4dHVyZSgncmVmYWN0b3JpbmcnLCBhc3luYyAoZml4dHVyZSkgPT4ge1xuICAgIGNvbnN0IG1vZEVudiA9IHtcbiAgICAgIEJBU0lDX1FVRVVFX0xPR0lDQUxfSUQ6ICdPbGROYW1lJyxcbiAgICB9O1xuXG4gICAgLy8gRmlyc3QsIGRlcGxveSB0aGUgc3RhY2tzXG4gICAgYXdhaXQgZml4dHVyZS5jZGtEZXBsb3koJ2J1Y2tldC1zdGFjaycpO1xuICAgIGF3YWl0IGZpeHR1cmUuY2RrRGVwbG95KCdiYXNpYycsIHsgbW9kRW52IH0pO1xuXG4gICAgLy8gVGhlbiBzZWUgaWYgdGhlIHJlZmFjdG9yaW5nIHRvb2wgZGV0ZWN0cyB0aGUgY2hhbmdlXG4gICAgY29uc3Qgc3RkRXJyID0gYXdhaXQgZml4dHVyZS5jZGtSZWZhY3Rvcih7XG4gICAgICBvcHRpb25zOiBbJy0tZHJ5LXJ1bicsICctLXVuc3RhYmxlPXJlZmFjdG9yJ10sXG4gICAgICBhbGxvd0VyckV4aXQ6IHRydWUsXG4gICAgICBtb2RFbnYsXG4gICAgfSk7XG5cbiAgICBleHBlY3Qoc3RkRXJyKS50b0NvbnRhaW4oJ05vdGhpbmcgdG8gcmVmYWN0b3InKTtcbiAgfSksXG4pO1xuXG5pbnRlZ1Rlc3QoXG4gICdjZGsgcmVmYWN0b3IgLSBmaWx0ZXJzIHN0YWNrcyBieSBwYXR0ZXJuJyxcbiAgd2l0aFNwZWNpZmljRml4dHVyZSgncmVmYWN0b3JpbmctbXVsdGlwbGUtZW52cycsIGFzeW5jIChmaXh0dXJlKSA9PiB7XG4gICAgLy8gRmlyc3QsIGRlcGxveSB0aGUgc3RhY2tzXG4gICAgYXdhaXQgZml4dHVyZS5jZGtEZXBsb3koJ2dhbW1hLXN0YWNrJywge1xuICAgICAgbW9kRW52OiB7XG4gICAgICAgIEJVQ0tFVF9JRDogJ09sZE5hbWUnLFxuICAgICAgfSxcbiAgICB9KTtcbiAgICBhd2FpdCBmaXh0dXJlLmNka0RlcGxveSgncHJvZC1zdGFjaycsIHtcbiAgICAgIG1vZEVudjoge1xuICAgICAgICBCVUNLRVRfSUQ6ICdPbGROYW1lJyxcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICAvLyBUaGVuIHNlZSBpZiB0aGUgcmVmYWN0b3JpbmcgdG9vbCBkZXRlY3RzIHRoZSBjaGFuZ2VcbiAgICBjb25zdCBzdGRFcnIgPSBhd2FpdCBmaXh0dXJlLmNka1JlZmFjdG9yKHtcbiAgICAgIG9wdGlvbnM6IFsnKi1nYW1tYS1zdGFjaycsICctLWRyeS1ydW4nLCAnLS11bnN0YWJsZT1yZWZhY3RvciddLFxuICAgICAgYWxsb3dFcnJFeGl0OiB0cnVlLFxuICAgICAgY2FwdHVyZVN0ZGVycjogdHJ1ZSxcbiAgICAgIC8vIE1ha2luZyBzdXJlIHRoZSBzeW50aGVzaXplZCBzdGFjayBoYXMgYSBxdWV1ZSB3aXRoXG4gICAgICAvLyB0aGUgbmV3IG5hbWUgc28gdGhhdCBhIHJlZmFjdG9yIGlzIGRldGVjdGVkXG4gICAgICBtb2RFbnY6IHtcbiAgICAgICAgQlVDS0VUX0lEOiAnTmV3TmFtZScsXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgY29uc3QgbnVtYmVyT2ZFbnZpcm9ubWVudHMgPSAoc3RkRXJyLm1hdGNoKC9SZXNvdXJjZSBUeXBlL2cpIHx8IFtdKS5sZW5ndGg7XG4gICAgZXhwZWN0KG51bWJlck9mRW52aXJvbm1lbnRzKS50b0VxdWFsKDEpO1xuICB9KSxcbik7XG5cbmZ1bmN0aW9uIHJlbW92ZUNvbG9yKHN0cjogc3RyaW5nKTogc3RyaW5nIHtcbiAgcmV0dXJuIHN0ci5yZXBsYWNlKC9cXHgxQltbKD8pO117MCwyfSg7P1xcZCkqLi9nLCAnJyk7XG59XG5cbiJdfQ==
@@ -0,0 +1,7 @@
1
+ interface StackInfo {
2
+ readonly account: string;
3
+ readonly region: string;
4
+ readonly name: string;
5
+ }
6
+ export declare function getStackInfoFromArn(stackArn: string): StackInfo;
7
+ export {};
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getStackInfoFromArn = getStackInfoFromArn;
4
+ const client_cloudformation_1 = require("@aws-sdk/client-cloudformation");
5
+ const lib_1 = require("../../../lib");
6
+ (0, lib_1.integTest)('cdk refactor - moves a referenced resource to a different stack', (0, lib_1.withSpecificFixture)('refactoring', async (fixture) => {
7
+ // First, deploy the stacks
8
+ await fixture.cdkDeploy('bucket-stack');
9
+ const originalStackArn = await fixture.cdkDeploy('basic');
10
+ const originalStackInfo = getStackInfoFromArn(originalStackArn);
11
+ const stackPrefix = originalStackInfo.name.replace(/-basic$/, '');
12
+ // Then see if the refactoring tool detects the change
13
+ const stdErr = await fixture.cdkRefactor({
14
+ options: ['--unstable=refactor', '--force'],
15
+ allowErrExit: true,
16
+ // Making sure the synthesized stack has a queue with
17
+ // the new name so that a refactor is detected
18
+ modEnv: {
19
+ BUCKET_IN_SEPARATE_STACK: 'true',
20
+ },
21
+ });
22
+ expect(stdErr).toMatch('Stack refactor complete');
23
+ const stacks = await fixture.aws.cloudFormation.send(new client_cloudformation_1.ListStacksCommand());
24
+ const bucketStack = (stacks.StackSummaries ?? []).find((s) => s.StackName === `${stackPrefix}-bucket-stack`);
25
+ expect(bucketStack).toBeDefined();
26
+ const stackDescription = await fixture.aws.cloudFormation.send(new client_cloudformation_1.DescribeStackResourcesCommand({
27
+ StackName: bucketStack.StackName,
28
+ }));
29
+ const resources = Object.fromEntries((stackDescription.StackResources ?? []).map((resource) => [resource.LogicalResourceId, resource]));
30
+ expect(resources.Bucket83908E77).toBeDefined();
31
+ // CloudFormation may complete the refactoring, while the stack is still in the "UPDATE_IN_PROGRESS" state.
32
+ // Give it a couple of seconds to finish the update.
33
+ await new Promise((resolve) => setTimeout(resolve, 2000));
34
+ }));
35
+ function getStackInfoFromArn(stackArn) {
36
+ // Example ARN: arn:aws:cloudformation:region:account-id:stack/stack-name/guid
37
+ const arnParts = stackArn.split(':');
38
+ const resource = arnParts[5]; // "stack/stack-name/guid"
39
+ const resourceParts = resource.split('/');
40
+ // The stack name is the second part: ["stack", "stack-name", "guid"]
41
+ return {
42
+ region: arnParts[3],
43
+ account: arnParts[4],
44
+ name: resourceParts[1],
45
+ };
46
+ }
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2RrLXJlZmFjdG9yLW1vdmUtc2FtZS10by1kaWZmZXJlbnQtc3RhY2tzLmludGVndGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImNkay1yZWZhY3Rvci1tb3ZlLXNhbWUtdG8tZGlmZmVyZW50LXN0YWNrcy5pbnRlZ3Rlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUF5REEsa0RBV0M7QUFwRUQsMEVBQXNIO0FBQ3RILHNDQUE4RDtBQUU5RCxJQUFBLGVBQVMsRUFDUCxpRUFBaUUsRUFDakUsSUFBQSx5QkFBbUIsRUFBQyxhQUFhLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxFQUFFO0lBQ25ELDJCQUEyQjtJQUMzQixNQUFNLE9BQU8sQ0FBQyxTQUFTLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDeEMsTUFBTSxnQkFBZ0IsR0FBRyxNQUFNLE9BQU8sQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDMUQsTUFBTSxpQkFBaUIsR0FBRyxtQkFBbUIsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0lBQ2hFLE1BQU0sV0FBVyxHQUFHLGlCQUFpQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBRWxFLHNEQUFzRDtJQUN0RCxNQUFNLE1BQU0sR0FBRyxNQUFNLE9BQU8sQ0FBQyxXQUFXLENBQUM7UUFDdkMsT0FBTyxFQUFFLENBQUMscUJBQXFCLEVBQUUsU0FBUyxDQUFDO1FBQzNDLFlBQVksRUFBRSxJQUFJO1FBQ2xCLHFEQUFxRDtRQUNyRCw4Q0FBOEM7UUFDOUMsTUFBTSxFQUFFO1lBQ04sd0JBQXdCLEVBQUUsTUFBTTtTQUNqQztLQUNGLENBQUMsQ0FBQztJQUVILE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxPQUFPLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUVsRCxNQUFNLE1BQU0sR0FBRyxNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxJQUFJLHlDQUFpQixFQUFFLENBQUMsQ0FBQztJQUU5RSxNQUFNLFdBQVcsR0FBRyxDQUFDLE1BQU0sQ0FBQyxjQUFjLElBQUksRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsU0FBUyxLQUFLLEdBQUcsV0FBVyxlQUFlLENBQUMsQ0FBQztJQUU3RyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUM7SUFFbEMsTUFBTSxnQkFBZ0IsR0FBRyxNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDLElBQUksQ0FDNUQsSUFBSSxxREFBNkIsQ0FBQztRQUNoQyxTQUFTLEVBQUUsV0FBWSxDQUFDLFNBQVM7S0FDbEMsQ0FBQyxDQUNILENBQUM7SUFFRixNQUFNLFNBQVMsR0FBRyxNQUFNLENBQUMsV0FBVyxDQUNsQyxDQUFDLGdCQUFnQixDQUFDLGNBQWMsSUFBSSxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQ3pDLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxpQkFBa0IsRUFBRSxRQUFRLENBQTRCLENBQ2pGLENBQ0YsQ0FBQztJQUVGLE1BQU0sQ0FBQyxTQUFTLENBQUMsY0FBYyxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUM7SUFFL0MsMkdBQTJHO0lBQzNHLG9EQUFvRDtJQUNwRCxNQUFNLElBQUksT0FBTyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxVQUFVLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUM7QUFDNUQsQ0FBQyxDQUFDLENBQ0gsQ0FBQztBQVFGLFNBQWdCLG1CQUFtQixDQUFDLFFBQWdCO0lBQ2xELDhFQUE4RTtJQUM5RSxNQUFNLFFBQVEsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3JDLE1BQU0sUUFBUSxHQUFHLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLDBCQUEwQjtJQUN4RCxNQUFNLGFBQWEsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzFDLHFFQUFxRTtJQUNyRSxPQUFPO1FBQ0wsTUFBTSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUM7UUFDbkIsT0FBTyxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUM7UUFDcEIsSUFBSSxFQUFFLGFBQWEsQ0FBQyxDQUFDLENBQUM7S0FDdkIsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEZXNjcmliZVN0YWNrUmVzb3VyY2VzQ29tbWFuZCwgTGlzdFN0YWNrc0NvbW1hbmQsIHR5cGUgU3RhY2tSZXNvdXJjZSB9IGZyb20gJ0Bhd3Mtc2RrL2NsaWVudC1jbG91ZGZvcm1hdGlvbic7XG5pbXBvcnQgeyBpbnRlZ1Rlc3QsIHdpdGhTcGVjaWZpY0ZpeHR1cmUgfSBmcm9tICcuLi8uLi8uLi9saWInO1xuXG5pbnRlZ1Rlc3QoXG4gICdjZGsgcmVmYWN0b3IgLSBtb3ZlcyBhIHJlZmVyZW5jZWQgcmVzb3VyY2UgdG8gYSBkaWZmZXJlbnQgc3RhY2snLFxuICB3aXRoU3BlY2lmaWNGaXh0dXJlKCdyZWZhY3RvcmluZycsIGFzeW5jIChmaXh0dXJlKSA9PiB7XG4gICAgLy8gRmlyc3QsIGRlcGxveSB0aGUgc3RhY2tzXG4gICAgYXdhaXQgZml4dHVyZS5jZGtEZXBsb3koJ2J1Y2tldC1zdGFjaycpO1xuICAgIGNvbnN0IG9yaWdpbmFsU3RhY2tBcm4gPSBhd2FpdCBmaXh0dXJlLmNka0RlcGxveSgnYmFzaWMnKTtcbiAgICBjb25zdCBvcmlnaW5hbFN0YWNrSW5mbyA9IGdldFN0YWNrSW5mb0Zyb21Bcm4ob3JpZ2luYWxTdGFja0Fybik7XG4gICAgY29uc3Qgc3RhY2tQcmVmaXggPSBvcmlnaW5hbFN0YWNrSW5mby5uYW1lLnJlcGxhY2UoLy1iYXNpYyQvLCAnJyk7XG5cbiAgICAvLyBUaGVuIHNlZSBpZiB0aGUgcmVmYWN0b3JpbmcgdG9vbCBkZXRlY3RzIHRoZSBjaGFuZ2VcbiAgICBjb25zdCBzdGRFcnIgPSBhd2FpdCBmaXh0dXJlLmNka1JlZmFjdG9yKHtcbiAgICAgIG9wdGlvbnM6IFsnLS11bnN0YWJsZT1yZWZhY3RvcicsICctLWZvcmNlJ10sXG4gICAgICBhbGxvd0VyckV4aXQ6IHRydWUsXG4gICAgICAvLyBNYWtpbmcgc3VyZSB0aGUgc3ludGhlc2l6ZWQgc3RhY2sgaGFzIGEgcXVldWUgd2l0aFxuICAgICAgLy8gdGhlIG5ldyBuYW1lIHNvIHRoYXQgYSByZWZhY3RvciBpcyBkZXRlY3RlZFxuICAgICAgbW9kRW52OiB7XG4gICAgICAgIEJVQ0tFVF9JTl9TRVBBUkFURV9TVEFDSzogJ3RydWUnLFxuICAgICAgfSxcbiAgICB9KTtcblxuICAgIGV4cGVjdChzdGRFcnIpLnRvTWF0Y2goJ1N0YWNrIHJlZmFjdG9yIGNvbXBsZXRlJyk7XG5cbiAgICBjb25zdCBzdGFja3MgPSBhd2FpdCBmaXh0dXJlLmF3cy5jbG91ZEZvcm1hdGlvbi5zZW5kKG5ldyBMaXN0U3RhY2tzQ29tbWFuZCgpKTtcblxuICAgIGNvbnN0IGJ1Y2tldFN0YWNrID0gKHN0YWNrcy5TdGFja1N1bW1hcmllcyA/PyBbXSkuZmluZCgocykgPT4gcy5TdGFja05hbWUgPT09IGAke3N0YWNrUHJlZml4fS1idWNrZXQtc3RhY2tgKTtcblxuICAgIGV4cGVjdChidWNrZXRTdGFjaykudG9CZURlZmluZWQoKTtcblxuICAgIGNvbnN0IHN0YWNrRGVzY3JpcHRpb24gPSBhd2FpdCBmaXh0dXJlLmF3cy5jbG91ZEZvcm1hdGlvbi5zZW5kKFxuICAgICAgbmV3IERlc2NyaWJlU3RhY2tSZXNvdXJjZXNDb21tYW5kKHtcbiAgICAgICAgU3RhY2tOYW1lOiBidWNrZXRTdGFjayEuU3RhY2tOYW1lLFxuICAgICAgfSksXG4gICAgKTtcblxuICAgIGNvbnN0IHJlc291cmNlcyA9IE9iamVjdC5mcm9tRW50cmllcyhcbiAgICAgIChzdGFja0Rlc2NyaXB0aW9uLlN0YWNrUmVzb3VyY2VzID8/IFtdKS5tYXAoXG4gICAgICAgIChyZXNvdXJjZSkgPT4gW3Jlc291cmNlLkxvZ2ljYWxSZXNvdXJjZUlkISwgcmVzb3VyY2VdIGFzIFtzdHJpbmcsIFN0YWNrUmVzb3VyY2VdLFxuICAgICAgKSxcbiAgICApO1xuXG4gICAgZXhwZWN0KHJlc291cmNlcy5CdWNrZXQ4MzkwOEU3NykudG9CZURlZmluZWQoKTtcblxuICAgIC8vIENsb3VkRm9ybWF0aW9uIG1heSBjb21wbGV0ZSB0aGUgcmVmYWN0b3JpbmcsIHdoaWxlIHRoZSBzdGFjayBpcyBzdGlsbCBpbiB0aGUgXCJVUERBVEVfSU5fUFJPR1JFU1NcIiBzdGF0ZS5cbiAgICAvLyBHaXZlIGl0IGEgY291cGxlIG9mIHNlY29uZHMgdG8gZmluaXNoIHRoZSB1cGRhdGUuXG4gICAgYXdhaXQgbmV3IFByb21pc2UoKHJlc29sdmUpID0+IHNldFRpbWVvdXQocmVzb2x2ZSwgMjAwMCkpO1xuICB9KSxcbik7XG5cbmludGVyZmFjZSBTdGFja0luZm8ge1xuICByZWFkb25seSBhY2NvdW50OiBzdHJpbmc7XG4gIHJlYWRvbmx5IHJlZ2lvbjogc3RyaW5nO1xuICByZWFkb25seSBuYW1lOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRTdGFja0luZm9Gcm9tQXJuKHN0YWNrQXJuOiBzdHJpbmcpOiBTdGFja0luZm8ge1xuICAvLyBFeGFtcGxlIEFSTjogYXJuOmF3czpjbG91ZGZvcm1hdGlvbjpyZWdpb246YWNjb3VudC1pZDpzdGFjay9zdGFjay1uYW1lL2d1aWRcbiAgY29uc3QgYXJuUGFydHMgPSBzdGFja0Fybi5zcGxpdCgnOicpO1xuICBjb25zdCByZXNvdXJjZSA9IGFyblBhcnRzWzVdOyAvLyBcInN0YWNrL3N0YWNrLW5hbWUvZ3VpZFwiXG4gIGNvbnN0IHJlc291cmNlUGFydHMgPSByZXNvdXJjZS5zcGxpdCgnLycpO1xuICAvLyBUaGUgc3RhY2sgbmFtZSBpcyB0aGUgc2Vjb25kIHBhcnQ6IFtcInN0YWNrXCIsIFwic3RhY2stbmFtZVwiLCBcImd1aWRcIl1cbiAgcmV0dXJuIHtcbiAgICByZWdpb246IGFyblBhcnRzWzNdLFxuICAgIGFjY291bnQ6IGFyblBhcnRzWzRdLFxuICAgIG5hbWU6IHJlc291cmNlUGFydHNbMV0sXG4gIH07XG59XG5cbiJdfQ==
@@ -0,0 +1 @@
1
+ export declare function getStackNameFromArn(stackArn: string): string;
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getStackNameFromArn = getStackNameFromArn;
4
+ const client_cloudformation_1 = require("@aws-sdk/client-cloudformation");
5
+ const lib_1 = require("../../../lib");
6
+ (0, lib_1.integTest)('cdk refactor - detects refactoring changes and executes the refactor', (0, lib_1.withSpecificFixture)('refactoring', async (fixture) => {
7
+ // First, deploy the stacks
8
+ await fixture.cdkDeploy('bucket-stack');
9
+ const stackArn = await fixture.cdkDeploy('basic', {
10
+ modEnv: {
11
+ BASIC_QUEUE_LOGICAL_ID: 'OldName',
12
+ },
13
+ });
14
+ // Then see if the refactoring tool detects the change
15
+ const stdErr = await fixture.cdkRefactor({
16
+ options: ['--unstable=refactor', '--force'],
17
+ allowErrExit: true,
18
+ // Making sure the synthesized stack has a queue with
19
+ // the new name so that a refactor is detected
20
+ modEnv: {
21
+ BASIC_QUEUE_LOGICAL_ID: 'NewName',
22
+ },
23
+ });
24
+ expect(stdErr).toMatch('Stack refactor complete');
25
+ const stackDescription = await fixture.aws.cloudFormation.send(new client_cloudformation_1.DescribeStackResourcesCommand({
26
+ StackName: getStackNameFromArn(stackArn),
27
+ }));
28
+ const resources = Object.fromEntries((stackDescription.StackResources ?? []).map((resource) => [resource.LogicalResourceId, resource]));
29
+ expect(resources.NewName57B171FE).toBeDefined();
30
+ // CloudFormation may complete the refactoring, while the stack is still in the "UPDATE_IN_PROGRESS" state.
31
+ // Give it a couple of seconds to finish the update.
32
+ await new Promise((resolve) => setTimeout(resolve, 2000));
33
+ }));
34
+ function getStackNameFromArn(stackArn) {
35
+ // Example ARN: arn:aws:cloudformation:region:account-id:stack/stack-name/guid
36
+ const arnParts = stackArn.split(':');
37
+ const resource = arnParts[5]; // "stack/stack-name/guid"
38
+ const resourceParts = resource.split('/');
39
+ // The stack name is the second part: ["stack", "stack-name", "guid"]
40
+ return resourceParts[1];
41
+ }
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2RrLXJlZmFjdG9yLW5vLWFtYmlndWl0aWVzLWV4ZWN1dGlvbi5pbnRlZ3Rlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJjZGstcmVmYWN0b3Itbm8tYW1iaWd1aXRpZXMtZXhlY3V0aW9uLmludGVndGVzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQStDQSxrREFPQztBQXRERCwwRUFBbUc7QUFDbkcsc0NBQThEO0FBRTlELElBQUEsZUFBUyxFQUNQLHNFQUFzRSxFQUN0RSxJQUFBLHlCQUFtQixFQUFDLGFBQWEsRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLEVBQUU7SUFDbkQsMkJBQTJCO0lBQzNCLE1BQU0sT0FBTyxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUN4QyxNQUFNLFFBQVEsR0FBRyxNQUFNLE9BQU8sQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFO1FBQ2hELE1BQU0sRUFBRTtZQUNOLHNCQUFzQixFQUFFLFNBQVM7U0FDbEM7S0FDRixDQUFDLENBQUM7SUFFSCxzREFBc0Q7SUFDdEQsTUFBTSxNQUFNLEdBQUcsTUFBTSxPQUFPLENBQUMsV0FBVyxDQUFDO1FBQ3ZDLE9BQU8sRUFBRSxDQUFDLHFCQUFxQixFQUFFLFNBQVMsQ0FBQztRQUMzQyxZQUFZLEVBQUUsSUFBSTtRQUNsQixxREFBcUQ7UUFDckQsOENBQThDO1FBQzlDLE1BQU0sRUFBRTtZQUNOLHNCQUFzQixFQUFFLFNBQVM7U0FDbEM7S0FDRixDQUFDLENBQUM7SUFFSCxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsT0FBTyxDQUFDLHlCQUF5QixDQUFDLENBQUM7SUFFbEQsTUFBTSxnQkFBZ0IsR0FBRyxNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDLElBQUksQ0FDNUQsSUFBSSxxREFBNkIsQ0FBQztRQUNoQyxTQUFTLEVBQUUsbUJBQW1CLENBQUMsUUFBUSxDQUFDO0tBQ3pDLENBQUMsQ0FDSCxDQUFDO0lBRUYsTUFBTSxTQUFTLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FDbEMsQ0FBQyxnQkFBZ0IsQ0FBQyxjQUFjLElBQUksRUFBRSxDQUFDLENBQUMsR0FBRyxDQUN6QyxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUMsQ0FBQyxRQUFRLENBQUMsaUJBQWtCLEVBQUUsUUFBUSxDQUE0QixDQUNqRixDQUNGLENBQUM7SUFFRixNQUFNLENBQUMsU0FBUyxDQUFDLGVBQWUsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBRWhELDJHQUEyRztJQUMzRyxvREFBb0Q7SUFDcEQsTUFBTSxJQUFJLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsVUFBVSxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFDO0FBQzVELENBQUMsQ0FBQyxDQUNILENBQUM7QUFFRixTQUFnQixtQkFBbUIsQ0FBQyxRQUFnQjtJQUNsRCw4RUFBOEU7SUFDOUUsTUFBTSxRQUFRLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNyQyxNQUFNLFFBQVEsR0FBRyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQywwQkFBMEI7SUFDeEQsTUFBTSxhQUFhLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUMxQyxxRUFBcUU7SUFDckUsT0FBTyxhQUFhLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDMUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERlc2NyaWJlU3RhY2tSZXNvdXJjZXNDb21tYW5kLCB0eXBlIFN0YWNrUmVzb3VyY2UgfSBmcm9tICdAYXdzLXNkay9jbGllbnQtY2xvdWRmb3JtYXRpb24nO1xuaW1wb3J0IHsgaW50ZWdUZXN0LCB3aXRoU3BlY2lmaWNGaXh0dXJlIH0gZnJvbSAnLi4vLi4vLi4vbGliJztcblxuaW50ZWdUZXN0KFxuICAnY2RrIHJlZmFjdG9yIC0gZGV0ZWN0cyByZWZhY3RvcmluZyBjaGFuZ2VzIGFuZCBleGVjdXRlcyB0aGUgcmVmYWN0b3InLFxuICB3aXRoU3BlY2lmaWNGaXh0dXJlKCdyZWZhY3RvcmluZycsIGFzeW5jIChmaXh0dXJlKSA9PiB7XG4gICAgLy8gRmlyc3QsIGRlcGxveSB0aGUgc3RhY2tzXG4gICAgYXdhaXQgZml4dHVyZS5jZGtEZXBsb3koJ2J1Y2tldC1zdGFjaycpO1xuICAgIGNvbnN0IHN0YWNrQXJuID0gYXdhaXQgZml4dHVyZS5jZGtEZXBsb3koJ2Jhc2ljJywge1xuICAgICAgbW9kRW52OiB7XG4gICAgICAgIEJBU0lDX1FVRVVFX0xPR0lDQUxfSUQ6ICdPbGROYW1lJyxcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICAvLyBUaGVuIHNlZSBpZiB0aGUgcmVmYWN0b3JpbmcgdG9vbCBkZXRlY3RzIHRoZSBjaGFuZ2VcbiAgICBjb25zdCBzdGRFcnIgPSBhd2FpdCBmaXh0dXJlLmNka1JlZmFjdG9yKHtcbiAgICAgIG9wdGlvbnM6IFsnLS11bnN0YWJsZT1yZWZhY3RvcicsICctLWZvcmNlJ10sXG4gICAgICBhbGxvd0VyckV4aXQ6IHRydWUsXG4gICAgICAvLyBNYWtpbmcgc3VyZSB0aGUgc3ludGhlc2l6ZWQgc3RhY2sgaGFzIGEgcXVldWUgd2l0aFxuICAgICAgLy8gdGhlIG5ldyBuYW1lIHNvIHRoYXQgYSByZWZhY3RvciBpcyBkZXRlY3RlZFxuICAgICAgbW9kRW52OiB7XG4gICAgICAgIEJBU0lDX1FVRVVFX0xPR0lDQUxfSUQ6ICdOZXdOYW1lJyxcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICBleHBlY3Qoc3RkRXJyKS50b01hdGNoKCdTdGFjayByZWZhY3RvciBjb21wbGV0ZScpO1xuXG4gICAgY29uc3Qgc3RhY2tEZXNjcmlwdGlvbiA9IGF3YWl0IGZpeHR1cmUuYXdzLmNsb3VkRm9ybWF0aW9uLnNlbmQoXG4gICAgICBuZXcgRGVzY3JpYmVTdGFja1Jlc291cmNlc0NvbW1hbmQoe1xuICAgICAgICBTdGFja05hbWU6IGdldFN0YWNrTmFtZUZyb21Bcm4oc3RhY2tBcm4pLFxuICAgICAgfSksXG4gICAgKTtcblxuICAgIGNvbnN0IHJlc291cmNlcyA9IE9iamVjdC5mcm9tRW50cmllcyhcbiAgICAgIChzdGFja0Rlc2NyaXB0aW9uLlN0YWNrUmVzb3VyY2VzID8/IFtdKS5tYXAoXG4gICAgICAgIChyZXNvdXJjZSkgPT4gW3Jlc291cmNlLkxvZ2ljYWxSZXNvdXJjZUlkISwgcmVzb3VyY2VdIGFzIFtzdHJpbmcsIFN0YWNrUmVzb3VyY2VdLFxuICAgICAgKSxcbiAgICApO1xuXG4gICAgZXhwZWN0KHJlc291cmNlcy5OZXdOYW1lNTdCMTcxRkUpLnRvQmVEZWZpbmVkKCk7XG5cbiAgICAvLyBDbG91ZEZvcm1hdGlvbiBtYXkgY29tcGxldGUgdGhlIHJlZmFjdG9yaW5nLCB3aGlsZSB0aGUgc3RhY2sgaXMgc3RpbGwgaW4gdGhlIFwiVVBEQVRFX0lOX1BST0dSRVNTXCIgc3RhdGUuXG4gICAgLy8gR2l2ZSBpdCBhIGNvdXBsZSBvZiBzZWNvbmRzIHRvIGZpbmlzaCB0aGUgdXBkYXRlLlxuICAgIGF3YWl0IG5ldyBQcm9taXNlKChyZXNvbHZlKSA9PiBzZXRUaW1lb3V0KHJlc29sdmUsIDIwMDApKTtcbiAgfSksXG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0U3RhY2tOYW1lRnJvbUFybihzdGFja0Fybjogc3RyaW5nKTogc3RyaW5nIHtcbiAgLy8gRXhhbXBsZSBBUk46IGFybjphd3M6Y2xvdWRmb3JtYXRpb246cmVnaW9uOmFjY291bnQtaWQ6c3RhY2svc3RhY2stbmFtZS9ndWlkXG4gIGNvbnN0IGFyblBhcnRzID0gc3RhY2tBcm4uc3BsaXQoJzonKTtcbiAgY29uc3QgcmVzb3VyY2UgPSBhcm5QYXJ0c1s1XTsgLy8gXCJzdGFjay9zdGFjay1uYW1lL2d1aWRcIlxuICBjb25zdCByZXNvdXJjZVBhcnRzID0gcmVzb3VyY2Uuc3BsaXQoJy8nKTtcbiAgLy8gVGhlIHN0YWNrIG5hbWUgaXMgdGhlIHNlY29uZCBwYXJ0OiBbXCJzdGFja1wiLCBcInN0YWNrLW5hbWVcIiwgXCJndWlkXCJdXG4gIHJldHVybiByZXNvdXJjZVBhcnRzWzFdO1xufVxuIl19
@@ -0,0 +1,7 @@
1
+ interface StackInfo {
2
+ readonly account: string;
3
+ readonly region: string;
4
+ readonly name: string;
5
+ }
6
+ export declare function getStackInfoFromArn(stackArn: string): StackInfo;
7
+ export {};
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getStackInfoFromArn = getStackInfoFromArn;
4
+ const fs = require("node:fs");
5
+ const os = require("node:os");
6
+ const path = require("node:path");
7
+ const client_cloudformation_1 = require("@aws-sdk/client-cloudformation");
8
+ const lib_1 = require("../../../lib");
9
+ (0, lib_1.integTest)('cdk refactor - detects refactoring changes and executes the refactor, overriding ambiguities', (0, lib_1.withSpecificFixture)('refactoring', async (fixture) => {
10
+ // First, deploy the stacks
11
+ await fixture.cdkDeploy('bucket-stack');
12
+ const stackArn = await fixture.cdkDeploy('basic', {
13
+ modEnv: {
14
+ BASIC_QUEUE_LOGICAL_ID: 'OldName',
15
+ ADDITIONAL_QUEUE_LOGICAL_ID: 'AdditionalOldName',
16
+ },
17
+ });
18
+ const stackInfo = getStackInfoFromArn(stackArn);
19
+ const stackName = stackInfo.name;
20
+ const overrides = {
21
+ environments: [
22
+ {
23
+ account: stackInfo.account,
24
+ region: stackInfo.region,
25
+ resources: {
26
+ [`${stackName}/OldName/Resource`]: `${stackName}/NewName/Resource`,
27
+ [`${stackName}/AdditionalOldName/Resource`]: `${stackName}/AdditionalNewName/Resource`,
28
+ },
29
+ },
30
+ ],
31
+ };
32
+ const overridesPath = path.join(os.tmpdir(), `overrides-${Date.now()}.json`);
33
+ fs.writeFileSync(overridesPath, JSON.stringify(overrides));
34
+ // Then see if the refactoring tool detects the change
35
+ const stdErr = await fixture.cdkRefactor({
36
+ options: ['--unstable=refactor', '--force', `--override-file=${overridesPath}`],
37
+ allowErrExit: true,
38
+ // Making sure the synthesized stack has a queue with
39
+ // the new name so that a refactor is detected
40
+ modEnv: {
41
+ BASIC_QUEUE_LOGICAL_ID: 'NewName',
42
+ ADDITIONAL_QUEUE_LOGICAL_ID: 'AdditionalNewName',
43
+ },
44
+ });
45
+ expect(stdErr).toMatch('Stack refactor complete');
46
+ const stackDescription = await fixture.aws.cloudFormation.send(new client_cloudformation_1.DescribeStackResourcesCommand({
47
+ StackName: stackName,
48
+ }));
49
+ const resources = Object.fromEntries((stackDescription.StackResources ?? []).map((resource) => [resource.LogicalResourceId, resource]));
50
+ expect(resources.AdditionalNewNameE2FC5A4C).toBeDefined();
51
+ expect(resources.NewName57B171FE).toBeDefined();
52
+ // CloudFormation may complete the refactoring, while the stack is still in the "UPDATE_IN_PROGRESS" state.
53
+ // Give it a couple of seconds to finish the update.
54
+ await new Promise((resolve) => setTimeout(resolve, 2000));
55
+ }));
56
+ function getStackInfoFromArn(stackArn) {
57
+ // Example ARN: arn:aws:cloudformation:region:account-id:stack/stack-name/guid
58
+ const arnParts = stackArn.split(':');
59
+ const resource = arnParts[5]; // "stack/stack-name/guid"
60
+ const resourceParts = resource.split('/');
61
+ // The stack name is the second part: ["stack", "stack-name", "guid"]
62
+ return {
63
+ region: arnParts[3],
64
+ account: arnParts[4],
65
+ name: resourceParts[1],
66
+ };
67
+ }
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2RrLXJlZmFjdG9yLXdpdGgtYW1iaWd1aXRpZXMtZXhlY3V0aW9uLmludGVndGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImNkay1yZWZhY3Rvci13aXRoLWFtYmlndWl0aWVzLWV4ZWN1dGlvbi5pbnRlZ3Rlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUErRUEsa0RBV0M7QUExRkQsOEJBQThCO0FBQzlCLDhCQUE4QjtBQUM5QixrQ0FBa0M7QUFFbEMsMEVBQStFO0FBQy9FLHNDQUE4RDtBQUU5RCxJQUFBLGVBQVMsRUFDUCw4RkFBOEYsRUFDOUYsSUFBQSx5QkFBbUIsRUFBQyxhQUFhLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxFQUFFO0lBQ25ELDJCQUEyQjtJQUMzQixNQUFNLE9BQU8sQ0FBQyxTQUFTLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDeEMsTUFBTSxRQUFRLEdBQUcsTUFBTSxPQUFPLENBQUMsU0FBUyxDQUFDLE9BQU8sRUFBRTtRQUNoRCxNQUFNLEVBQUU7WUFDTixzQkFBc0IsRUFBRSxTQUFTO1lBQ2pDLDJCQUEyQixFQUFFLG1CQUFtQjtTQUNqRDtLQUNGLENBQUMsQ0FBQztJQUVILE1BQU0sU0FBUyxHQUFHLG1CQUFtQixDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ2hELE1BQU0sU0FBUyxHQUFHLFNBQVMsQ0FBQyxJQUFJLENBQUM7SUFFakMsTUFBTSxTQUFTLEdBQUc7UUFDaEIsWUFBWSxFQUFFO1lBQ1o7Z0JBQ0UsT0FBTyxFQUFFLFNBQVMsQ0FBQyxPQUFPO2dCQUMxQixNQUFNLEVBQUUsU0FBUyxDQUFDLE1BQU07Z0JBQ3hCLFNBQVMsRUFBRTtvQkFDVCxDQUFDLEdBQUcsU0FBUyxtQkFBbUIsQ0FBQyxFQUFFLEdBQUcsU0FBUyxtQkFBbUI7b0JBQ2xFLENBQUMsR0FBRyxTQUFTLDZCQUE2QixDQUFDLEVBQUUsR0FBRyxTQUFTLDZCQUE2QjtpQkFDdkY7YUFDRjtTQUNGO0tBQ0YsQ0FBQztJQUVGLE1BQU0sYUFBYSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLE1BQU0sRUFBRSxFQUFFLGFBQWEsSUFBSSxDQUFDLEdBQUcsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUM3RSxFQUFFLENBQUMsYUFBYSxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFFM0Qsc0RBQXNEO0lBQ3RELE1BQU0sTUFBTSxHQUFHLE1BQU0sT0FBTyxDQUFDLFdBQVcsQ0FBQztRQUN2QyxPQUFPLEVBQUUsQ0FBQyxxQkFBcUIsRUFBRSxTQUFTLEVBQUUsbUJBQW1CLGFBQWEsRUFBRSxDQUFDO1FBQy9FLFlBQVksRUFBRSxJQUFJO1FBQ2xCLHFEQUFxRDtRQUNyRCw4Q0FBOEM7UUFDOUMsTUFBTSxFQUFFO1lBQ04sc0JBQXNCLEVBQUUsU0FBUztZQUNqQywyQkFBMkIsRUFBRSxtQkFBbUI7U0FDakQ7S0FDRixDQUFDLENBQUM7SUFFSCxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsT0FBTyxDQUFDLHlCQUF5QixDQUFDLENBQUM7SUFFbEQsTUFBTSxnQkFBZ0IsR0FBRyxNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDLElBQUksQ0FDNUQsSUFBSSxxREFBNkIsQ0FBQztRQUNoQyxTQUFTLEVBQUUsU0FBUztLQUNyQixDQUFDLENBQ0gsQ0FBQztJQUVGLE1BQU0sU0FBUyxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQ2xDLENBQUMsZ0JBQWdCLENBQUMsY0FBYyxJQUFJLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FDekMsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLENBQUMsUUFBUSxDQUFDLGlCQUFrQixFQUFFLFFBQVEsQ0FBNEIsQ0FDakYsQ0FDRixDQUFDO0lBRUYsTUFBTSxDQUFDLFNBQVMsQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQzFELE1BQU0sQ0FBQyxTQUFTLENBQUMsZUFBZSxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUM7SUFFaEQsMkdBQTJHO0lBQzNHLG9EQUFvRDtJQUNwRCxNQUFNLElBQUksT0FBTyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxVQUFVLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUM7QUFDNUQsQ0FBQyxDQUFDLENBQ0gsQ0FBQztBQVFGLFNBQWdCLG1CQUFtQixDQUFDLFFBQWdCO0lBQ2xELDhFQUE4RTtJQUM5RSxNQUFNLFFBQVEsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3JDLE1BQU0sUUFBUSxHQUFHLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLDBCQUEwQjtJQUN4RCxNQUFNLGFBQWEsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzFDLHFFQUFxRTtJQUNyRSxPQUFPO1FBQ0wsTUFBTSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUM7UUFDbkIsT0FBTyxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUM7UUFDcEIsSUFBSSxFQUFFLGFBQWEsQ0FBQyxDQUFDLENBQUM7S0FDdkIsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBmcyBmcm9tICdub2RlOmZzJztcbmltcG9ydCAqIGFzIG9zIGZyb20gJ25vZGU6b3MnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdub2RlOnBhdGgnO1xuaW1wb3J0IHR5cGUgeyBTdGFja1Jlc291cmNlIH0gZnJvbSAnQGF3cy1zZGsvY2xpZW50LWNsb3VkZm9ybWF0aW9uJztcbmltcG9ydCB7IERlc2NyaWJlU3RhY2tSZXNvdXJjZXNDb21tYW5kIH0gZnJvbSAnQGF3cy1zZGsvY2xpZW50LWNsb3VkZm9ybWF0aW9uJztcbmltcG9ydCB7IGludGVnVGVzdCwgd2l0aFNwZWNpZmljRml4dHVyZSB9IGZyb20gJy4uLy4uLy4uL2xpYic7XG5cbmludGVnVGVzdChcbiAgJ2NkayByZWZhY3RvciAtIGRldGVjdHMgcmVmYWN0b3JpbmcgY2hhbmdlcyBhbmQgZXhlY3V0ZXMgdGhlIHJlZmFjdG9yLCBvdmVycmlkaW5nIGFtYmlndWl0aWVzJyxcbiAgd2l0aFNwZWNpZmljRml4dHVyZSgncmVmYWN0b3JpbmcnLCBhc3luYyAoZml4dHVyZSkgPT4ge1xuICAgIC8vIEZpcnN0LCBkZXBsb3kgdGhlIHN0YWNrc1xuICAgIGF3YWl0IGZpeHR1cmUuY2RrRGVwbG95KCdidWNrZXQtc3RhY2snKTtcbiAgICBjb25zdCBzdGFja0FybiA9IGF3YWl0IGZpeHR1cmUuY2RrRGVwbG95KCdiYXNpYycsIHtcbiAgICAgIG1vZEVudjoge1xuICAgICAgICBCQVNJQ19RVUVVRV9MT0dJQ0FMX0lEOiAnT2xkTmFtZScsXG4gICAgICAgIEFERElUSU9OQUxfUVVFVUVfTE9HSUNBTF9JRDogJ0FkZGl0aW9uYWxPbGROYW1lJyxcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICBjb25zdCBzdGFja0luZm8gPSBnZXRTdGFja0luZm9Gcm9tQXJuKHN0YWNrQXJuKTtcbiAgICBjb25zdCBzdGFja05hbWUgPSBzdGFja0luZm8ubmFtZTtcblxuICAgIGNvbnN0IG92ZXJyaWRlcyA9IHtcbiAgICAgIGVudmlyb25tZW50czogW1xuICAgICAgICB7XG4gICAgICAgICAgYWNjb3VudDogc3RhY2tJbmZvLmFjY291bnQsXG4gICAgICAgICAgcmVnaW9uOiBzdGFja0luZm8ucmVnaW9uLFxuICAgICAgICAgIHJlc291cmNlczoge1xuICAgICAgICAgICAgW2Ake3N0YWNrTmFtZX0vT2xkTmFtZS9SZXNvdXJjZWBdOiBgJHtzdGFja05hbWV9L05ld05hbWUvUmVzb3VyY2VgLFxuICAgICAgICAgICAgW2Ake3N0YWNrTmFtZX0vQWRkaXRpb25hbE9sZE5hbWUvUmVzb3VyY2VgXTogYCR7c3RhY2tOYW1lfS9BZGRpdGlvbmFsTmV3TmFtZS9SZXNvdXJjZWAsXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgfTtcblxuICAgIGNvbnN0IG92ZXJyaWRlc1BhdGggPSBwYXRoLmpvaW4ob3MudG1wZGlyKCksIGBvdmVycmlkZXMtJHtEYXRlLm5vdygpfS5qc29uYCk7XG4gICAgZnMud3JpdGVGaWxlU3luYyhvdmVycmlkZXNQYXRoLCBKU09OLnN0cmluZ2lmeShvdmVycmlkZXMpKTtcblxuICAgIC8vIFRoZW4gc2VlIGlmIHRoZSByZWZhY3RvcmluZyB0b29sIGRldGVjdHMgdGhlIGNoYW5nZVxuICAgIGNvbnN0IHN0ZEVyciA9IGF3YWl0IGZpeHR1cmUuY2RrUmVmYWN0b3Ioe1xuICAgICAgb3B0aW9uczogWyctLXVuc3RhYmxlPXJlZmFjdG9yJywgJy0tZm9yY2UnLCBgLS1vdmVycmlkZS1maWxlPSR7b3ZlcnJpZGVzUGF0aH1gXSxcbiAgICAgIGFsbG93RXJyRXhpdDogdHJ1ZSxcbiAgICAgIC8vIE1ha2luZyBzdXJlIHRoZSBzeW50aGVzaXplZCBzdGFjayBoYXMgYSBxdWV1ZSB3aXRoXG4gICAgICAvLyB0aGUgbmV3IG5hbWUgc28gdGhhdCBhIHJlZmFjdG9yIGlzIGRldGVjdGVkXG4gICAgICBtb2RFbnY6IHtcbiAgICAgICAgQkFTSUNfUVVFVUVfTE9HSUNBTF9JRDogJ05ld05hbWUnLFxuICAgICAgICBBRERJVElPTkFMX1FVRVVFX0xPR0lDQUxfSUQ6ICdBZGRpdGlvbmFsTmV3TmFtZScsXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgZXhwZWN0KHN0ZEVycikudG9NYXRjaCgnU3RhY2sgcmVmYWN0b3IgY29tcGxldGUnKTtcblxuICAgIGNvbnN0IHN0YWNrRGVzY3JpcHRpb24gPSBhd2FpdCBmaXh0dXJlLmF3cy5jbG91ZEZvcm1hdGlvbi5zZW5kKFxuICAgICAgbmV3IERlc2NyaWJlU3RhY2tSZXNvdXJjZXNDb21tYW5kKHtcbiAgICAgICAgU3RhY2tOYW1lOiBzdGFja05hbWUsXG4gICAgICB9KSxcbiAgICApO1xuXG4gICAgY29uc3QgcmVzb3VyY2VzID0gT2JqZWN0LmZyb21FbnRyaWVzKFxuICAgICAgKHN0YWNrRGVzY3JpcHRpb24uU3RhY2tSZXNvdXJjZXMgPz8gW10pLm1hcChcbiAgICAgICAgKHJlc291cmNlKSA9PiBbcmVzb3VyY2UuTG9naWNhbFJlc291cmNlSWQhLCByZXNvdXJjZV0gYXMgW3N0cmluZywgU3RhY2tSZXNvdXJjZV0sXG4gICAgICApLFxuICAgICk7XG5cbiAgICBleHBlY3QocmVzb3VyY2VzLkFkZGl0aW9uYWxOZXdOYW1lRTJGQzVBNEMpLnRvQmVEZWZpbmVkKCk7XG4gICAgZXhwZWN0KHJlc291cmNlcy5OZXdOYW1lNTdCMTcxRkUpLnRvQmVEZWZpbmVkKCk7XG5cbiAgICAvLyBDbG91ZEZvcm1hdGlvbiBtYXkgY29tcGxldGUgdGhlIHJlZmFjdG9yaW5nLCB3aGlsZSB0aGUgc3RhY2sgaXMgc3RpbGwgaW4gdGhlIFwiVVBEQVRFX0lOX1BST0dSRVNTXCIgc3RhdGUuXG4gICAgLy8gR2l2ZSBpdCBhIGNvdXBsZSBvZiBzZWNvbmRzIHRvIGZpbmlzaCB0aGUgdXBkYXRlLlxuICAgIGF3YWl0IG5ldyBQcm9taXNlKChyZXNvbHZlKSA9PiBzZXRUaW1lb3V0KHJlc29sdmUsIDIwMDApKTtcbiAgfSksXG4pO1xuXG5pbnRlcmZhY2UgU3RhY2tJbmZvIHtcbiAgcmVhZG9ubHkgYWNjb3VudDogc3RyaW5nO1xuICByZWFkb25seSByZWdpb246IHN0cmluZztcbiAgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0U3RhY2tJbmZvRnJvbUFybihzdGFja0Fybjogc3RyaW5nKTogU3RhY2tJbmZvIHtcbiAgLy8gRXhhbXBsZSBBUk46IGFybjphd3M6Y2xvdWRmb3JtYXRpb246cmVnaW9uOmFjY291bnQtaWQ6c3RhY2svc3RhY2stbmFtZS9ndWlkXG4gIGNvbnN0IGFyblBhcnRzID0gc3RhY2tBcm4uc3BsaXQoJzonKTtcbiAgY29uc3QgcmVzb3VyY2UgPSBhcm5QYXJ0c1s1XTsgLy8gXCJzdGFjay9zdGFjay1uYW1lL2d1aWRcIlxuICBjb25zdCByZXNvdXJjZVBhcnRzID0gcmVzb3VyY2Uuc3BsaXQoJy8nKTtcbiAgLy8gVGhlIHN0YWNrIG5hbWUgaXMgdGhlIHNlY29uZCBwYXJ0OiBbXCJzdGFja1wiLCBcInN0YWNrLW5hbWVcIiwgXCJndWlkXCJdXG4gIHJldHVybiB7XG4gICAgcmVnaW9uOiBhcm5QYXJ0c1szXSxcbiAgICBhY2NvdW50OiBhcm5QYXJ0c1s0XSxcbiAgICBuYW1lOiByZXNvdXJjZVBhcnRzWzFdLFxuICB9O1xufVxuIl19
@@ -28,7 +28,6 @@ jest.setTimeout(2 * 60 * 60_000); // Includes the time to acquire locks, worst-c
28
28
  json: false,
29
29
  debug: false,
30
30
  staging: true,
31
- notices: true,
32
31
  ['no-color']: false,
33
32
  ci: expect.anything(), // changes based on where this is called
34
33
  validation: true,
@@ -77,7 +76,6 @@ jest.setTimeout(2 * 60 * 60_000); // Includes the time to acquire locks, worst-c
77
76
  json: false,
78
77
  debug: false,
79
78
  staging: true,
80
- notices: true,
81
79
  ['no-color']: false,
82
80
  ci: expect.anything(), // changes based on where this is called
83
81
  validation: true,
@@ -119,4 +117,4 @@ jest.setTimeout(2 * 60 * 60_000); // Includes the time to acquire locks, worst-c
119
117
  ]);
120
118
  fs.unlinkSync(telemetryFile);
121
119
  }));
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-synth-telemetry-with-errors.integtest.js","sourceRoot":"","sources":["cdk-synth-telemetry-with-errors.integtest.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as fs from 'fs-extra';\nimport { integTest, withDefaultFixture } from '../../../lib';\n\njest.setTimeout(2 * 60 * 60_000); // Includes the time to acquire locks, worst-case single-threaded runtime\n\nintegTest(\n  'cdk synth with telemetry and validation error leads to invoke failure',\n  withDefaultFixture(async (fixture) => {\n    const telemetryFile = path.join(fixture.integTestDir, `telemetry-${Date.now()}.json`);\n    const output = await fixture.cdk(['synth', '--unstable=telemetry', `--telemetry-file=${telemetryFile}`], {\n      allowErrExit: true,\n      modEnv: {\n        INTEG_STACK_SET: 'stage-with-errors',\n      },\n    });\n\n    expect(output).toContain('This is an error');\n\n    const json = fs.readJSONSync(telemetryFile);\n    expect(json).toEqual([\n      expect.objectContaining({\n        event: expect.objectContaining({\n          command: expect.objectContaining({\n            path: ['synth'],\n            parameters: {\n              verbose: 1,\n              unstable: '<redacted>',\n              ['telemetry-file']: '<redacted>',\n              lookups: true,\n              ['ignore-errors']: false,\n              json: false,\n              debug: false,\n              staging: true,\n              notices: true,\n              ['no-color']: false,\n              ci: expect.anything(), // changes based on where this is called\n              validation: true,\n              quiet: false,\n            },\n            config: {\n              context: {},\n            },\n          }),\n          state: 'SUCCEEDED',\n          eventType: 'SYNTH',\n        }),\n        identifiers: expect.objectContaining({\n          installationId: expect.anything(),\n          sessionId: expect.anything(),\n          telemetryVersion: '1.0',\n          cdkCliVersion: expect.anything(),\n          cdkLibraryVersion: fixture.library.requestedVersion(),\n          region: expect.anything(),\n          eventId: expect.stringContaining(':1'),\n          timestamp: expect.anything(),\n        }),\n        environment: {\n          ci: expect.anything(),\n          os: {\n            platform: expect.anything(),\n            release: expect.anything(),\n          },\n          nodeVersion: expect.anything(),\n        },\n        project: {},\n        duration: {\n          total: expect.anything(),\n        },\n      }),\n      expect.objectContaining({\n        event: expect.objectContaining({\n          command: expect.objectContaining({\n            path: ['synth'],\n            parameters: {\n              verbose: 1,\n              unstable: '<redacted>',\n              ['telemetry-file']: '<redacted>',\n              lookups: true,\n              ['ignore-errors']: false,\n              json: false,\n              debug: false,\n              staging: true,\n              notices: true,\n              ['no-color']: false,\n              ci: expect.anything(), // changes based on where this is called\n              validation: true,\n              quiet: false,\n            },\n            config: {\n              context: {},\n            },\n          }),\n          state: 'FAILED',\n          eventType: 'INVOKE',\n        }),\n        identifiers: expect.objectContaining({\n          installationId: expect.anything(),\n          sessionId: expect.anything(),\n          telemetryVersion: '1.0',\n          cdkCliVersion: expect.anything(),\n          cdkLibraryVersion: fixture.library.requestedVersion(),\n          region: expect.anything(),\n          eventId: expect.stringContaining(':2'),\n          timestamp: expect.anything(),\n        }),\n        environment: {\n          ci: expect.anything(),\n          os: {\n            platform: expect.anything(),\n            release: expect.anything(),\n          },\n          nodeVersion: expect.anything(),\n        },\n        project: {},\n        duration: {\n          total: expect.anything(),\n        },\n        error: {\n          name: 'AssemblyError',\n        },\n      }),\n    ]);\n    fs.unlinkSync(telemetryFile);\n  }),\n);\n\n"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-synth-telemetry-with-errors.integtest.js","sourceRoot":"","sources":["cdk-synth-telemetry-with-errors.integtest.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as fs from 'fs-extra';\nimport { integTest, withDefaultFixture } from '../../../lib';\n\njest.setTimeout(2 * 60 * 60_000); // Includes the time to acquire locks, worst-case single-threaded runtime\n\nintegTest(\n  'cdk synth with telemetry and validation error leads to invoke failure',\n  withDefaultFixture(async (fixture) => {\n    const telemetryFile = path.join(fixture.integTestDir, `telemetry-${Date.now()}.json`);\n    const output = await fixture.cdk(['synth', '--unstable=telemetry', `--telemetry-file=${telemetryFile}`], {\n      allowErrExit: true,\n      modEnv: {\n        INTEG_STACK_SET: 'stage-with-errors',\n      },\n    });\n\n    expect(output).toContain('This is an error');\n\n    const json = fs.readJSONSync(telemetryFile);\n    expect(json).toEqual([\n      expect.objectContaining({\n        event: expect.objectContaining({\n          command: expect.objectContaining({\n            path: ['synth'],\n            parameters: {\n              verbose: 1,\n              unstable: '<redacted>',\n              ['telemetry-file']: '<redacted>',\n              lookups: true,\n              ['ignore-errors']: false,\n              json: false,\n              debug: false,\n              staging: true,\n              ['no-color']: false,\n              ci: expect.anything(), // changes based on where this is called\n              validation: true,\n              quiet: false,\n            },\n            config: {\n              context: {},\n            },\n          }),\n          state: 'SUCCEEDED',\n          eventType: 'SYNTH',\n        }),\n        identifiers: expect.objectContaining({\n          installationId: expect.anything(),\n          sessionId: expect.anything(),\n          telemetryVersion: '1.0',\n          cdkCliVersion: expect.anything(),\n          cdkLibraryVersion: fixture.library.requestedVersion(),\n          region: expect.anything(),\n          eventId: expect.stringContaining(':1'),\n          timestamp: expect.anything(),\n        }),\n        environment: {\n          ci: expect.anything(),\n          os: {\n            platform: expect.anything(),\n            release: expect.anything(),\n          },\n          nodeVersion: expect.anything(),\n        },\n        project: {},\n        duration: {\n          total: expect.anything(),\n        },\n      }),\n      expect.objectContaining({\n        event: expect.objectContaining({\n          command: expect.objectContaining({\n            path: ['synth'],\n            parameters: {\n              verbose: 1,\n              unstable: '<redacted>',\n              ['telemetry-file']: '<redacted>',\n              lookups: true,\n              ['ignore-errors']: false,\n              json: false,\n              debug: false,\n              staging: true,\n              ['no-color']: false,\n              ci: expect.anything(), // changes based on where this is called\n              validation: true,\n              quiet: false,\n            },\n            config: {\n              context: {},\n            },\n          }),\n          state: 'FAILED',\n          eventType: 'INVOKE',\n        }),\n        identifiers: expect.objectContaining({\n          installationId: expect.anything(),\n          sessionId: expect.anything(),\n          telemetryVersion: '1.0',\n          cdkCliVersion: expect.anything(),\n          cdkLibraryVersion: fixture.library.requestedVersion(),\n          region: expect.anything(),\n          eventId: expect.stringContaining(':2'),\n          timestamp: expect.anything(),\n        }),\n        environment: {\n          ci: expect.anything(),\n          os: {\n            platform: expect.anything(),\n            release: expect.anything(),\n          },\n          nodeVersion: expect.anything(),\n        },\n        project: {},\n        duration: {\n          total: expect.anything(),\n        },\n        error: {\n          name: 'AssemblyError',\n        },\n      }),\n    ]);\n    fs.unlinkSync(telemetryFile);\n  }),\n);\n\n"]}
@@ -22,7 +22,6 @@ jest.setTimeout(2 * 60 * 60_000); // Includes the time to acquire locks, worst-c
22
22
  json: false,
23
23
  debug: false,
24
24
  staging: true,
25
- notices: true,
26
25
  ['no-color']: false,
27
26
  ci: expect.anything(), // changes based on where this is called
28
27
  validation: true,
@@ -72,7 +71,6 @@ jest.setTimeout(2 * 60 * 60_000); // Includes the time to acquire locks, worst-c
72
71
  json: false,
73
72
  debug: false,
74
73
  staging: true,
75
- notices: true,
76
74
  ['no-color']: false,
77
75
  ci: expect.anything(), // changes based on where this is called
78
76
  validation: true,
@@ -111,4 +109,4 @@ jest.setTimeout(2 * 60 * 60_000); // Includes the time to acquire locks, worst-c
111
109
  ]);
112
110
  fs.unlinkSync(telemetryFile);
113
111
  }));
114
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-synth-telemetry.integtest.js","sourceRoot":"","sources":["cdk-synth-telemetry.integtest.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as fs from 'fs-extra';\nimport { integTest, withDefaultFixture } from '../../../lib';\n\njest.setTimeout(2 * 60 * 60_000); // Includes the time to acquire locks, worst-case single-threaded runtime\n\nintegTest(\n  'cdk synth with telemetry data',\n  withDefaultFixture(async (fixture) => {\n    const telemetryFile = path.join(fixture.integTestDir, `telemetry-${Date.now()}.json`);\n    await fixture.cdk(['synth', fixture.fullStackName('test-1'), '--unstable=telemetry', `--telemetry-file=${telemetryFile}`]);\n    const json = fs.readJSONSync(telemetryFile);\n    expect(json).toEqual([\n      expect.objectContaining({\n        event: expect.objectContaining({\n          command: expect.objectContaining({\n            path: ['synth', '$STACKS_1'],\n            parameters: {\n              verbose: 1,\n              unstable: '<redacted>',\n              ['telemetry-file']: '<redacted>',\n              lookups: true,\n              ['ignore-errors']: false,\n              json: false,\n              debug: false,\n              staging: true,\n              notices: true,\n              ['no-color']: false,\n              ci: expect.anything(), // changes based on where this is called\n              validation: true,\n              quiet: false,\n            },\n            config: {\n              context: {},\n            },\n          }),\n          state: 'SUCCEEDED',\n          eventType: 'SYNTH',\n        }),\n        // some of these can change; but we assert that some value is recorded\n        identifiers: expect.objectContaining({\n          installationId: expect.anything(),\n          sessionId: expect.anything(),\n          telemetryVersion: '1.0',\n          cdkCliVersion: expect.anything(),\n          cdkLibraryVersion: fixture.library.requestedVersion(),\n          region: expect.anything(),\n          eventId: expect.stringContaining(':1'),\n          timestamp: expect.anything(),\n        }),\n        environment: {\n          ci: expect.anything(),\n          os: {\n            platform: expect.anything(),\n            release: expect.anything(),\n          },\n          nodeVersion: expect.anything(),\n        },\n        project: {},\n        duration: {\n          total: expect.anything(),\n        },\n      }),\n      expect.objectContaining({\n        event: expect.objectContaining({\n          command: expect.objectContaining({\n            path: ['synth', '$STACKS_1'],\n            parameters: {\n              verbose: 1,\n              unstable: '<redacted>',\n              ['telemetry-file']: '<redacted>',\n              lookups: true,\n              ['ignore-errors']: false,\n              json: false,\n              debug: false,\n              staging: true,\n              notices: true,\n              ['no-color']: false,\n              ci: expect.anything(), // changes based on where this is called\n              validation: true,\n              quiet: false,\n            },\n            config: {\n              context: {},\n            },\n          }),\n          state: 'SUCCEEDED',\n          eventType: 'INVOKE',\n        }),\n        identifiers: expect.objectContaining({\n          installationId: expect.anything(),\n          sessionId: expect.anything(),\n          telemetryVersion: '1.0',\n          cdkCliVersion: expect.anything(),\n          cdkLibraryVersion: fixture.library.requestedVersion(),\n          region: expect.anything(),\n          eventId: expect.stringContaining(':2'),\n          timestamp: expect.anything(),\n        }),\n        environment: {\n          ci: expect.anything(),\n          os: {\n            platform: expect.anything(),\n            release: expect.anything(),\n          },\n          nodeVersion: expect.anything(),\n        },\n        project: {},\n        duration: {\n          total: expect.anything(),\n        },\n      }),\n    ]);\n    fs.unlinkSync(telemetryFile);\n  }),\n);\n"]}
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-synth-telemetry.integtest.js","sourceRoot":"","sources":["cdk-synth-telemetry.integtest.ts"],"names":[],"mappings":";;AAAA,6BAA6B;AAC7B,+BAA+B;AAC/B,sCAA6D;AAE7D,IAAI,CAAC,UAAU,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,yEAAyE;AAE3G,IAAA,eAAS,EACP,+BAA+B,EAC/B,IAAA,wBAAkB,EAAC,KAAK,EAAE,OAAO,EAAE,EAAE;IACnC,MAAM,aAAa,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,aAAa,IAAI,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;IACtF,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,sBAAsB,EAAE,oBAAoB,aAAa,EAAE,CAAC,CAAC,CAAC;IAC3H,MAAM,IAAI,GAAG,EAAE,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;IAC5C,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC;QACnB,MAAM,CAAC,gBAAgB,CAAC;YACtB,KAAK,EAAE,MAAM,CAAC,gBAAgB,CAAC;gBAC7B,OAAO,EAAE,MAAM,CAAC,gBAAgB,CAAC;oBAC/B,IAAI,EAAE,CAAC,OAAO,EAAE,WAAW,CAAC;oBAC5B,UAAU,EAAE;wBACV,OAAO,EAAE,CAAC;wBACV,QAAQ,EAAE,YAAY;wBACtB,CAAC,gBAAgB,CAAC,EAAE,YAAY;wBAChC,OAAO,EAAE,IAAI;wBACb,CAAC,eAAe,CAAC,EAAE,KAAK;wBACxB,IAAI,EAAE,KAAK;wBACX,KAAK,EAAE,KAAK;wBACZ,OAAO,EAAE,IAAI;wBACb,CAAC,UAAU,CAAC,EAAE,KAAK;wBACnB,EAAE,EAAE,MAAM,CAAC,QAAQ,EAAE,EAAE,wCAAwC;wBAC/D,UAAU,EAAE,IAAI;wBAChB,KAAK,EAAE,KAAK;qBACb;oBACD,MAAM,EAAE;wBACN,OAAO,EAAE,EAAE;qBACZ;iBACF,CAAC;gBACF,KAAK,EAAE,WAAW;gBAClB,SAAS,EAAE,OAAO;aACnB,CAAC;YACF,sEAAsE;YACtE,WAAW,EAAE,MAAM,CAAC,gBAAgB,CAAC;gBACnC,cAAc,EAAE,MAAM,CAAC,QAAQ,EAAE;gBACjC,SAAS,EAAE,MAAM,CAAC,QAAQ,EAAE;gBAC5B,gBAAgB,EAAE,KAAK;gBACvB,aAAa,EAAE,MAAM,CAAC,QAAQ,EAAE;gBAChC,iBAAiB,EAAE,OAAO,CAAC,OAAO,CAAC,gBAAgB,EAAE;gBACrD,MAAM,EAAE,MAAM,CAAC,QAAQ,EAAE;gBACzB,OAAO,EAAE,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC;gBACtC,SAAS,EAAE,MAAM,CAAC,QAAQ,EAAE;aAC7B,CAAC;YACF,WAAW,EAAE;gBACX,EAAE,EAAE,MAAM,CAAC,QAAQ,EAAE;gBACrB,EAAE,EAAE;oBACF,QAAQ,EAAE,MAAM,CAAC,QAAQ,EAAE;oBAC3B,OAAO,EAAE,MAAM,CAAC,QAAQ,EAAE;iBAC3B;gBACD,WAAW,EAAE,MAAM,CAAC,QAAQ,EAAE;aAC/B;YACD,OAAO,EAAE,EAAE;YACX,QAAQ,EAAE;gBACR,KAAK,EAAE,MAAM,CAAC,QAAQ,EAAE;aACzB;SACF,CAAC;QACF,MAAM,CAAC,gBAAgB,CAAC;YACtB,KAAK,EAAE,MAAM,CAAC,gBAAgB,CAAC;gBAC7B,OAAO,EAAE,MAAM,CAAC,gBAAgB,CAAC;oBAC/B,IAAI,EAAE,CAAC,OAAO,EAAE,WAAW,CAAC;oBAC5B,UAAU,EAAE;wBACV,OAAO,EAAE,CAAC;wBACV,QAAQ,EAAE,YAAY;wBACtB,CAAC,gBAAgB,CAAC,EAAE,YAAY;wBAChC,OAAO,EAAE,IAAI;wBACb,CAAC,eAAe,CAAC,EAAE,KAAK;wBACxB,IAAI,EAAE,KAAK;wBACX,KAAK,EAAE,KAAK;wBACZ,OAAO,EAAE,IAAI;wBACb,CAAC,UAAU,CAAC,EAAE,KAAK;wBACnB,EAAE,EAAE,MAAM,CAAC,QAAQ,EAAE,EAAE,wCAAwC;wBAC/D,UAAU,EAAE,IAAI;wBAChB,KAAK,EAAE,KAAK;qBACb;oBACD,MAAM,EAAE;wBACN,OAAO,EAAE,EAAE;qBACZ;iBACF,CAAC;gBACF,KAAK,EAAE,WAAW;gBAClB,SAAS,EAAE,QAAQ;aACpB,CAAC;YACF,WAAW,EAAE,MAAM,CAAC,gBAAgB,CAAC;gBACnC,cAAc,EAAE,MAAM,CAAC,QAAQ,EAAE;gBACjC,SAAS,EAAE,MAAM,CAAC,QAAQ,EAAE;gBAC5B,gBAAgB,EAAE,KAAK;gBACvB,aAAa,EAAE,MAAM,CAAC,QAAQ,EAAE;gBAChC,iBAAiB,EAAE,OAAO,CAAC,OAAO,CAAC,gBAAgB,EAAE;gBACrD,MAAM,EAAE,MAAM,CAAC,QAAQ,EAAE;gBACzB,OAAO,EAAE,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC;gBACtC,SAAS,EAAE,MAAM,CAAC,QAAQ,EAAE;aAC7B,CAAC;YACF,WAAW,EAAE;gBACX,EAAE,EAAE,MAAM,CAAC,QAAQ,EAAE;gBACrB,EAAE,EAAE;oBACF,QAAQ,EAAE,MAAM,CAAC,QAAQ,EAAE;oBAC3B,OAAO,EAAE,MAAM,CAAC,QAAQ,EAAE;iBAC3B;gBACD,WAAW,EAAE,MAAM,CAAC,QAAQ,EAAE;aAC/B;YACD,OAAO,EAAE,EAAE;YACX,QAAQ,EAAE;gBACR,KAAK,EAAE,MAAM,CAAC,QAAQ,EAAE;aACzB;SACF,CAAC;KACH,CAAC,CAAC;IACH,EAAE,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;AAC/B,CAAC,CAAC,CACH,CAAC","sourcesContent":["import * as path from 'path';\nimport * as fs from 'fs-extra';\nimport { integTest, withDefaultFixture } from '../../../lib';\n\njest.setTimeout(2 * 60 * 60_000); // Includes the time to acquire locks, worst-case single-threaded runtime\n\nintegTest(\n  'cdk synth with telemetry data',\n  withDefaultFixture(async (fixture) => {\n    const telemetryFile = path.join(fixture.integTestDir, `telemetry-${Date.now()}.json`);\n    await fixture.cdk(['synth', fixture.fullStackName('test-1'), '--unstable=telemetry', `--telemetry-file=${telemetryFile}`]);\n    const json = fs.readJSONSync(telemetryFile);\n    expect(json).toEqual([\n      expect.objectContaining({\n        event: expect.objectContaining({\n          command: expect.objectContaining({\n            path: ['synth', '$STACKS_1'],\n            parameters: {\n              verbose: 1,\n              unstable: '<redacted>',\n              ['telemetry-file']: '<redacted>',\n              lookups: true,\n              ['ignore-errors']: false,\n              json: false,\n              debug: false,\n              staging: true,\n              ['no-color']: false,\n              ci: expect.anything(), // changes based on where this is called\n              validation: true,\n              quiet: false,\n            },\n            config: {\n              context: {},\n            },\n          }),\n          state: 'SUCCEEDED',\n          eventType: 'SYNTH',\n        }),\n        // some of these can change; but we assert that some value is recorded\n        identifiers: expect.objectContaining({\n          installationId: expect.anything(),\n          sessionId: expect.anything(),\n          telemetryVersion: '1.0',\n          cdkCliVersion: expect.anything(),\n          cdkLibraryVersion: fixture.library.requestedVersion(),\n          region: expect.anything(),\n          eventId: expect.stringContaining(':1'),\n          timestamp: expect.anything(),\n        }),\n        environment: {\n          ci: expect.anything(),\n          os: {\n            platform: expect.anything(),\n            release: expect.anything(),\n          },\n          nodeVersion: expect.anything(),\n        },\n        project: {},\n        duration: {\n          total: expect.anything(),\n        },\n      }),\n      expect.objectContaining({\n        event: expect.objectContaining({\n          command: expect.objectContaining({\n            path: ['synth', '$STACKS_1'],\n            parameters: {\n              verbose: 1,\n              unstable: '<redacted>',\n              ['telemetry-file']: '<redacted>',\n              lookups: true,\n              ['ignore-errors']: false,\n              json: false,\n              debug: false,\n              staging: true,\n              ['no-color']: false,\n              ci: expect.anything(), // changes based on where this is called\n              validation: true,\n              quiet: false,\n            },\n            config: {\n              context: {},\n            },\n          }),\n          state: 'SUCCEEDED',\n          eventType: 'INVOKE',\n        }),\n        identifiers: expect.objectContaining({\n          installationId: expect.anything(),\n          sessionId: expect.anything(),\n          telemetryVersion: '1.0',\n          cdkCliVersion: expect.anything(),\n          cdkLibraryVersion: fixture.library.requestedVersion(),\n          region: expect.anything(),\n          eventId: expect.stringContaining(':2'),\n          timestamp: expect.anything(),\n        }),\n        environment: {\n          ci: expect.anything(),\n          os: {\n            platform: expect.anything(),\n            release: expect.anything(),\n          },\n          nodeVersion: expect.anything(),\n        },\n        project: {},\n        duration: {\n          total: expect.anything(),\n        },\n      }),\n    ]);\n    fs.unlinkSync(telemetryFile);\n  }),\n);\n"]}