@aws-cdk-testing/cli-integ 2.61.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 (165) hide show
  1. package/LICENSE +201 -0
  2. package/NOTICE +16 -0
  3. package/README.md +151 -0
  4. package/bin/apply-patches +19 -0
  5. package/bin/download-and-run-old-tests +52 -0
  6. package/bin/query-github +2 -0
  7. package/bin/query-github.d.ts +1 -0
  8. package/bin/query-github.js +55 -0
  9. package/bin/run-suite +2 -0
  10. package/bin/run-suite.d.ts +1 -0
  11. package/bin/run-suite.js +126 -0
  12. package/bin/stage-distribution +2 -0
  13. package/bin/stage-distribution.d.ts +1 -0
  14. package/bin/stage-distribution.js +209 -0
  15. package/bin/test-root +2 -0
  16. package/bin/test-root.d.ts +1 -0
  17. package/bin/test-root.js +6 -0
  18. package/entrypoints/test-cli-regression-against-current-code.sh +11 -0
  19. package/entrypoints/test-cli-regression-against-latest-release.sh +11 -0
  20. package/entrypoints/test-cli-regression.bash +83 -0
  21. package/entrypoints/test.sh +12 -0
  22. package/lib/aws.d.ts +55 -0
  23. package/lib/aws.js +243 -0
  24. package/lib/corking.d.ts +13 -0
  25. package/lib/corking.js +34 -0
  26. package/lib/files.d.ts +15 -0
  27. package/lib/files.js +80 -0
  28. package/lib/github.d.ts +4 -0
  29. package/lib/github.js +43 -0
  30. package/lib/index.d.ts +12 -0
  31. package/lib/index.js +25 -0
  32. package/lib/integ-test.d.ts +11 -0
  33. package/lib/integ-test.js +55 -0
  34. package/lib/lists.d.ts +1 -0
  35. package/lib/lists.js +12 -0
  36. package/lib/memoize.d.ts +6 -0
  37. package/lib/memoize.js +19 -0
  38. package/lib/npm.d.ts +4 -0
  39. package/lib/npm.js +15 -0
  40. package/lib/package-sources/release-source.d.ts +22 -0
  41. package/lib/package-sources/release-source.js +67 -0
  42. package/lib/package-sources/repo-source.d.ts +23 -0
  43. package/lib/package-sources/repo-source.js +92 -0
  44. package/lib/package-sources/repo-tools/npm +2 -0
  45. package/lib/package-sources/repo-tools/npm.d.ts +1 -0
  46. package/lib/package-sources/repo-tools/npm.js +42 -0
  47. package/lib/package-sources/source.d.ts +24 -0
  48. package/lib/package-sources/source.js +3 -0
  49. package/lib/package-sources/subprocess.d.ts +3 -0
  50. package/lib/package-sources/subprocess.js +18 -0
  51. package/lib/resource-pool.d.ts +54 -0
  52. package/lib/resource-pool.js +120 -0
  53. package/lib/resources.d.ts +1 -0
  54. package/lib/resources.js +6 -0
  55. package/lib/shell.d.ts +59 -0
  56. package/lib/shell.js +118 -0
  57. package/lib/staging/codeartifact.d.ts +44 -0
  58. package/lib/staging/codeartifact.js +258 -0
  59. package/lib/staging/maven.d.ts +5 -0
  60. package/lib/staging/maven.js +83 -0
  61. package/lib/staging/npm.d.ts +4 -0
  62. package/lib/staging/npm.js +56 -0
  63. package/lib/staging/nuget.d.ts +4 -0
  64. package/lib/staging/nuget.js +71 -0
  65. package/lib/staging/parallel-shell.d.ts +6 -0
  66. package/lib/staging/parallel-shell.js +46 -0
  67. package/lib/staging/pypi.d.ts +4 -0
  68. package/lib/staging/pypi.js +49 -0
  69. package/lib/staging/usage-dir.d.ts +31 -0
  70. package/lib/staging/usage-dir.js +87 -0
  71. package/lib/with-aws.d.ts +13 -0
  72. package/lib/with-aws.js +60 -0
  73. package/lib/with-cdk-app.d.ts +146 -0
  74. package/lib/with-cdk-app.js +398 -0
  75. package/lib/with-packages.d.ts +5 -0
  76. package/lib/with-packages.js +14 -0
  77. package/lib/with-sam.d.ts +33 -0
  78. package/lib/with-sam.js +240 -0
  79. package/lib/with-temporary-directory.d.ts +5 -0
  80. package/lib/with-temporary-directory.js +32 -0
  81. package/lib/xpmutex.d.ts +43 -0
  82. package/lib/xpmutex.js +207 -0
  83. package/package.json +73 -0
  84. package/resources/cdk-apps/app/app.js +463 -0
  85. package/resources/cdk-apps/app/cdk.json +7 -0
  86. package/resources/cdk-apps/app/docker/Dockerfile +2 -0
  87. package/resources/cdk-apps/app/docker/Dockerfile.Custom +2 -0
  88. package/resources/cdk-apps/app/lambda/index.js +4 -0
  89. package/resources/cdk-apps/app/lambda/response.json +3 -0
  90. package/resources/cdk-apps/app/nested-stack.js +49 -0
  91. package/resources/cdk-apps/cfn-include-app/.gitignore +1 -0
  92. package/resources/cdk-apps/cfn-include-app/cdk.json +4 -0
  93. package/resources/cdk-apps/cfn-include-app/cfn-include-app.js +21 -0
  94. package/resources/cdk-apps/cfn-include-app/example-template.json +13 -0
  95. package/resources/cdk-apps/sam_cdk_integ_app/bin/test-app.js +11 -0
  96. package/resources/cdk-apps/sam_cdk_integ_app/cdk.json +6 -0
  97. package/resources/cdk-apps/sam_cdk_integ_app/lib/nested-stack.js +19 -0
  98. package/resources/cdk-apps/sam_cdk_integ_app/lib/test-stack.js +134 -0
  99. package/resources/cdk-apps/sam_cdk_integ_app/src/docker/DockerImageFunctionConstruct/.no-packagejson-validator +0 -0
  100. package/resources/cdk-apps/sam_cdk_integ_app/src/docker/DockerImageFunctionConstruct/Dockerfile +9 -0
  101. package/resources/cdk-apps/sam_cdk_integ_app/src/docker/DockerImageFunctionConstruct/app.js +22 -0
  102. package/resources/cdk-apps/sam_cdk_integ_app/src/docker/DockerImageFunctionConstruct/package.json +18 -0
  103. package/resources/cdk-apps/sam_cdk_integ_app/src/go/GoFunctionConstruct/go.mod +5 -0
  104. package/resources/cdk-apps/sam_cdk_integ_app/src/go/GoFunctionConstruct/go.sum +17 -0
  105. package/resources/cdk-apps/sam_cdk_integ_app/src/go/GoFunctionConstruct/main.go +17 -0
  106. package/resources/cdk-apps/sam_cdk_integ_app/src/nodejs/NodeJsFunctionConstruct/.no-packagejson-validator +0 -0
  107. package/resources/cdk-apps/sam_cdk_integ_app/src/nodejs/NodeJsFunctionConstruct/app.ts +16 -0
  108. package/resources/cdk-apps/sam_cdk_integ_app/src/nodejs/NodeJsFunctionConstruct/package-lock.json +12 -0
  109. package/resources/cdk-apps/sam_cdk_integ_app/src/nodejs/NodeJsFunctionConstruct/package.json +5 -0
  110. package/resources/cdk-apps/sam_cdk_integ_app/src/python/Function/app.py +15 -0
  111. package/resources/cdk-apps/sam_cdk_integ_app/src/python/Function/requirements.txt +1 -0
  112. package/resources/cdk-apps/sam_cdk_integ_app/src/python/Layer/layer_version_dependency.py +5 -0
  113. package/resources/cdk-apps/sam_cdk_integ_app/src/python/Layer/requirements.txt +1 -0
  114. package/resources/cdk-apps/sam_cdk_integ_app/src/rest-api-definition.yaml +12 -0
  115. package/resources/cli-regression-patches/v1.119.0/NOTES.md +5 -0
  116. package/resources/cli-regression-patches/v1.119.0/cli.integtest.js +659 -0
  117. package/resources/cli-regression-patches/v1.130.0/NOTES.md +12 -0
  118. package/resources/cli-regression-patches/v1.130.0/app/app.js +378 -0
  119. package/resources/cli-regression-patches/v1.130.0/bootstrapping.integtest.js +220 -0
  120. package/resources/cli-regression-patches/v1.44.0/NOTES.md +18 -0
  121. package/resources/cli-regression-patches/v1.44.0/bootstrapping.integtest.js +126 -0
  122. package/resources/cli-regression-patches/v1.44.0/test.sh +26 -0
  123. package/resources/cli-regression-patches/v1.61.1/NOTES.md +2 -0
  124. package/resources/cli-regression-patches/v1.61.1/skip-tests.txt +16 -0
  125. package/resources/cli-regression-patches/v1.62.0/NOTES.md +2 -0
  126. package/resources/cli-regression-patches/v1.62.0/aws-helpers.js +245 -0
  127. package/resources/cli-regression-patches/v1.63.0/NOTES.md +1 -0
  128. package/resources/cli-regression-patches/v1.63.0/skip-tests.txt +7 -0
  129. package/resources/cli-regression-patches/v1.64.0/NOTES.md +3 -0
  130. package/resources/cli-regression-patches/v1.64.0/cdk-helpers.js +325 -0
  131. package/resources/cli-regression-patches/v1.64.0/cli.integtest.js +599 -0
  132. package/resources/cli-regression-patches/v1.64.1/NOTES.md +3 -0
  133. package/resources/cli-regression-patches/v1.64.1/cdk-helpers.js +324 -0
  134. package/resources/cli-regression-patches/v1.64.1/cli.integtest.js +599 -0
  135. package/resources/cli-regression-patches/v1.67.0/NOTES.md +2 -0
  136. package/resources/cli-regression-patches/v1.67.0/cdk-helpers.js +331 -0
  137. package/resources/cloud-assemblies/0.36.0/InitStack.template.json +1 -0
  138. package/resources/cloud-assemblies/0.36.0/manifest.json +19 -0
  139. package/resources/cloud-assemblies/1.10.0-lookup-default-vpc/InitStack.template.json +2 -0
  140. package/resources/cloud-assemblies/1.10.0-lookup-default-vpc/manifest.json.js +37 -0
  141. package/resources/cloud-assemblies/1.10.0-request-azs/InitStack.template.json +2 -0
  142. package/resources/cloud-assemblies/1.10.0-request-azs/manifest.json.js +34 -0
  143. package/resources/integ.jest.config.js +25 -0
  144. package/skip-tests.txt +8 -0
  145. package/tests/cli-integ-tests/README.md +47 -0
  146. package/tests/cli-integ-tests/bootstrapping.integtest.d.ts +1 -0
  147. package/tests/cli-integ-tests/bootstrapping.integtest.js +271 -0
  148. package/tests/cli-integ-tests/cli.integtest.d.ts +1 -0
  149. package/tests/cli-integ-tests/cli.integtest.js +1029 -0
  150. package/tests/init-csharp/init-csharp.integtest.d.ts +1 -0
  151. package/tests/init-csharp/init-csharp.integtest.js +14 -0
  152. package/tests/init-fsharp/init-fsharp.integtest.d.ts +1 -0
  153. package/tests/init-fsharp/init-fsharp.integtest.js +14 -0
  154. package/tests/init-java/init-java.integtest.d.ts +1 -0
  155. package/tests/init-java/init-java.integtest.js +14 -0
  156. package/tests/init-javascript/init-javascript.integtest.d.ts +1 -0
  157. package/tests/init-javascript/init-javascript.integtest.js +15 -0
  158. package/tests/init-python/init-python.integtest.d.ts +1 -0
  159. package/tests/init-python/init-python.integtest.js +19 -0
  160. package/tests/init-typescript-app/init-typescript-app.integtest.d.ts +1 -0
  161. package/tests/init-typescript-app/init-typescript-app.integtest.js +49 -0
  162. package/tests/init-typescript-lib/init-typescript-lib.integtest.d.ts +1 -0
  163. package/tests/init-typescript-lib/init-typescript-lib.integtest.js +13 -0
  164. package/tests/uberpackage/uberpackage.integtest.d.ts +1 -0
  165. package/tests/uberpackage/uberpackage.integtest.js +11 -0
@@ -0,0 +1,12 @@
1
+ ---------------------------------------
2
+
3
+ On november 2nd 2021, lambda started deprecating the nodejs10.x runtime. This meant we can no longer create functions with this runtime.
4
+ Our integration tests use this runtime for one of its stacks.
5
+
6
+ This patch brings https://github.com/aws/aws-cdk/pull/17282 into the regression suite.
7
+
8
+ ----------------------------------------
9
+
10
+ Needs to disable an existing test due to change in bootstrap of integration tests.
11
+
12
+ This patch brings https://github.com/aws/aws-cdk/pull/17337 into the regression suite.
@@ -0,0 +1,378 @@
1
+ const path = require('path');
2
+
3
+ var constructs = require('constructs');
4
+ if (process.env.PACKAGE_LAYOUT_VERSION === '1') {
5
+ var cdk = require('@aws-cdk/core');
6
+ var ec2 = require('@aws-cdk/aws-ec2');
7
+ var ssm = require('@aws-cdk/aws-ssm');
8
+ var iam = require('@aws-cdk/aws-iam');
9
+ var sns = require('@aws-cdk/aws-sns');
10
+ var lambda = require('@aws-cdk/aws-lambda');
11
+ var docker = require('@aws-cdk/aws-ecr-assets');
12
+ } else {
13
+ var cdk = require('aws-cdk-lib');
14
+ var {
15
+ aws_ec2: ec2,
16
+ aws_ssm: ssm,
17
+ aws_iam: iam,
18
+ aws_sns: sns,
19
+ aws_lambda: lambda,
20
+ aws_ecr_assets: docker
21
+ } = require('aws-cdk-lib');
22
+ }
23
+
24
+ const { Annotations } = cdk;
25
+ const { StackWithNestedStack, StackWithNestedStackUsingParameters } = require('./nested-stack');
26
+
27
+ const stackPrefix = process.env.STACK_NAME_PREFIX;
28
+ if (!stackPrefix) {
29
+ throw new Error(`the STACK_NAME_PREFIX environment variable is required`);
30
+ }
31
+
32
+ class MyStack extends cdk.Stack {
33
+ constructor(parent, id, props) {
34
+ super(parent, id, props);
35
+ new sns.Topic(this, 'topic');
36
+
37
+ if (cdk.AvailabilityZoneProvider) { // <= 0.34.0
38
+ new cdk.AvailabilityZoneProvider(this).availabilityZones;
39
+ } else if (cdk.Context) { // <= 0.35.0
40
+ cdk.Context.getAvailabilityZones(this);
41
+ } else {
42
+ this.availabilityZones;
43
+ }
44
+
45
+ const parameterName = '/aws/service/ami-amazon-linux-latest/amzn2-ami-hvm-x86_64-gp2';
46
+ getSsmParameterValue(this, parameterName);
47
+ }
48
+ }
49
+
50
+ function getSsmParameterValue(scope, parameterName) {
51
+ return ssm.StringParameter.valueFromLookup(scope, parameterName);
52
+ }
53
+
54
+ class YourStack extends cdk.Stack {
55
+ constructor(parent, id, props) {
56
+ super(parent, id, props);
57
+ new sns.Topic(this, 'topic1');
58
+ new sns.Topic(this, 'topic2');
59
+ }
60
+ }
61
+
62
+ class StackUsingContext extends cdk.Stack {
63
+ constructor(parent, id, props) {
64
+ super(parent, id, props);
65
+ new cdk.CfnResource(this, 'Handle', {
66
+ type: 'AWS::CloudFormation::WaitConditionHandle'
67
+ });
68
+
69
+ new cdk.CfnOutput(this, 'Output', {
70
+ value: this.availabilityZones,
71
+ });
72
+ }
73
+ }
74
+
75
+ class ParameterStack extends cdk.Stack {
76
+ constructor(parent, id, props) {
77
+ super(parent, id, props);
78
+
79
+ new sns.Topic(this, 'TopicParameter', {
80
+ topicName: new cdk.CfnParameter(this, 'TopicNameParam').valueAsString
81
+ });
82
+ }
83
+ }
84
+
85
+ class OtherParameterStack extends cdk.Stack {
86
+ constructor(parent, id, props) {
87
+ super(parent, id, props);
88
+
89
+ new sns.Topic(this, 'TopicParameter', {
90
+ topicName: new cdk.CfnParameter(this, 'OtherTopicNameParam').valueAsString
91
+ });
92
+ }
93
+ }
94
+
95
+ class MultiParameterStack extends cdk.Stack {
96
+ constructor(parent, id, props) {
97
+ super(parent, id, props);
98
+
99
+ new sns.Topic(this, 'TopicParameter', {
100
+ displayName: new cdk.CfnParameter(this, 'DisplayNameParam').valueAsString
101
+ });
102
+ new sns.Topic(this, 'OtherTopicParameter', {
103
+ displayName: new cdk.CfnParameter(this, 'OtherDisplayNameParam').valueAsString
104
+ });
105
+ }
106
+ }
107
+
108
+ class OutputsStack extends cdk.Stack {
109
+ constructor(parent, id, props) {
110
+ super(parent, id, props);
111
+
112
+ const topic = new sns.Topic(this, 'MyOutput', {
113
+ topicName: `${cdk.Stack.of(this).stackName}MyTopic`
114
+ });
115
+
116
+ new cdk.CfnOutput(this, 'TopicName', {
117
+ value: topic.topicName
118
+ })
119
+ }
120
+ }
121
+
122
+ class AnotherOutputsStack extends cdk.Stack {
123
+ constructor(parent, id, props) {
124
+ super(parent, id, props);
125
+
126
+ const topic = new sns.Topic(this, 'MyOtherOutput', {
127
+ topicName: `${cdk.Stack.of(this).stackName}MyOtherTopic`
128
+ });
129
+
130
+ new cdk.CfnOutput(this, 'TopicName', {
131
+ value: topic.topicName
132
+ });
133
+ }
134
+ }
135
+
136
+ class IamStack extends cdk.Stack {
137
+ constructor(parent, id, props) {
138
+ super(parent, id, props);
139
+
140
+ new iam.Role(this, 'SomeRole', {
141
+ assumedBy: new iam.ServicePrincipal('ec2.amazonaws.com')
142
+ });
143
+ }
144
+ }
145
+
146
+ class ProvidingStack extends cdk.Stack {
147
+ constructor(parent, id, props) {
148
+ super(parent, id, props);
149
+
150
+ this.topic = new sns.Topic(this, 'BogusTopic'); // Some filler
151
+ }
152
+ }
153
+
154
+ class StackWithError extends cdk.Stack {
155
+ constructor(parent, id, props) {
156
+ super(parent, id, props);
157
+
158
+ this.topic = new sns.Topic(this, 'BogusTopic'); // Some filler
159
+ Annotations.of(this).addError('This is an error');
160
+ }
161
+ }
162
+
163
+ class StageWithError extends cdk.Stage {
164
+ constructor(parent, id, props) {
165
+ super(parent, id, props);
166
+
167
+ new StackWithError(this, 'Stack');
168
+ }
169
+ }
170
+
171
+ class ConsumingStack extends cdk.Stack {
172
+ constructor(parent, id, props) {
173
+ super(parent, id, props);
174
+
175
+ new sns.Topic(this, 'BogusTopic'); // Some filler
176
+ new cdk.CfnOutput(this, 'IConsumedSomething', { value: props.providingStack.topic.topicArn });
177
+ }
178
+ }
179
+
180
+ class MissingSSMParameterStack extends cdk.Stack {
181
+ constructor(parent, id, props) {
182
+ super(parent, id, props);
183
+
184
+ const parameterName = constructs.Node.of(this).tryGetContext('test:ssm-parameter-name');
185
+ if (parameterName) {
186
+ const param = getSsmParameterValue(this, parameterName);
187
+ new iam.Role(this, 'PhonyRole', { assumedBy: new iam.AccountPrincipal(param) });
188
+ }
189
+ }
190
+ }
191
+
192
+ class LambdaStack extends cdk.Stack {
193
+ constructor(parent, id, props) {
194
+ super(parent, id, props);
195
+
196
+ const fn = new lambda.Function(this, 'my-function', {
197
+ code: lambda.Code.asset(path.join(__dirname, 'lambda')),
198
+ runtime: lambda.Runtime.NODEJS_12_X,
199
+ handler: 'index.handler'
200
+ });
201
+
202
+ new cdk.CfnOutput(this, 'FunctionArn', { value: fn.functionArn });
203
+ }
204
+ }
205
+
206
+ class DockerStack extends cdk.Stack {
207
+ constructor(parent, id, props) {
208
+ super(parent, id, props);
209
+
210
+ new docker.DockerImageAsset(this, 'image', {
211
+ directory: path.join(__dirname, 'docker')
212
+ });
213
+
214
+ // Add at least a single resource (WaitConditionHandle), otherwise this stack will never
215
+ // be deployed (and its assets never built)
216
+ new cdk.CfnResource(this, 'Handle', {
217
+ type: 'AWS::CloudFormation::WaitConditionHandle'
218
+ });
219
+ }
220
+ }
221
+
222
+ class DockerStackWithCustomFile extends cdk.Stack {
223
+ constructor(parent, id, props) {
224
+ super(parent, id, props);
225
+
226
+ new docker.DockerImageAsset(this, 'image', {
227
+ directory: path.join(__dirname, 'docker'),
228
+ file: 'Dockerfile.Custom'
229
+ });
230
+
231
+ // Add at least a single resource (WaitConditionHandle), otherwise this stack will never
232
+ // be deployed (and its assets never built)
233
+ new cdk.CfnResource(this, 'Handle', {
234
+ type: 'AWS::CloudFormation::WaitConditionHandle'
235
+ });
236
+ }
237
+ }
238
+
239
+ class FailedStack extends cdk.Stack {
240
+
241
+ constructor(parent, id, props) {
242
+ super(parent, id, props);
243
+
244
+ // fails on 'Property PolicyDocument cannot be empty'.
245
+ new cdk.CfnResource(this, 'EmptyPolicy', {
246
+ type: 'AWS::IAM::Policy'
247
+ })
248
+
249
+ }
250
+
251
+ }
252
+
253
+ const VPC_TAG_NAME = 'custom-tag';
254
+ const VPC_TAG_VALUE = `${stackPrefix}-bazinga!`;
255
+
256
+ class DefineVpcStack extends cdk.Stack {
257
+ constructor(parent, id, props) {
258
+ super(parent, id, props);
259
+
260
+ const vpc = new ec2.Vpc(this, 'VPC', {
261
+ maxAzs: 1,
262
+ })
263
+ cdk.Aspects.of(vpc).add(new cdk.Tag(VPC_TAG_NAME, VPC_TAG_VALUE));
264
+ }
265
+ }
266
+
267
+ class ImportVpcStack extends cdk.Stack {
268
+ constructor(parent, id, props) {
269
+ super(parent, id, props);
270
+
271
+ ec2.Vpc.fromLookup(this, 'DefaultVPC', { isDefault: true });
272
+ ec2.Vpc.fromLookup(this, 'ByTag', { tags: { [VPC_TAG_NAME]: VPC_TAG_VALUE } });
273
+ }
274
+ }
275
+
276
+ class ConditionalResourceStack extends cdk.Stack {
277
+ constructor(parent, id, props) {
278
+ super(parent, id, props);
279
+
280
+ if (!process.env.NO_RESOURCE) {
281
+ new iam.User(this, 'User');
282
+ }
283
+ }
284
+ }
285
+
286
+ class SomeStage extends cdk.Stage {
287
+ constructor(parent, id, props) {
288
+ super(parent, id, props);
289
+
290
+ new YourStack(this, 'StackInStage');
291
+ }
292
+ }
293
+
294
+ class StageUsingContext extends cdk.Stage {
295
+ constructor(parent, id, props) {
296
+ super(parent, id, props);
297
+
298
+ new StackUsingContext(this, 'StackInStage');
299
+ }
300
+ }
301
+
302
+ const app = new cdk.App();
303
+
304
+ const defaultEnv = {
305
+ account: process.env.CDK_DEFAULT_ACCOUNT,
306
+ region: process.env.CDK_DEFAULT_REGION
307
+ };
308
+
309
+ // Sometimes we don't want to synthesize all stacks because it will impact the results
310
+ const stackSet = process.env.INTEG_STACK_SET || 'default';
311
+
312
+ switch (stackSet) {
313
+ case 'default':
314
+ // Deploy all does a wildcard ${stackPrefix}-test-*
315
+ new MyStack(app, `${stackPrefix}-test-1`, { env: defaultEnv });
316
+ new YourStack(app, `${stackPrefix}-test-2`);
317
+ // Deploy wildcard with parameters does ${stackPrefix}-param-test-*
318
+ new ParameterStack(app, `${stackPrefix}-param-test-1`);
319
+ new OtherParameterStack(app, `${stackPrefix}-param-test-2`);
320
+ // Deploy stack with multiple parameters
321
+ new MultiParameterStack(app, `${stackPrefix}-param-test-3`);
322
+ // Deploy stack with outputs does ${stackPrefix}-outputs-test-*
323
+ new OutputsStack(app, `${stackPrefix}-outputs-test-1`);
324
+ new AnotherOutputsStack(app, `${stackPrefix}-outputs-test-2`);
325
+ // Not included in wildcard
326
+ new IamStack(app, `${stackPrefix}-iam-test`, { env: defaultEnv });
327
+ const providing = new ProvidingStack(app, `${stackPrefix}-order-providing`);
328
+ new ConsumingStack(app, `${stackPrefix}-order-consuming`, { providingStack: providing });
329
+
330
+ new MissingSSMParameterStack(app, `${stackPrefix}-missing-ssm-parameter`, { env: defaultEnv });
331
+
332
+ new LambdaStack(app, `${stackPrefix}-lambda`);
333
+ new DockerStack(app, `${stackPrefix}-docker`);
334
+ new DockerStackWithCustomFile(app, `${stackPrefix}-docker-with-custom-file`);
335
+ new FailedStack(app, `${stackPrefix}-failed`)
336
+
337
+ if (process.env.ENABLE_VPC_TESTING) { // Gating so we don't do context fetching unless that's what we are here for
338
+ const env = { account: process.env.CDK_DEFAULT_ACCOUNT, region: process.env.CDK_DEFAULT_REGION };
339
+ if (process.env.ENABLE_VPC_TESTING === 'DEFINE')
340
+ new DefineVpcStack(app, `${stackPrefix}-define-vpc`, { env });
341
+ if (process.env.ENABLE_VPC_TESTING === 'IMPORT')
342
+ new ImportVpcStack(app, `${stackPrefix}-import-vpc`, { env });
343
+ }
344
+
345
+ new ConditionalResourceStack(app, `${stackPrefix}-conditional-resource`)
346
+
347
+ new StackWithNestedStack(app, `${stackPrefix}-with-nested-stack`);
348
+ new StackWithNestedStackUsingParameters(app, `${stackPrefix}-with-nested-stack-using-parameters`);
349
+
350
+ new YourStack(app, `${stackPrefix}-termination-protection`, {
351
+ terminationProtection: process.env.TERMINATION_PROTECTION !== 'FALSE' ? true : false,
352
+ });
353
+
354
+ new SomeStage(app, `${stackPrefix}-stage`);
355
+ break;
356
+
357
+ case 'stage-using-context':
358
+ // Cannot be combined with other test stacks, because we use this to test
359
+ // that stage context is propagated up and causes synth to fail when combined
360
+ // with '--no-lookups'.
361
+
362
+ // Needs a dummy stack at the top level because the CLI will fail otherwise
363
+ new YourStack(app, `${stackPrefix}-toplevel`, { env: defaultEnv });
364
+ new StageUsingContext(app, `${stackPrefix}-stage-using-context`, {
365
+ env: defaultEnv,
366
+ });
367
+ break;
368
+
369
+ case 'stage-with-errors':
370
+ const stage = new StageWithError(app, `${stackPrefix}-stage-with-errors`);
371
+ stage.synth({ validateOnSynthesis: true });
372
+ break;
373
+
374
+ default:
375
+ throw new Error(`Unrecognized INTEG_STACK_SET: '${stackSet}'`);
376
+ }
377
+
378
+ app.synth();
@@ -0,0 +1,220 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const fs = require("fs");
4
+ const path = require("path");
5
+ const cdk_1 = require("../helpers/cdk");
6
+ const test_helpers_1 = require("../helpers/test-helpers");
7
+ const timeout = process.env.CODEBUILD_BUILD_ID ? // if the process is running in CodeBuild
8
+ 3600000 : // 1 hour
9
+ 600000; // 10 minutes
10
+ jest.setTimeout(timeout);
11
+ process.stdout.write(`bootstrapping.integtest.ts: Setting jest time out to ${timeout} ms`);
12
+ test_helpers_1.integTest('can bootstrap without execution', cdk_1.withDefaultFixture(async (fixture) => {
13
+ var _a;
14
+ const bootstrapStackName = fixture.bootstrapStackName;
15
+ await fixture.cdkBootstrapLegacy({
16
+ toolkitStackName: bootstrapStackName,
17
+ noExecute: true,
18
+ });
19
+ const resp = await fixture.aws.cloudFormation('describeStacks', {
20
+ StackName: bootstrapStackName,
21
+ });
22
+ expect((_a = resp.Stacks) === null || _a === void 0 ? void 0 : _a[0].StackStatus).toEqual('REVIEW_IN_PROGRESS');
23
+ }));
24
+ test_helpers_1.integTest('upgrade legacy bootstrap stack to new bootstrap stack while in use', cdk_1.withDefaultFixture(async (fixture) => {
25
+ const bootstrapStackName = fixture.bootstrapStackName;
26
+ const legacyBootstrapBucketName = `aws-cdk-bootstrap-integ-test-legacy-bckt-${cdk_1.randomString()}`;
27
+ const newBootstrapBucketName = `aws-cdk-bootstrap-integ-test-v2-bckt-${cdk_1.randomString()}`;
28
+ fixture.rememberToDeleteBucket(legacyBootstrapBucketName); // This one will leak
29
+ fixture.rememberToDeleteBucket(newBootstrapBucketName); // This one shouldn't leak if the test succeeds, but let's be safe in case it doesn't
30
+ // Legacy bootstrap
31
+ await fixture.cdkBootstrapLegacy({
32
+ toolkitStackName: bootstrapStackName,
33
+ bootstrapBucketName: legacyBootstrapBucketName,
34
+ });
35
+ // Deploy stack that uses file assets
36
+ await fixture.cdkDeploy('lambda', {
37
+ options: ['--toolkit-stack-name', bootstrapStackName],
38
+ });
39
+ // Upgrade bootstrap stack to "new" style
40
+ await fixture.cdkBootstrapModern({
41
+ toolkitStackName: bootstrapStackName,
42
+ bootstrapBucketName: newBootstrapBucketName,
43
+ cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
44
+ });
45
+ // (Force) deploy stack again
46
+ // --force to bypass the check which says that the template hasn't changed.
47
+ await fixture.cdkDeploy('lambda', {
48
+ options: [
49
+ '--toolkit-stack-name', bootstrapStackName,
50
+ '--force',
51
+ ],
52
+ });
53
+ }));
54
+ test_helpers_1.integTest('can and deploy if omitting execution policies', cdk_1.withDefaultFixture(async (fixture) => {
55
+ const bootstrapStackName = fixture.bootstrapStackName;
56
+ await fixture.cdkBootstrapModern({
57
+ toolkitStackName: bootstrapStackName,
58
+ });
59
+ // Deploy stack that uses file assets
60
+ await fixture.cdkDeploy('lambda', {
61
+ options: [
62
+ '--toolkit-stack-name', bootstrapStackName,
63
+ '--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,
64
+ '--context', '@aws-cdk/core:newStyleStackSynthesis=1',
65
+ ],
66
+ });
67
+ }));
68
+ test_helpers_1.integTest('deploy new style synthesis to new style bootstrap', cdk_1.withDefaultFixture(async (fixture) => {
69
+ const bootstrapStackName = fixture.bootstrapStackName;
70
+ await fixture.cdkBootstrapModern({
71
+ toolkitStackName: bootstrapStackName,
72
+ cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
73
+ });
74
+ // Deploy stack that uses file assets
75
+ await fixture.cdkDeploy('lambda', {
76
+ options: [
77
+ '--toolkit-stack-name', bootstrapStackName,
78
+ '--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,
79
+ '--context', '@aws-cdk/core:newStyleStackSynthesis=1',
80
+ ],
81
+ });
82
+ }));
83
+ test_helpers_1.integTest('deploy new style synthesis to new style bootstrap (with docker image)', cdk_1.withDefaultFixture(async (fixture) => {
84
+ const bootstrapStackName = fixture.bootstrapStackName;
85
+ await fixture.cdkBootstrapModern({
86
+ toolkitStackName: bootstrapStackName,
87
+ cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
88
+ });
89
+ // Deploy stack that uses file assets
90
+ await fixture.cdkDeploy('docker', {
91
+ options: [
92
+ '--toolkit-stack-name', bootstrapStackName,
93
+ '--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,
94
+ '--context', '@aws-cdk/core:newStyleStackSynthesis=1',
95
+ ],
96
+ });
97
+ }));
98
+ test_helpers_1.integTest('deploy old style synthesis to new style bootstrap', cdk_1.withDefaultFixture(async (fixture) => {
99
+ const bootstrapStackName = fixture.bootstrapStackName;
100
+ await fixture.cdkBootstrapModern({
101
+ toolkitStackName: bootstrapStackName,
102
+ cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
103
+ });
104
+ // Deploy stack that uses file assets
105
+ await fixture.cdkDeploy('lambda', {
106
+ options: [
107
+ '--toolkit-stack-name', bootstrapStackName,
108
+ ],
109
+ });
110
+ }));
111
+ test_helpers_1.integTest('can create a legacy bootstrap stack with --public-access-block-configuration=false', cdk_1.withDefaultFixture(async (fixture) => {
112
+ var _a;
113
+ const bootstrapStackName = fixture.bootstrapStackName;
114
+ await fixture.cdkBootstrapLegacy({
115
+ verbose: true,
116
+ toolkitStackName: bootstrapStackName,
117
+ publicAccessBlockConfiguration: false,
118
+ tags: 'Foo=Bar',
119
+ });
120
+ const response = await fixture.aws.cloudFormation('describeStacks', { StackName: bootstrapStackName });
121
+ expect((_a = response.Stacks) === null || _a === void 0 ? void 0 : _a[0].Tags).toEqual([
122
+ { Key: 'Foo', Value: 'Bar' },
123
+ ]);
124
+ }));
125
+ test_helpers_1.integTest('can create multiple legacy bootstrap stacks', cdk_1.withDefaultFixture(async (fixture) => {
126
+ var _a;
127
+ const bootstrapStackName1 = `${fixture.bootstrapStackName}-1`;
128
+ const bootstrapStackName2 = `${fixture.bootstrapStackName}-2`;
129
+ // deploy two toolkit stacks into the same environment (see #1416)
130
+ // one with tags
131
+ await fixture.cdkBootstrapLegacy({
132
+ verbose: true,
133
+ toolkitStackName: bootstrapStackName1,
134
+ tags: 'Foo=Bar',
135
+ });
136
+ await fixture.cdkBootstrapLegacy({
137
+ verbose: true,
138
+ toolkitStackName: bootstrapStackName2,
139
+ });
140
+ const response = await fixture.aws.cloudFormation('describeStacks', { StackName: bootstrapStackName1 });
141
+ expect((_a = response.Stacks) === null || _a === void 0 ? void 0 : _a[0].Tags).toEqual([
142
+ { Key: 'Foo', Value: 'Bar' },
143
+ ]);
144
+ }));
145
+ test_helpers_1.integTest('can dump the template, modify and use it to deploy a custom bootstrap stack', cdk_1.withDefaultFixture(async (fixture) => {
146
+ let template = await fixture.cdkBootstrapModern({
147
+ // toolkitStackName doesn't matter for this particular invocation
148
+ toolkitStackName: fixture.bootstrapStackName,
149
+ showTemplate: true,
150
+ cliOptions: {
151
+ captureStderr: false,
152
+ },
153
+ });
154
+ expect(template).toContain('BootstrapVersion:');
155
+ template += '\n' + [
156
+ ' TwiddleDee:',
157
+ ' Value: Template got twiddled',
158
+ ].join('\n');
159
+ const filename = path.join(fixture.integTestDir, `${fixture.qualifier}-template.yaml`);
160
+ fs.writeFileSync(filename, template, { encoding: 'utf-8' });
161
+ await fixture.cdkBootstrapModern({
162
+ toolkitStackName: fixture.bootstrapStackName,
163
+ template: filename,
164
+ cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
165
+ });
166
+ }));
167
+ test_helpers_1.integTest('switch on termination protection, switch is left alone on re-bootstrap', cdk_1.withDefaultFixture(async (fixture) => {
168
+ var _a;
169
+ const bootstrapStackName = fixture.bootstrapStackName;
170
+ await fixture.cdkBootstrapModern({
171
+ verbose: true,
172
+ toolkitStackName: bootstrapStackName,
173
+ terminationProtection: true,
174
+ cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
175
+ });
176
+ await fixture.cdkBootstrapModern({
177
+ verbose: true,
178
+ toolkitStackName: bootstrapStackName,
179
+ force: true,
180
+ });
181
+ const response = await fixture.aws.cloudFormation('describeStacks', { StackName: bootstrapStackName });
182
+ expect((_a = response.Stacks) === null || _a === void 0 ? void 0 : _a[0].EnableTerminationProtection).toEqual(true);
183
+ }));
184
+ test_helpers_1.integTest('add tags, left alone on re-bootstrap', cdk_1.withDefaultFixture(async (fixture) => {
185
+ var _a;
186
+ const bootstrapStackName = fixture.bootstrapStackName;
187
+ await fixture.cdkBootstrapModern({
188
+ verbose: true,
189
+ toolkitStackName: bootstrapStackName,
190
+ tags: 'Foo=Bar',
191
+ cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
192
+ });
193
+ await fixture.cdkBootstrapModern({
194
+ verbose: true,
195
+ toolkitStackName: bootstrapStackName,
196
+ force: true,
197
+ });
198
+ const response = await fixture.aws.cloudFormation('describeStacks', { StackName: bootstrapStackName });
199
+ expect((_a = response.Stacks) === null || _a === void 0 ? void 0 : _a[0].Tags).toEqual([
200
+ { Key: 'Foo', Value: 'Bar' },
201
+ ]);
202
+ }));
203
+ test_helpers_1.integTest('can deploy modern-synthesized stack even if bootstrap stack name is unknown', cdk_1.withDefaultFixture(async (fixture) => {
204
+ const bootstrapStackName = fixture.bootstrapStackName;
205
+ await fixture.cdkBootstrapModern({
206
+ toolkitStackName: bootstrapStackName,
207
+ cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
208
+ });
209
+ // Deploy stack that uses file assets
210
+ await fixture.cdkDeploy('lambda', {
211
+ options: [
212
+ // Explicity pass a name that's sure to not exist, otherwise the CLI might accidentally find a
213
+ // default bootstracp stack if that happens to be in the account already.
214
+ '--toolkit-stack-name', 'DefinitelyDoesNotExist',
215
+ '--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,
216
+ '--context', '@aws-cdk/core:newStyleStackSynthesis=1',
217
+ ],
218
+ });
219
+ }));
220
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bootstrapping.integtest.js","sourceRoot":"","sources":["bootstrapping.integtest.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport { randomString, withDefaultFixture } from '../helpers/cdk';\nimport { integTest } from '../helpers/test-helpers';\n\nconst timeout = process.env.CODEBUILD_BUILD_ID ? // if the process is running in CodeBuild\n  3_600_000 : // 1 hour\n  600_000; // 10 minutes\njest.setTimeout(timeout);\nprocess.stdout.write(`bootstrapping.integtest.ts: Setting jest time out to ${timeout} ms`);\n\nintegTest('can bootstrap without execution', withDefaultFixture(async (fixture) => {\n  const bootstrapStackName = fixture.bootstrapStackName;\n\n  await fixture.cdkBootstrapLegacy({\n    toolkitStackName: bootstrapStackName,\n    noExecute: true,\n  });\n\n  const resp = await fixture.aws.cloudFormation('describeStacks', {\n    StackName: bootstrapStackName,\n  });\n\n  expect(resp.Stacks?.[0].StackStatus).toEqual('REVIEW_IN_PROGRESS');\n}));\n\nintegTest('upgrade legacy bootstrap stack to new bootstrap stack while in use', withDefaultFixture(async (fixture) => {\n  const bootstrapStackName = fixture.bootstrapStackName;\n\n  const legacyBootstrapBucketName = `aws-cdk-bootstrap-integ-test-legacy-bckt-${randomString()}`;\n  const newBootstrapBucketName = `aws-cdk-bootstrap-integ-test-v2-bckt-${randomString()}`;\n  fixture.rememberToDeleteBucket(legacyBootstrapBucketName); // This one will leak\n  fixture.rememberToDeleteBucket(newBootstrapBucketName); // This one shouldn't leak if the test succeeds, but let's be safe in case it doesn't\n\n  // Legacy bootstrap\n  await fixture.cdkBootstrapLegacy({\n    toolkitStackName: bootstrapStackName,\n    bootstrapBucketName: legacyBootstrapBucketName,\n  });\n\n  // Deploy stack that uses file assets\n  await fixture.cdkDeploy('lambda', {\n    options: ['--toolkit-stack-name', bootstrapStackName],\n  });\n\n  // Upgrade bootstrap stack to \"new\" style\n  await fixture.cdkBootstrapModern({\n    toolkitStackName: bootstrapStackName,\n    bootstrapBucketName: newBootstrapBucketName,\n    cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',\n  });\n\n  // (Force) deploy stack again\n  // --force to bypass the check which says that the template hasn't changed.\n  await fixture.cdkDeploy('lambda', {\n    options: [\n      '--toolkit-stack-name', bootstrapStackName,\n      '--force',\n    ],\n  });\n}));\n\nintegTest('can and deploy if omitting execution policies', withDefaultFixture(async (fixture) => {\n  const bootstrapStackName = fixture.bootstrapStackName;\n\n  await fixture.cdkBootstrapModern({\n    toolkitStackName: bootstrapStackName,\n  });\n\n  // Deploy stack that uses file assets\n  await fixture.cdkDeploy('lambda', {\n    options: [\n      '--toolkit-stack-name', bootstrapStackName,\n      '--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,\n      '--context', '@aws-cdk/core:newStyleStackSynthesis=1',\n    ],\n  });\n}));\n\nintegTest('deploy new style synthesis to new style bootstrap', withDefaultFixture(async (fixture) => {\n  const bootstrapStackName = fixture.bootstrapStackName;\n\n  await fixture.cdkBootstrapModern({\n    toolkitStackName: bootstrapStackName,\n    cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',\n  });\n\n  // Deploy stack that uses file assets\n  await fixture.cdkDeploy('lambda', {\n    options: [\n      '--toolkit-stack-name', bootstrapStackName,\n      '--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,\n      '--context', '@aws-cdk/core:newStyleStackSynthesis=1',\n    ],\n  });\n}));\n\nintegTest('deploy new style synthesis to new style bootstrap (with docker image)', withDefaultFixture(async (fixture) => {\n  const bootstrapStackName = fixture.bootstrapStackName;\n\n  await fixture.cdkBootstrapModern({\n    toolkitStackName: bootstrapStackName,\n    cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',\n  });\n\n  // Deploy stack that uses file assets\n  await fixture.cdkDeploy('docker', {\n    options: [\n      '--toolkit-stack-name', bootstrapStackName,\n      '--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,\n      '--context', '@aws-cdk/core:newStyleStackSynthesis=1',\n    ],\n  });\n}));\n\nintegTest('deploy old style synthesis to new style bootstrap', withDefaultFixture(async (fixture) => {\n  const bootstrapStackName = fixture.bootstrapStackName;\n\n  await fixture.cdkBootstrapModern({\n    toolkitStackName: bootstrapStackName,\n    cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',\n  });\n\n  // Deploy stack that uses file assets\n  await fixture.cdkDeploy('lambda', {\n    options: [\n      '--toolkit-stack-name', bootstrapStackName,\n    ],\n  });\n}));\n\nintegTest('can create a legacy bootstrap stack with --public-access-block-configuration=false', withDefaultFixture(async (fixture) => {\n  const bootstrapStackName = fixture.bootstrapStackName;\n\n  await fixture.cdkBootstrapLegacy({\n    verbose: true,\n    toolkitStackName: bootstrapStackName,\n    publicAccessBlockConfiguration: false,\n    tags: 'Foo=Bar',\n  });\n\n  const response = await fixture.aws.cloudFormation('describeStacks', { StackName: bootstrapStackName });\n  expect(response.Stacks?.[0].Tags).toEqual([\n    { Key: 'Foo', Value: 'Bar' },\n  ]);\n}));\n\nintegTest('can create multiple legacy bootstrap stacks', withDefaultFixture(async (fixture) => {\n  const bootstrapStackName1 = `${fixture.bootstrapStackName}-1`;\n  const bootstrapStackName2 = `${fixture.bootstrapStackName}-2`;\n\n  // deploy two toolkit stacks into the same environment (see #1416)\n  // one with tags\n  await fixture.cdkBootstrapLegacy({\n    verbose: true,\n    toolkitStackName: bootstrapStackName1,\n    tags: 'Foo=Bar',\n  });\n  await fixture.cdkBootstrapLegacy({\n    verbose: true,\n    toolkitStackName: bootstrapStackName2,\n  });\n\n  const response = await fixture.aws.cloudFormation('describeStacks', { StackName: bootstrapStackName1 });\n  expect(response.Stacks?.[0].Tags).toEqual([\n    { Key: 'Foo', Value: 'Bar' },\n  ]);\n}));\n\nintegTest('can dump the template, modify and use it to deploy a custom bootstrap stack', withDefaultFixture(async (fixture) => {\n  let template = await fixture.cdkBootstrapModern({\n    // toolkitStackName doesn't matter for this particular invocation\n    toolkitStackName: fixture.bootstrapStackName,\n    showTemplate: true,\n    cliOptions: {\n      captureStderr: false,\n    },\n  });\n\n  expect(template).toContain('BootstrapVersion:');\n\n  template += '\\n' + [\n    '  TwiddleDee:',\n    '    Value: Template got twiddled',\n  ].join('\\n');\n\n  const filename = path.join(fixture.integTestDir, `${fixture.qualifier}-template.yaml`);\n  fs.writeFileSync(filename, template, { encoding: 'utf-8' });\n  await fixture.cdkBootstrapModern({\n    toolkitStackName: fixture.bootstrapStackName,\n    template: filename,\n    cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',\n  });\n}));\n\nintegTest('switch on termination protection, switch is left alone on re-bootstrap', withDefaultFixture(async (fixture) => {\n  const bootstrapStackName = fixture.bootstrapStackName;\n\n  await fixture.cdkBootstrapModern({\n    verbose: true,\n    toolkitStackName: bootstrapStackName,\n    terminationProtection: true,\n    cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',\n  });\n  await fixture.cdkBootstrapModern({\n    verbose: true,\n    toolkitStackName: bootstrapStackName,\n    force: true,\n  });\n\n  const response = await fixture.aws.cloudFormation('describeStacks', { StackName: bootstrapStackName });\n  expect(response.Stacks?.[0].EnableTerminationProtection).toEqual(true);\n}));\n\nintegTest('add tags, left alone on re-bootstrap', withDefaultFixture(async (fixture) => {\n  const bootstrapStackName = fixture.bootstrapStackName;\n\n  await fixture.cdkBootstrapModern({\n    verbose: true,\n    toolkitStackName: bootstrapStackName,\n    tags: 'Foo=Bar',\n    cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',\n  });\n  await fixture.cdkBootstrapModern({\n    verbose: true,\n    toolkitStackName: bootstrapStackName,\n    force: true,\n  });\n\n  const response = await fixture.aws.cloudFormation('describeStacks', { StackName: bootstrapStackName });\n  expect(response.Stacks?.[0].Tags).toEqual([\n    { Key: 'Foo', Value: 'Bar' },\n  ]);\n}));\n\nintegTest('can deploy modern-synthesized stack even if bootstrap stack name is unknown', withDefaultFixture(async (fixture) => {\n  const bootstrapStackName = fixture.bootstrapStackName;\n\n  await fixture.cdkBootstrapModern({\n    toolkitStackName: bootstrapStackName,\n    cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',\n  });\n\n  // Deploy stack that uses file assets\n  await fixture.cdkDeploy('lambda', {\n    options: [\n      // Explicity pass a name that's sure to not exist, otherwise the CLI might accidentally find a\n      // default bootstracp stack if that happens to be in the account already.\n      '--toolkit-stack-name', 'DefinitelyDoesNotExist',\n      '--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,\n      '--context', '@aws-cdk/core:newStyleStackSynthesis=1',\n    ],\n  });\n}));\n"]}
@@ -0,0 +1,18 @@
1
+ Patch notes:
2
+
3
+ - Replace `test.sh` since we removed the old test exclusion
4
+ mechanism, and the `cli.exclusions.js` file that the old `test.sh`
5
+ depended upon.
6
+
7
+ - We removed the old asset-publishing role from the new bootstrap
8
+ stack, and split it into separate file- and docker-publishing roles.
9
+ Since 1.44.0 would still expect the old asset-publishing role,
10
+ its test would fail, so we disable it:
11
+
12
+ ```
13
+ test.skip('deploy new style synthesis to new style bootstrap', async () => {
14
+ ```
15
+
16
+ There is a better mechanism for skipping certain tests by using `skip-tests.txt`,
17
+ but that one is only available AFTER this release, so for this version we just replace
18
+ source files.