@aws-cdk-testing/cli-integ 3.13.0 → 3.14.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/lib/aws.d.ts +16 -3
  2. package/lib/aws.js +92 -6
  3. package/lib/cli/run-suite.js +40 -4
  4. package/lib/corking.d.ts +1 -1
  5. package/lib/npm.js +2 -1
  6. package/lib/package-sources/cli-npm-source.d.ts +2 -1
  7. package/lib/package-sources/cli-npm-source.js +6 -4
  8. package/lib/package-sources/cli-repo-source.d.ts +3 -2
  9. package/lib/package-sources/cli-repo-source.js +5 -3
  10. package/lib/package-sources/subprocess.d.ts +1 -0
  11. package/lib/package-sources/subprocess.js +1 -1
  12. package/lib/shell.d.ts +1 -0
  13. package/lib/shell.js +5 -2
  14. package/lib/with-aws.js +27 -17
  15. package/lib/with-cdk-app.d.ts +2 -0
  16. package/lib/with-cdk-app.js +4 -1
  17. package/npm-shrinkwrap.json +1094 -889
  18. package/package.json +21 -20
  19. package/tests/cli-integ-tests/cdk-assets/asset_helpers.d.ts +12 -0
  20. package/tests/cli-integ-tests/cdk-assets/asset_helpers.js +45 -0
  21. package/tests/cli-integ-tests/cdk-assets/cdk-assets-can-read-lib-output.integtest.d.ts +1 -0
  22. package/tests/cli-integ-tests/cdk-assets/cdk-assets-can-read-lib-output.integtest.js +13 -0
  23. package/tests/cli-integ-tests/cdk-assets/cdk-assets-docker-credential.integtest.js +64 -11
  24. package/tests/cli-integ-tests/cdk-assets/cdk-assets-uses-profile.integtest.js +3 -4
  25. package/tests/cli-integ-tests/cdk-assets/smoketest.integtest.js +10 -25
  26. package/tests/cli-integ-tests/cli-telemetry/cdk-cli-telemetry-adds-context-value.integtest.js +2 -2
  27. package/tests/cli-integ-tests/cli-telemetry/cdk-cli-telemetry-reports-status.integtest.d.ts +1 -0
  28. package/tests/cli-integ-tests/cli-telemetry/cdk-cli-telemetry-reports-status.integtest.js +22 -0
  29. package/tests/cli-integ-tests/cli-telemetry/cdk-cli-telemetry-send-to-file-unstable.integtest.d.ts +1 -0
  30. package/tests/cli-integ-tests/cli-telemetry/cdk-cli-telemetry-send-to-file-unstable.integtest.js +18 -0
  31. package/tests/cli-integ-tests/deploy/cdk-deploy-telemetry.integtest.d.ts +1 -0
  32. package/tests/cli-integ-tests/deploy/cdk-deploy-telemetry.integtest.js +54 -0
  33. package/tests/cli-integ-tests/synth/cdk-synth-telemetry-with-errors.integtest.d.ts +1 -0
  34. package/tests/cli-integ-tests/synth/cdk-synth-telemetry-with-errors.integtest.js +122 -0
  35. package/tests/cli-integ-tests/synth/cdk-synth-telemetry.integtest.d.ts +1 -0
  36. package/tests/cli-integ-tests/synth/cdk-synth-telemetry.integtest.js +114 -0
@@ -0,0 +1,122 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const path = require("path");
4
+ const fs = require("fs-extra");
5
+ const lib_1 = require("../../../lib");
6
+ jest.setTimeout(2 * 60 * 60_000); // Includes the time to acquire locks, worst-case single-threaded runtime
7
+ (0, lib_1.integTest)('cdk synth with telemetry and validation error leads to invoke failure', (0, lib_1.withDefaultFixture)(async (fixture) => {
8
+ const telemetryFile = path.join(fixture.integTestDir, `telemetry-${Date.now()}.json`);
9
+ const output = await fixture.cdk(['synth', '--unstable=telemetry', `--telemetry-file=${telemetryFile}`], {
10
+ allowErrExit: true,
11
+ modEnv: {
12
+ INTEG_STACK_SET: 'stage-with-errors',
13
+ },
14
+ });
15
+ expect(output).toContain('This is an error');
16
+ const json = fs.readJSONSync(telemetryFile);
17
+ expect(json).toEqual([
18
+ expect.objectContaining({
19
+ event: expect.objectContaining({
20
+ command: expect.objectContaining({
21
+ path: ['synth'],
22
+ parameters: {
23
+ verbose: 1,
24
+ unstable: '<redacted>',
25
+ ['telemetry-file']: '<redacted>',
26
+ lookups: true,
27
+ ['ignore-errors']: false,
28
+ json: false,
29
+ debug: false,
30
+ staging: true,
31
+ notices: true,
32
+ ['no-color']: false,
33
+ ci: expect.anything(), // changes based on where this is called
34
+ validation: true,
35
+ quiet: false,
36
+ },
37
+ config: {
38
+ context: {},
39
+ },
40
+ }),
41
+ state: 'SUCCEEDED',
42
+ eventType: 'SYNTH',
43
+ }),
44
+ identifiers: expect.objectContaining({
45
+ installationId: expect.anything(),
46
+ sessionId: expect.anything(),
47
+ telemetryVersion: '1.0',
48
+ cdkCliVersion: expect.anything(),
49
+ cdkLibraryVersion: fixture.library.requestedVersion(),
50
+ region: expect.anything(),
51
+ eventId: expect.stringContaining(':1'),
52
+ timestamp: expect.anything(),
53
+ }),
54
+ environment: {
55
+ ci: expect.anything(),
56
+ os: {
57
+ platform: expect.anything(),
58
+ release: expect.anything(),
59
+ },
60
+ nodeVersion: expect.anything(),
61
+ },
62
+ project: {},
63
+ duration: {
64
+ total: expect.anything(),
65
+ },
66
+ }),
67
+ expect.objectContaining({
68
+ event: expect.objectContaining({
69
+ command: expect.objectContaining({
70
+ path: ['synth'],
71
+ parameters: {
72
+ verbose: 1,
73
+ unstable: '<redacted>',
74
+ ['telemetry-file']: '<redacted>',
75
+ lookups: true,
76
+ ['ignore-errors']: false,
77
+ json: false,
78
+ debug: false,
79
+ staging: true,
80
+ notices: true,
81
+ ['no-color']: false,
82
+ ci: expect.anything(), // changes based on where this is called
83
+ validation: true,
84
+ quiet: false,
85
+ },
86
+ config: {
87
+ context: {},
88
+ },
89
+ }),
90
+ state: 'FAILED',
91
+ eventType: 'INVOKE',
92
+ }),
93
+ identifiers: expect.objectContaining({
94
+ installationId: expect.anything(),
95
+ sessionId: expect.anything(),
96
+ telemetryVersion: '1.0',
97
+ cdkCliVersion: expect.anything(),
98
+ cdkLibraryVersion: fixture.library.requestedVersion(),
99
+ region: expect.anything(),
100
+ eventId: expect.stringContaining(':2'),
101
+ timestamp: expect.anything(),
102
+ }),
103
+ environment: {
104
+ ci: expect.anything(),
105
+ os: {
106
+ platform: expect.anything(),
107
+ release: expect.anything(),
108
+ },
109
+ nodeVersion: expect.anything(),
110
+ },
111
+ project: {},
112
+ duration: {
113
+ total: expect.anything(),
114
+ },
115
+ error: {
116
+ name: 'AssemblyError',
117
+ },
118
+ }),
119
+ ]);
120
+ fs.unlinkSync(telemetryFile);
121
+ }));
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"]}
@@ -0,0 +1,114 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const path = require("path");
4
+ const fs = require("fs-extra");
5
+ const lib_1 = require("../../../lib");
6
+ jest.setTimeout(2 * 60 * 60_000); // Includes the time to acquire locks, worst-case single-threaded runtime
7
+ (0, lib_1.integTest)('cdk synth with telemetry data', (0, lib_1.withDefaultFixture)(async (fixture) => {
8
+ const telemetryFile = path.join(fixture.integTestDir, `telemetry-${Date.now()}.json`);
9
+ await fixture.cdk(['synth', fixture.fullStackName('test-1'), '--unstable=telemetry', `--telemetry-file=${telemetryFile}`]);
10
+ const json = fs.readJSONSync(telemetryFile);
11
+ expect(json).toEqual([
12
+ expect.objectContaining({
13
+ event: expect.objectContaining({
14
+ command: expect.objectContaining({
15
+ path: ['synth', '$STACKS_1'],
16
+ parameters: {
17
+ verbose: 1,
18
+ unstable: '<redacted>',
19
+ ['telemetry-file']: '<redacted>',
20
+ lookups: true,
21
+ ['ignore-errors']: false,
22
+ json: false,
23
+ debug: false,
24
+ staging: true,
25
+ notices: true,
26
+ ['no-color']: false,
27
+ ci: expect.anything(), // changes based on where this is called
28
+ validation: true,
29
+ quiet: false,
30
+ },
31
+ config: {
32
+ context: {},
33
+ },
34
+ }),
35
+ state: 'SUCCEEDED',
36
+ eventType: 'SYNTH',
37
+ }),
38
+ // some of these can change; but we assert that some value is recorded
39
+ identifiers: expect.objectContaining({
40
+ installationId: expect.anything(),
41
+ sessionId: expect.anything(),
42
+ telemetryVersion: '1.0',
43
+ cdkCliVersion: expect.anything(),
44
+ cdkLibraryVersion: fixture.library.requestedVersion(),
45
+ region: expect.anything(),
46
+ eventId: expect.stringContaining(':1'),
47
+ timestamp: expect.anything(),
48
+ }),
49
+ environment: {
50
+ ci: expect.anything(),
51
+ os: {
52
+ platform: expect.anything(),
53
+ release: expect.anything(),
54
+ },
55
+ nodeVersion: expect.anything(),
56
+ },
57
+ project: {},
58
+ duration: {
59
+ total: expect.anything(),
60
+ },
61
+ }),
62
+ expect.objectContaining({
63
+ event: expect.objectContaining({
64
+ command: expect.objectContaining({
65
+ path: ['synth', '$STACKS_1'],
66
+ parameters: {
67
+ verbose: 1,
68
+ unstable: '<redacted>',
69
+ ['telemetry-file']: '<redacted>',
70
+ lookups: true,
71
+ ['ignore-errors']: false,
72
+ json: false,
73
+ debug: false,
74
+ staging: true,
75
+ notices: true,
76
+ ['no-color']: false,
77
+ ci: expect.anything(), // changes based on where this is called
78
+ validation: true,
79
+ quiet: false,
80
+ },
81
+ config: {
82
+ context: {},
83
+ },
84
+ }),
85
+ state: 'SUCCEEDED',
86
+ eventType: 'INVOKE',
87
+ }),
88
+ identifiers: expect.objectContaining({
89
+ installationId: expect.anything(),
90
+ sessionId: expect.anything(),
91
+ telemetryVersion: '1.0',
92
+ cdkCliVersion: expect.anything(),
93
+ cdkLibraryVersion: fixture.library.requestedVersion(),
94
+ region: expect.anything(),
95
+ eventId: expect.stringContaining(':2'),
96
+ timestamp: expect.anything(),
97
+ }),
98
+ environment: {
99
+ ci: expect.anything(),
100
+ os: {
101
+ platform: expect.anything(),
102
+ release: expect.anything(),
103
+ },
104
+ nodeVersion: expect.anything(),
105
+ },
106
+ project: {},
107
+ duration: {
108
+ total: expect.anything(),
109
+ },
110
+ }),
111
+ ]);
112
+ fs.unlinkSync(telemetryFile);
113
+ }));
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"]}