@aws-cdk-testing/cli-integ 3.3.0 → 3.3.2
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/lib/cli/run-suite.js +6 -1
- package/lib/cli/run-suite.ts +6 -0
- package/lib/integ-test.js +3 -13
- package/lib/integ-test.ts +2 -13
- package/lib/with-aws.js +1 -3
- package/lib/with-aws.ts +0 -3
- package/lib/with-cli-lib.js +2 -1
- package/lib/with-cli-lib.ts +1 -0
- package/package.json +4 -4
- package/resources/integ.jest.config.js +2 -3
- package/tests/cli-integ-tests/cdk---exclusively-selects-only-selected-stack.integtest.js +24 -0
- package/tests/cli-integ-tests/cdk---exclusively-selects-only-selected-stack.integtest.ts +29 -0
- package/tests/cli-integ-tests/cdk-assets/cdk-assets-uses-profile.integtest.js +80 -0
- package/tests/cli-integ-tests/cdk-assets/cdk-assets-uses-profile.integtest.ts +92 -0
- package/tests/cli-integ-tests/cdk-automatic-ordering-with-concurrency.integtest.js +11 -0
- package/tests/cli-integ-tests/cdk-automatic-ordering-with-concurrency.integtest.ts +15 -0
- package/tests/cli-integ-tests/cdk-automatic-ordering.integtest.js +11 -0
- package/tests/cli-integ-tests/cdk-automatic-ordering.integtest.ts +15 -0
- package/tests/cli-integ-tests/cdk-automatic-rollback-if-paused-and---no-rollback-is-removed-from-flags.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-automatic-rollback-if-paused-and---no-rollback-is-removed-from-flags.integtest.js +35 -0
- package/tests/cli-integ-tests/cdk-automatic-rollback-if-paused-and---no-rollback-is-removed-from-flags.integtest.ts +40 -0
- package/tests/cli-integ-tests/cdk-automatic-rollback-if-paused-and-change-contains-a-replacement.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-automatic-rollback-if-paused-and-change-contains-a-replacement.integtest.js +35 -0
- package/tests/cli-integ-tests/cdk-automatic-rollback-if-paused-and-change-contains-a-replacement.integtest.ts +40 -0
- package/tests/cli-integ-tests/cdk-automatic-rollback-if-replacement-and---no-rollback-is-removed-from-flags.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-automatic-rollback-if-replacement-and---no-rollback-is-removed-from-flags.integtest.js +26 -0
- package/tests/cli-integ-tests/cdk-automatic-rollback-if-replacement-and---no-rollback-is-removed-from-flags.integtest.ts +29 -0
- package/tests/cli-integ-tests/cdk-bootstrap-a-customized-template-vendor-will-not-overwrite-the-default-template.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-a-customized-template-vendor-will-not-overwrite-the-default-template.integtest.js +39 -0
- package/tests/cli-integ-tests/cdk-bootstrap-a-customized-template-vendor-will-not-overwrite-the-default-template.integtest.ts +42 -0
- package/tests/cli-integ-tests/cdk-bootstrap-add-tags.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-add-tags.integtest.js +25 -0
- package/tests/cli-integ-tests/cdk-bootstrap-add-tags.integtest.ts +26 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-add-tags-then-update-tags-during-re-bootstrap.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-add-tags-then-update-tags-during-re-bootstrap.integtest.js +27 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-add-tags-then-update-tags-during-re-bootstrap.integtest.ts +28 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-and-deploy-if-omitting-execution-policies.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-and-deploy-if-omitting-execution-policies.integtest.js +19 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-and-deploy-if-omitting-execution-policies.integtest.ts +21 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-bootstrap-without-execution.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-bootstrap-without-execution.integtest.js +18 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-bootstrap-without-execution.integtest.ts +22 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-create-a-legacy-bootstrap-stack-with---public-access-block-configuration-false.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-create-a-legacy-bootstrap-stack-with---public-access-block-configuration-false.integtest.js +20 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-create-a-legacy-bootstrap-stack-with---public-access-block-configuration-false.integtest.ts +21 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-create-multiple-legacy-bootstrap-stacks.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-create-multiple-legacy-bootstrap-stacks.integtest.js +26 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-create-multiple-legacy-bootstrap-stacks.integtest.ts +27 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-deploy-modern-synthesized-stack-even-if-bootstrap-stack-name-is-unknown.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-deploy-modern-synthesized-stack-even-if-bootstrap-stack-name-is-unknown.integtest.js +22 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-deploy-modern-synthesized-stack-even-if-bootstrap-stack-name-is-unknown.integtest.ts +24 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-deploy-with-session-tags-on-the-deploy.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-deploy-with-session-tags-on-the-deploy.integtest.js +23 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-deploy-with-session-tags-on-the-deploy.integtest.ts +25 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-deploy-without-execution-role-and-with-session-tags-on-deploy-role.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-deploy-without-execution-role-and-with-session-tags-on-deploy-role.integtest.js +20 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-deploy-without-execution-role-and-with-session-tags-on-deploy-role.integtest.ts +22 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-dump-the-template.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-dump-the-template.integtest.js +29 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-dump-the-template.integtest.ts +32 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-remove-custompermissionsboundary.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-remove-custompermissionsboundary.integtest.js +61 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-remove-custompermissionsboundary.integtest.ts +77 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-remove-trusted-account.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-remove-trusted-account.integtest.js +25 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-remove-trusted-account.integtest.ts +30 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-use-the-custom-permissions-boundary-(with-slashes)-to-bootstrap.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-use-the-custom-permissions-boundary-(with-slashes)-to-bootstrap.integtest.js +14 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-use-the-custom-permissions-boundary-(with-slashes)-to-bootstrap.integtest.ts +15 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-use-the-custom-permissions-boundary-to-bootstrap.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-use-the-custom-permissions-boundary-to-bootstrap.integtest.js +14 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-use-the-custom-permissions-boundary-to-bootstrap.integtest.ts +15 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-use-the-default-permissions-boundary-to-bootstrap.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-use-the-default-permissions-boundary-to-bootstrap.integtest.js +14 -0
- package/tests/cli-integ-tests/cdk-bootstrap-can-use-the-default-permissions-boundary-to-bootstrap.integtest.ts +15 -0
- package/tests/cli-integ-tests/cdk-bootstrap-create-ecr-with-tag-immutability-to-set-on.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-create-ecr-with-tag-immutability-to-set-on.integtest.js +27 -0
- package/tests/cli-integ-tests/cdk-bootstrap-create-ecr-with-tag-immutability-to-set-on.integtest.ts +34 -0
- package/tests/cli-integ-tests/cdk-bootstrap-deploy-new-style-synthesis-to-new-style-bootstrap-(with-docker-image).integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-deploy-new-style-synthesis-to-new-style-bootstrap-(with-docker-image).integtest.js +20 -0
- package/tests/cli-integ-tests/cdk-bootstrap-deploy-new-style-synthesis-to-new-style-bootstrap-(with-docker-image).integtest.ts +22 -0
- package/tests/cli-integ-tests/cdk-bootstrap-deploy-new-style-synthesis-to-new-style-bootstrap.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-deploy-new-style-synthesis-to-new-style-bootstrap.integtest.js +20 -0
- package/tests/cli-integ-tests/cdk-bootstrap-deploy-new-style-synthesis-to-new-style-bootstrap.integtest.ts +22 -0
- package/tests/cli-integ-tests/cdk-bootstrap-deploy-old-style-synthesis-to-new-style-bootstrap.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-deploy-old-style-synthesis-to-new-style-bootstrap.integtest.js +19 -0
- package/tests/cli-integ-tests/cdk-bootstrap-deploy-old-style-synthesis-to-new-style-bootstrap.integtest.ts +21 -0
- package/tests/cli-integ-tests/cdk-bootstrap-switch-on-termination-protection.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-switch-on-termination-protection.integtest.js +23 -0
- package/tests/cli-integ-tests/cdk-bootstrap-switch-on-termination-protection.integtest.ts +24 -0
- package/tests/cli-integ-tests/cdk-bootstrap-upgrade-legacy-bootstrap-stack-to-new-bootstrap-stack-while-in-use.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-bootstrap-upgrade-legacy-bootstrap-stack-to-new-bootstrap-stack-while-in-use.integtest.js +42 -0
- package/tests/cli-integ-tests/cdk-bootstrap-upgrade-legacy-bootstrap-stack-to-new-bootstrap-stack-while-in-use.integtest.ts +47 -0
- package/tests/cli-integ-tests/cdk-can-still-load-old-assemblies.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-can-still-load-old-assemblies.integtest.js +49 -0
- package/tests/cli-integ-tests/cdk-can-still-load-old-assemblies.integtest.ts +57 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---fail-on-multiple-stacks-exits-with-error-if-any-of-the-stacks-contains-a-diff.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---fail-on-multiple-stacks-exits-with-error-if-any-of-the-stacks-contains-a-diff.integtest.js +15 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---fail-on-multiple-stacks-exits-with-error-if-any-of-the-stacks-contains-a-diff.integtest.ts +22 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---fail-with-multiple-stack-exits-with-if-any-of-the-stacks-contains-a-diff.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---fail-with-multiple-stack-exits-with-if-any-of-the-stacks-contains-a-diff.integtest.js +15 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---fail-with-multiple-stack-exits-with-if-any-of-the-stacks-contains-a-diff.integtest.ts +22 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---quiet-does-not-print-there-were-no-differences-message-for-stacks-which-have-no-differences.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---quiet-does-not-print-there-were-no-differences-message-for-stacks-which-have-no-differences.integtest.js +14 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---quiet-does-not-print-there-were-no-differences-message-for-stacks-which-have-no-differences.integtest.ts +19 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only---fail-exits-when-security-changes-are-present.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only---fail-exits-when-security-changes-are-present.integtest.js +9 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only---fail-exits-when-security-changes-are-present.integtest.ts +14 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only---fail-exits-when-security-diff-for-sso-access-control-config.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only---fail-exits-when-security-diff-for-sso-access-control-config.integtest.js +8 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only---fail-exits-when-security-diff-for-sso-access-control-config.integtest.ts +13 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only---fail-exits-when-security-diff-for-sso-assignment.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only---fail-exits-when-security-diff-for-sso-assignment.integtest.js +8 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only---fail-exits-when-security-diff-for-sso-assignment.integtest.ts +13 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only---fail-exits-when-security-diff-for-sso-perm-set-with-managed-policy.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only---fail-exits-when-security-diff-for-sso-perm-set-with-managed-policy.integtest.js +8 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only---fail-exits-when-security-diff-for-sso-perm-set-with-managed-policy.integtest.ts +13 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only---fail-exits-when-security-diff-for-sso-perm-set-without-managed-policy.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only---fail-exits-when-security-diff-for-sso-perm-set-without-managed-policy.integtest.js +8 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only---fail-exits-when-security-diff-for-sso-perm-set-without-managed-policy.integtest.ts +13 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only-successfully-outputs-sso-access-control-information.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only-successfully-outputs-sso-access-control-information.integtest.js +30 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only-successfully-outputs-sso-access-control-information.integtest.ts +35 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only-successfully-outputs-sso-assignment-information.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only-successfully-outputs-sso-assignment-information.integtest.js +28 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only-successfully-outputs-sso-assignment-information.integtest.ts +37 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only-successfully-outputs-sso-permission-set-with-managed-policy-information.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only-successfully-outputs-sso-permission-set-with-managed-policy-information.integtest.js +27 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only-successfully-outputs-sso-permission-set-with-managed-policy-information.integtest.ts +35 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only-successfully-outputs-sso-permission-set-without-managed-policy-information.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only-successfully-outputs-sso-permission-set-without-managed-policy-information.integtest.js +30 -0
- package/tests/cli-integ-tests/cdk-cdk-diff---security-only-successfully-outputs-sso-permission-set-without-managed-policy-information.integtest.ts +37 -0
- package/tests/cli-integ-tests/cdk-cdk-diff-doesnt-show-resource-metadata-changes.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff-doesnt-show-resource-metadata-changes.integtest.js +18 -0
- package/tests/cli-integ-tests/cdk-cdk-diff-doesnt-show-resource-metadata-changes.integtest.ts +23 -0
- package/tests/cli-integ-tests/cdk-cdk-diff-shows-resource-metadata-changes-with---no-change-set.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff-shows-resource-metadata-changes-with---no-change-set.integtest.js +18 -0
- package/tests/cli-integ-tests/cdk-cdk-diff-shows-resource-metadata-changes-with---no-change-set.integtest.ts +23 -0
- package/tests/cli-integ-tests/cdk-cdk-diff-with-large-changeset-and-custom-toolkit-stack-name-and-qualifier-does-not-fail.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff-with-large-changeset-and-custom-toolkit-stack-name-and-qualifier-does-not-fail.integtest.js +35 -0
- package/tests/cli-integ-tests/cdk-cdk-diff-with-large-changeset-and-custom-toolkit-stack-name-and-qualifier-does-not-fail.integtest.ts +38 -0
- package/tests/cli-integ-tests/cdk-cdk-diff-with-large-changeset-does-not-fail.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff-with-large-changeset-does-not-fail.integtest.js +23 -0
- package/tests/cli-integ-tests/cdk-cdk-diff-with-large-changeset-does-not-fail.integtest.ts +28 -0
- package/tests/cli-integ-tests/cdk-cdk-diff.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-diff.integtest.js +13 -0
- package/tests/cli-integ-tests/cdk-cdk-diff.integtest.ts +18 -0
- package/tests/cli-integ-tests/cdk-cdk-ls---show-dependencies---json---long.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-ls---show-dependencies---json---long.integtest.js +45 -0
- package/tests/cli-integ-tests/cdk-cdk-ls---show-dependencies---json---long.integtest.ts +50 -0
- package/tests/cli-integ-tests/cdk-cdk-ls---show-dependencies---json.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-ls---show-dependencies---json.integtest.js +75 -0
- package/tests/cli-integ-tests/cdk-cdk-ls---show-dependencies---json.integtest.ts +95 -0
- package/tests/cli-integ-tests/cdk-cdk-ls.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-ls.integtest.js +32 -0
- package/tests/cli-integ-tests/cdk-cdk-ls.integtest.ts +36 -0
- package/tests/cli-integ-tests/cdk-cdk-notices-are-displayed-correctly.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-notices-are-displayed-correctly.integtest.js +38 -0
- package/tests/cli-integ-tests/cdk-cdk-notices-are-displayed-correctly.integtest.ts +42 -0
- package/tests/cli-integ-tests/cdk-cdk-notices-with---unacknowledged.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-notices-with---unacknowledged.integtest.js +11 -0
- package/tests/cli-integ-tests/cdk-cdk-notices-with---unacknowledged.integtest.ts +14 -0
- package/tests/cli-integ-tests/cdk-cdk-synth-add-the-metadata-properties-expected-by-sam.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-synth-add-the-metadata-properties-expected-by-sam.integtest.js +111 -0
- package/tests/cli-integ-tests/cdk-cdk-synth-add-the-metadata-properties-expected-by-sam.integtest.ts +126 -0
- package/tests/cli-integ-tests/cdk-cdk-synth-bundled-functions-as-expected.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-synth-bundled-functions-as-expected.integtest.js +74 -0
- package/tests/cli-integ-tests/cdk-cdk-synth-bundled-functions-as-expected.integtest.ts +80 -0
- package/tests/cli-integ-tests/cdk-cdk-synth.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-cdk-synth.integtest.js +40 -0
- package/tests/cli-integ-tests/cdk-cdk-synth.integtest.ts +53 -0
- package/tests/cli-integ-tests/cdk-ci-output-to-stderr.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-ci-output-to-stderr.integtest.js +16 -0
- package/tests/cli-integ-tests/cdk-ci-output-to-stderr.integtest.ts +19 -0
- package/tests/cli-integ-tests/cdk-ci-true-output-to-stdout.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-ci-true-output-to-stdout.integtest.js +24 -0
- package/tests/cli-integ-tests/cdk-ci-true-output-to-stdout.integtest.ts +28 -0
- package/tests/cli-integ-tests/cdk-construct-with-builtin-lambda-function.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-construct-with-builtin-lambda-function.integtest.js +11 -0
- package/tests/cli-integ-tests/cdk-construct-with-builtin-lambda-function.integtest.ts +14 -0
- package/tests/cli-integ-tests/cdk-context-in-stage-propagates-to-top.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-context-in-stage-propagates-to-top.integtest.js +15 -0
- package/tests/cli-integ-tests/cdk-context-in-stage-propagates-to-top.integtest.ts +20 -0
- package/tests/cli-integ-tests/cdk-context-setting.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-context-setting.integtest.js +26 -0
- package/tests/cli-integ-tests/cdk-context-setting.integtest.ts +33 -0
- package/tests/cli-integ-tests/cdk-deploy---method-direct.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy---method-direct.integtest.js +18 -0
- package/tests/cli-integ-tests/cdk-deploy---method-direct.integtest.ts +23 -0
- package/tests/cli-integ-tests/cdk-deploy-all-concurrently.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-all-concurrently.integtest.js +13 -0
- package/tests/cli-integ-tests/cdk-deploy-all-concurrently.integtest.ts +17 -0
- package/tests/cli-integ-tests/cdk-deploy-all.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-all.integtest.js +10 -0
- package/tests/cli-integ-tests/cdk-deploy-all.integtest.ts +14 -0
- package/tests/cli-integ-tests/cdk-deploy-and-test-stack-with-lambda-asset.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-and-test-stack-with-lambda-asset.integtest.js +22 -0
- package/tests/cli-integ-tests/cdk-deploy-and-test-stack-with-lambda-asset.integtest.ts +31 -0
- package/tests/cli-integ-tests/cdk-deploy-deletes-all-notification-arns-when-empty-array-is-passed.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-deletes-all-notification-arns-when-empty-array-is-passed.integtest.js +41 -0
- package/tests/cli-integ-tests/cdk-deploy-deletes-all-notification-arns-when-empty-array-is-passed.integtest.ts +50 -0
- package/tests/cli-integ-tests/cdk-deploy-no-stacks-error.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-no-stacks-error.integtest.js +13 -0
- package/tests/cli-integ-tests/cdk-deploy-no-stacks-error.integtest.ts +18 -0
- package/tests/cli-integ-tests/cdk-deploy-no-stacks-with---ignore-no-stacks.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-no-stacks-with---ignore-no-stacks.integtest.js +14 -0
- package/tests/cli-integ-tests/cdk-deploy-no-stacks-with---ignore-no-stacks.integtest.ts +17 -0
- package/tests/cli-integ-tests/cdk-deploy-preserves-existing-notification-arns-when-not-specified.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-preserves-existing-notification-arns-when-not-specified.integtest.js +38 -0
- package/tests/cli-integ-tests/cdk-deploy-preserves-existing-notification-arns-when-not-specified.integtest.ts +51 -0
- package/tests/cli-integ-tests/cdk-deploy-stack-with-docker-asset.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-stack-with-docker-asset.integtest.js +8 -0
- package/tests/cli-integ-tests/cdk-deploy-stack-with-docker-asset.integtest.ts +11 -0
- package/tests/cli-integ-tests/cdk-deploy-stack-with-lambda-asset-to-object-lock-enabled-asset-bucket.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-stack-with-lambda-asset-to-object-lock-enabled-asset-bucket.integtest.js +39 -0
- package/tests/cli-integ-tests/cdk-deploy-stack-with-lambda-asset-to-object-lock-enabled-asset-bucket.integtest.ts +42 -0
- package/tests/cli-integ-tests/cdk-deploy-stack-without-resource.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-stack-without-resource.integtest.js +17 -0
- package/tests/cli-integ-tests/cdk-deploy-stack-without-resource.integtest.ts +32 -0
- package/tests/cli-integ-tests/cdk-deploy-wildcard-with-outputs.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-wildcard-with-outputs.integtest.js +23 -0
- package/tests/cli-integ-tests/cdk-deploy-wildcard-with-outputs.integtest.ts +28 -0
- package/tests/cli-integ-tests/cdk-deploy-with-import-existing-resources-true.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-with-import-existing-resources-true.integtest.js +28 -0
- package/tests/cli-integ-tests/cdk-deploy-with-import-existing-resources-true.integtest.ts +29 -0
- package/tests/cli-integ-tests/cdk-deploy-with-method-direct-and-import-existing-resources-fails.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-with-method-direct-and-import-existing-resources-fails.integtest.js +16 -0
- package/tests/cli-integ-tests/cdk-deploy-with-method-direct-and-import-existing-resources-fails.integtest.ts +17 -0
- package/tests/cli-integ-tests/cdk-deploy-with-notification-arn-as-flag.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-with-notification-arn-as-flag.integtest.js +28 -0
- package/tests/cli-integ-tests/cdk-deploy-with-notification-arn-as-flag.integtest.ts +36 -0
- package/tests/cli-integ-tests/cdk-deploy-with-notification-arn-as-prop-and-flag.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-with-notification-arn-as-prop-and-flag.integtest.js +37 -0
- package/tests/cli-integ-tests/cdk-deploy-with-notification-arn-as-prop-and-flag.integtest.ts +45 -0
- package/tests/cli-integ-tests/cdk-deploy-with-notification-arn-as-prop.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-with-notification-arn-as-prop.integtest.js +31 -0
- package/tests/cli-integ-tests/cdk-deploy-with-notification-arn-as-prop.integtest.ts +37 -0
- package/tests/cli-integ-tests/cdk-deploy-with-parameters-multi.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-with-parameters-multi.integtest.js +26 -0
- package/tests/cli-integ-tests/cdk-deploy-with-parameters-multi.integtest.ts +33 -0
- package/tests/cli-integ-tests/cdk-deploy-with-parameters.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-with-parameters.integtest.js +20 -0
- package/tests/cli-integ-tests/cdk-deploy-with-parameters.integtest.ts +26 -0
- package/tests/cli-integ-tests/cdk-deploy-with-role.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-with-role.integtest.js +97 -0
- package/tests/cli-integ-tests/cdk-deploy-with-role.integtest.ts +119 -0
- package/tests/cli-integ-tests/cdk-deploy-with-wildcard-and-parameters.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-with-wildcard-and-parameters.integtest.js +19 -0
- package/tests/cli-integ-tests/cdk-deploy-with-wildcard-and-parameters.integtest.ts +22 -0
- package/tests/cli-integ-tests/cdk-deploy-without-execute-a-named-change-set.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-without-execute-a-named-change-set.integtest.js +28 -0
- package/tests/cli-integ-tests/cdk-deploy-without-execute-a-named-change-set.integtest.ts +36 -0
- package/tests/cli-integ-tests/cdk-deploy-without-import-existing-resources.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy-without-import-existing-resources.integtest.js +27 -0
- package/tests/cli-integ-tests/cdk-deploy-without-import-existing-resources.integtest.ts +28 -0
- package/tests/cli-integ-tests/cdk-deploy.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-deploy.integtest.js +15 -0
- package/tests/cli-integ-tests/cdk-deploy.integtest.ts +20 -0
- package/tests/cli-integ-tests/cdk-destroy-interactive.integtest.js +1 -1
- package/tests/cli-integ-tests/cdk-destroy-interactive.integtest.ts +1 -1
- package/tests/cli-integ-tests/cdk-doubly-nested-stack.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-doubly-nested-stack.integtest.js +10 -0
- package/tests/cli-integ-tests/cdk-doubly-nested-stack.integtest.ts +12 -0
- package/tests/cli-integ-tests/cdk-enablediffnofail.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-enablediffnofail.integtest.js +34 -0
- package/tests/cli-integ-tests/cdk-enablediffnofail.integtest.ts +44 -0
- package/tests/cli-integ-tests/cdk-failed-deploy-does-not-hang.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-failed-deploy-does-not-hang.integtest.js +9 -0
- package/tests/cli-integ-tests/cdk-failed-deploy-does-not-hang.integtest.ts +12 -0
- package/tests/cli-integ-tests/cdk-fast-deploy.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-fast-deploy.integtest.js +35 -0
- package/tests/cli-integ-tests/cdk-fast-deploy.integtest.ts +41 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-deletes-unused-ecr-images.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-deletes-unused-ecr-images.integtest.js +39 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-deletes-unused-ecr-images.integtest.ts +48 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-deletes-unused-s3-objects.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-deletes-unused-s3-objects.integtest.js +43 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-deletes-unused-s3-objects.integtest.ts +51 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-keeps-in-use-ecr-images.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-keeps-in-use-ecr-images.integtest.js +39 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-keeps-in-use-ecr-images.integtest.ts +48 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-keeps-in-use-s3-objects.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-keeps-in-use-s3-objects.integtest.js +44 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-keeps-in-use-s3-objects.integtest.ts +52 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-tags-unused-ecr-images.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-tags-unused-ecr-images.integtest.js +38 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-tags-unused-ecr-images.integtest.ts +47 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-tags-unused-s3-objects.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-tags-unused-s3-objects.integtest.js +54 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-tags-unused-s3-objects.integtest.ts +63 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-untags-in-use-ecr-images.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-untags-in-use-ecr-images.integtest.js +45 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-untags-in-use-ecr-images.integtest.ts +55 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-untags-in-use-s3-objects.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-untags-in-use-s3-objects.integtest.js +53 -0
- package/tests/cli-integ-tests/cdk-gc-garbage-collection-untags-in-use-s3-objects.integtest.ts +63 -0
- package/tests/cli-integ-tests/cdk-generating-and-loading-assembly.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-generating-and-loading-assembly.integtest.js +44 -0
- package/tests/cli-integ-tests/cdk-generating-and-loading-assembly.integtest.ts +52 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-for-ecs-service-detects-failed-deployment-and-errors.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-for-ecs-service-detects-failed-deployment-and-errors.integtest.js +24 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-for-ecs-service-detects-failed-deployment-and-errors.integtest.ts +29 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-for-ecs-service-waits-for-deployment-to-complete.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-for-ecs-service-waits-for-deployment-to-complete.integtest.js +33 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-for-ecs-service-waits-for-deployment-to-complete.integtest.ts +45 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-supports-appsync-apis-with-many-functions.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-supports-appsync-apis-with-many-functions.integtest.js +30 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-supports-appsync-apis-with-many-functions.integtest.ts +36 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-supports-ecs-service.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-supports-ecs-service.integtest.js +33 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-supports-ecs-service.integtest.ts +41 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-supports-fn::importvalue-intrinsic.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-supports-fn::importvalue-intrinsic.integtest.js +46 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-supports-fn::importvalue-intrinsic.integtest.ts +53 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-supports-lambda-functions-description-and-environment-variables.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-supports-lambda-functions-description-and-environment-variables.integtest.js +36 -0
- package/tests/cli-integ-tests/cdk-hotswap-deployment-supports-lambda-functions-description-and-environment-variables.integtest.ts +43 -0
- package/tests/cli-integ-tests/cdk-hotswap-ecs-deployment-respects-properties-override.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-hotswap-ecs-deployment-respects-properties-override.integtest.js +51 -0
- package/tests/cli-integ-tests/cdk-hotswap-ecs-deployment-respects-properties-override.integtest.ts +59 -0
- package/tests/cli-integ-tests/cdk-iam-diff.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-iam-diff.integtest.js +18 -0
- package/tests/cli-integ-tests/cdk-iam-diff.integtest.ts +23 -0
- package/tests/cli-integ-tests/cdk-import-interactive.integtest.js +1 -1
- package/tests/cli-integ-tests/cdk-import-interactive.integtest.ts +1 -1
- package/tests/cli-integ-tests/cdk-lib-cli-lib-deploy.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-lib-cli-lib-deploy.integtest.js +27 -0
- package/tests/cli-integ-tests/cdk-lib-cli-lib-deploy.integtest.ts +32 -0
- package/tests/cli-integ-tests/cdk-lib-cli-lib-list.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-lib-cli-lib-list.integtest.js +9 -0
- package/tests/cli-integ-tests/cdk-lib-cli-lib-list.integtest.ts +12 -0
- package/tests/cli-integ-tests/cdk-lib-cli-lib-synth.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-lib-cli-lib-synth.integtest.js +22 -0
- package/tests/cli-integ-tests/cdk-lib-cli-lib-synth.integtest.ts +27 -0
- package/tests/cli-integ-tests/cdk-lib-security-related-changes-without-a-cli-are-expected-to-fail-when-approval-is-required.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-lib-security-related-changes-without-a-cli-are-expected-to-fail-when-approval-is-required.integtest.js +20 -0
- package/tests/cli-integ-tests/cdk-lib-security-related-changes-without-a-cli-are-expected-to-fail-when-approval-is-required.integtest.ts +32 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate--from-stack-creates-deployable-app-csharp.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate--from-stack-creates-deployable-app-csharp.integtest.js +9 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate--from-stack-creates-deployable-app-csharp.integtest.ts +11 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate--from-stack-creates-deployable-app-java.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate--from-stack-creates-deployable-app-java.integtest.js +9 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate--from-stack-creates-deployable-app-java.integtest.ts +11 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate--from-stack-creates-deployable-app-python.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate--from-stack-creates-deployable-app-python.integtest.js +9 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate--from-stack-creates-deployable-app-python.integtest.ts +11 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate--from-stack-creates-deployable-app-typescript.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate--from-stack-creates-deployable-app-typescript.integtest.js +9 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate--from-stack-creates-deployable-app-typescript.integtest.ts +11 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate-deploys-successfully-csharp.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate-deploys-successfully-csharp.integtest.js +9 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate-deploys-successfully-csharp.integtest.ts +13 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate-deploys-successfully-java.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate-deploys-successfully-java.integtest.js +9 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate-deploys-successfully-java.integtest.ts +13 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate-deploys-successfully-python.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate-deploys-successfully-python.integtest.js +9 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate-deploys-successfully-python.integtest.ts +13 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate-deploys-successfully-typescript.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate-deploys-successfully-typescript.integtest.js +9 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate-deploys-successfully-typescript.integtest.ts +13 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate-generates-migrate.json.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate-generates-migrate.json.integtest.js +16 -0
- package/tests/cli-integ-tests/cdk-migrate/cdk-migrate-generates-migrate.json.integtest.ts +20 -0
- package/tests/cli-integ-tests/cdk-migrate/testcase.d.ts +3 -0
- package/tests/cli-integ-tests/cdk-migrate/testcase.js +55 -0
- package/tests/cli-integ-tests/cdk-migrate/testcase.ts +69 -0
- package/tests/cli-integ-tests/cdk-nested-stack-with-parameters.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-nested-stack-with-parameters.integtest.js +22 -0
- package/tests/cli-integ-tests/cdk-nested-stack-with-parameters.integtest.ts +28 -0
- package/tests/cli-integ-tests/cdk-requests-go-through-a-proxy-when-configured.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-requests-go-through-a-proxy-when-configured.integtest.js +36 -0
- package/tests/cli-integ-tests/cdk-requests-go-through-a-proxy-when-configured.integtest.ts +39 -0
- package/tests/cli-integ-tests/cdk-sam-can-locally-test-the-synthesized-cdk-application.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-sam-can-locally-test-the-synthesized-cdk-application.integtest.js +14 -0
- package/tests/cli-integ-tests/cdk-sam-can-locally-test-the-synthesized-cdk-application.integtest.ts +25 -0
- package/tests/cli-integ-tests/cdk-security-related-changes-without-a-cli-are-expected-to-fail.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-security-related-changes-without-a-cli-are-expected-to-fail.integtest.js +20 -0
- package/tests/cli-integ-tests/cdk-security-related-changes-without-a-cli-are-expected-to-fail.integtest.ts +30 -0
- package/tests/cli-integ-tests/cdk-skips-notice-refresh.integtest.d.ts +6 -0
- package/tests/cli-integ-tests/cdk-skips-notice-refresh.integtest.js +22 -0
- package/tests/cli-integ-tests/cdk-skips-notice-refresh.integtest.ts +26 -0
- package/tests/cli-integ-tests/cdk-ssm-parameter-provider-error.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-ssm-parameter-provider-error.integtest.js +10 -0
- package/tests/cli-integ-tests/cdk-ssm-parameter-provider-error.integtest.ts +18 -0
- package/tests/cli-integ-tests/cdk-stack-in-update_rollback_complete-state-can-be-updated.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-stack-in-update_rollback_complete-state-can-be-updated.integtest.js +41 -0
- package/tests/cli-integ-tests/cdk-stack-in-update_rollback_complete-state-can-be-updated.integtest.ts +59 -0
- package/tests/cli-integ-tests/cdk-stage-with-bundled-lambda-function.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-stage-with-bundled-lambda-function.integtest.js +10 -0
- package/tests/cli-integ-tests/cdk-stage-with-bundled-lambda-function.integtest.ts +13 -0
- package/tests/cli-integ-tests/cdk-synth---quiet-can-be-specified-in-cdk.json.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-synth---quiet-can-be-specified-in-cdk.json.integtest.js +17 -0
- package/tests/cli-integ-tests/cdk-synth---quiet-can-be-specified-in-cdk.json.integtest.ts +20 -0
- package/tests/cli-integ-tests/cdk-synthing-a-stage-with-errors-can-be-suppressed.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-synthing-a-stage-with-errors-can-be-suppressed.integtest.js +12 -0
- package/tests/cli-integ-tests/cdk-synthing-a-stage-with-errors-can-be-suppressed.integtest.ts +15 -0
- package/tests/cli-integ-tests/cdk-synthing-a-stage-with-errors-leads-to-failure.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-synthing-a-stage-with-errors-leads-to-failure.integtest.js +14 -0
- package/tests/cli-integ-tests/cdk-synthing-a-stage-with-errors-leads-to-failure.integtest.ts +18 -0
- package/tests/cli-integ-tests/cdk-templates-on-disk-contain-metadata-resource.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-templates-on-disk-contain-metadata-resource.integtest.js +18 -0
- package/tests/cli-integ-tests/cdk-templates-on-disk-contain-metadata-resource.integtest.ts +25 -0
- package/tests/cli-integ-tests/cdk-termination-protection.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-termination-protection.integtest.js +14 -0
- package/tests/cli-integ-tests/cdk-termination-protection.integtest.ts +19 -0
- package/tests/cli-integ-tests/cdk-test-cdk-rollback---force.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-test-cdk-rollback---force.integtest.js +40 -0
- package/tests/cli-integ-tests/cdk-test-cdk-rollback---force.integtest.ts +48 -0
- package/tests/cli-integ-tests/cdk-test-cdk-rollback.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-test-cdk-rollback.integtest.js +33 -0
- package/tests/cli-integ-tests/cdk-test-cdk-rollback.integtest.ts +38 -0
- package/tests/cli-integ-tests/cdk-test-migrate-deployment-for-app-with-localfile-source-in-migrate.json.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-test-migrate-deployment-for-app-with-localfile-source-in-migrate.json.integtest.js +45 -0
- package/tests/cli-integ-tests/cdk-test-migrate-deployment-for-app-with-localfile-source-in-migrate.json.integtest.ts +56 -0
- package/tests/cli-integ-tests/cdk-test-resource-import-with-construct-that-requires-bundling.integtest.d.ts +6 -0
- package/tests/cli-integ-tests/cdk-test-resource-import-with-construct-that-requires-bundling.integtest.js +59 -0
- package/tests/cli-integ-tests/cdk-test-resource-import-with-construct-that-requires-bundling.integtest.ts +74 -0
- package/tests/cli-integ-tests/cdk-test-resource-import.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-test-resource-import.integtest.js +51 -0
- package/tests/cli-integ-tests/cdk-test-resource-import.integtest.ts +64 -0
- package/tests/cli-integ-tests/cdk-two-ways-of-showing-the-version.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-two-ways-of-showing-the-version.integtest.js +10 -0
- package/tests/cli-integ-tests/cdk-two-ways-of-showing-the-version.integtest.ts +14 -0
- package/tests/cli-integ-tests/cdk-update-to-stack-in-rollback_complete-state-will-delete-stack-and-create-a-new-one.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-update-to-stack-in-rollback_complete-state-will-delete-stack-and-create-a-new-one.integtest.js +34 -0
- package/tests/cli-integ-tests/cdk-update-to-stack-in-rollback_complete-state-will-delete-stack-and-create-a-new-one.integtest.ts +47 -0
- package/tests/cli-integ-tests/cdk-vpc-lookup.integtest.d.ts +1 -0
- package/tests/cli-integ-tests/cdk-vpc-lookup.integtest.js +21 -0
- package/tests/cli-integ-tests/cdk-vpc-lookup.integtest.ts +26 -0
- package/tests/cli-integ-tests/bootstrapping.integtest.js +0 -431
- package/tests/cli-integ-tests/bootstrapping.integtest.ts +0 -517
- package/tests/cli-integ-tests/cli-lib.integtest.js +0 -62
- package/tests/cli-integ-tests/cli-lib.integtest.ts +0 -90
- package/tests/cli-integ-tests/cli.integtest.js +0 -2188
- package/tests/cli-integ-tests/cli.integtest.ts +0 -2971
- package/tests/cli-integ-tests/garbage-collection.integtest.js +0 -314
- package/tests/cli-integ-tests/garbage-collection.integtest.ts +0 -392
- /package/tests/cli-integ-tests/{bootstrapping.integtest.d.ts → cdk---exclusively-selects-only-selected-stack.integtest.d.ts} +0 -0
- /package/tests/cli-integ-tests/{cli-lib.integtest.d.ts → cdk-assets/cdk-assets-uses-profile.integtest.d.ts} +0 -0
- /package/tests/cli-integ-tests/{cli.integtest.d.ts → cdk-automatic-ordering-with-concurrency.integtest.d.ts} +0 -0
- /package/tests/cli-integ-tests/{garbage-collection.integtest.d.ts → cdk-automatic-ordering.integtest.d.ts} +0 -0
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { DescribeStacksCommand } from '@aws-sdk/client-cloudformation';
|
|
2
|
+
import { integTest, withDefaultFixture } from '../../lib';
|
|
3
|
+
|
|
4
|
+
jest.setTimeout(2 * 60 * 60_000); // Includes the time to acquire locks, worst-case single-threaded runtime
|
|
5
|
+
|
|
6
|
+
integTest(
|
|
7
|
+
'update to stack in ROLLBACK_COMPLETE state will delete stack and create a new one',
|
|
8
|
+
withDefaultFixture(async (fixture) => {
|
|
9
|
+
// GIVEN
|
|
10
|
+
await expect(
|
|
11
|
+
fixture.cdkDeploy('param-test-1', {
|
|
12
|
+
options: ['--parameters', `TopicNameParam=${fixture.stackNamePrefix}@aww`],
|
|
13
|
+
captureStderr: false,
|
|
14
|
+
}),
|
|
15
|
+
).rejects.toThrow('exited with error');
|
|
16
|
+
|
|
17
|
+
const response = await fixture.aws.cloudFormation.send(
|
|
18
|
+
new DescribeStacksCommand({
|
|
19
|
+
StackName: fixture.fullStackName('param-test-1'),
|
|
20
|
+
}),
|
|
21
|
+
);
|
|
22
|
+
|
|
23
|
+
const stackArn = response.Stacks?.[0].StackId;
|
|
24
|
+
expect(response.Stacks?.[0].StackStatus).toEqual('ROLLBACK_COMPLETE');
|
|
25
|
+
|
|
26
|
+
// WHEN
|
|
27
|
+
const newStackArn = await fixture.cdkDeploy('param-test-1', {
|
|
28
|
+
options: ['--parameters', `TopicNameParam=${fixture.stackNamePrefix}allgood`],
|
|
29
|
+
captureStderr: false,
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
const newStackResponse = await fixture.aws.cloudFormation.send(
|
|
33
|
+
new DescribeStacksCommand({
|
|
34
|
+
StackName: newStackArn,
|
|
35
|
+
}),
|
|
36
|
+
);
|
|
37
|
+
|
|
38
|
+
// THEN
|
|
39
|
+
expect(stackArn).not.toEqual(newStackArn); // new stack was created
|
|
40
|
+
expect(newStackResponse.Stacks?.[0].StackStatus).toEqual('CREATE_COMPLETE');
|
|
41
|
+
expect(newStackResponse.Stacks?.[0].Parameters).toContainEqual({
|
|
42
|
+
ParameterKey: 'TopicNameParam',
|
|
43
|
+
ParameterValue: `${fixture.stackNamePrefix}allgood`,
|
|
44
|
+
});
|
|
45
|
+
}),
|
|
46
|
+
);
|
|
47
|
+
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const lib_1 = require("../../lib");
|
|
4
|
+
jest.setTimeout(2 * 60 * 60000); // Includes the time to acquire locks, worst-case single-threaded runtime
|
|
5
|
+
(0, lib_1.integTest)('VPC Lookup', (0, lib_1.withDefaultFixture)(async (fixture) => {
|
|
6
|
+
fixture.log('Making sure we are clean before starting.');
|
|
7
|
+
await fixture.cdkDestroy('define-vpc', { modEnv: { ENABLE_VPC_TESTING: 'DEFINE' } });
|
|
8
|
+
fixture.log('Setting up: creating a VPC with known tags');
|
|
9
|
+
await fixture.cdkDeploy('define-vpc', { modEnv: { ENABLE_VPC_TESTING: 'DEFINE' } });
|
|
10
|
+
fixture.log('Setup complete!');
|
|
11
|
+
fixture.log('Verifying we can now import that VPC');
|
|
12
|
+
await fixture.cdkDeploy('import-vpc', { modEnv: { ENABLE_VPC_TESTING: 'IMPORT' } });
|
|
13
|
+
}));
|
|
14
|
+
// testing a construct with a builtin Nodejs Lambda Function.
|
|
15
|
+
// In this case we are testing the s3.Bucket construct with the
|
|
16
|
+
// autoDeleteObjects prop set to true, which creates a Lambda backed
|
|
17
|
+
// CustomResource. Since the compiled Lambda code (e.g. __entrypoint__.js)
|
|
18
|
+
// is bundled as part of the CDK package, we want to make sure we don't
|
|
19
|
+
// introduce changes to the compiled code that could prevent the Lambda from
|
|
20
|
+
// executing. If we do, this test will timeout and fail.
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2RrLXZwYy1sb29rdXAuaW50ZWd0ZXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiY2RrLXZwYy1sb29rdXAuaW50ZWd0ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsbUNBQTBEO0FBRTFELElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxHQUFHLEVBQUUsR0FBRyxLQUFNLENBQUMsQ0FBQyxDQUFDLHlFQUF5RTtBQUUzRyxJQUFBLGVBQVMsRUFDUCxZQUFZLEVBQ1osSUFBQSx3QkFBa0IsRUFBQyxLQUFLLEVBQUUsT0FBTyxFQUFFLEVBQUU7SUFDbkMsT0FBTyxDQUFDLEdBQUcsQ0FBQywyQ0FBMkMsQ0FBQyxDQUFDO0lBQ3pELE1BQU0sT0FBTyxDQUFDLFVBQVUsQ0FBQyxZQUFZLEVBQUUsRUFBRSxNQUFNLEVBQUUsRUFBRSxrQkFBa0IsRUFBRSxRQUFRLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFFckYsT0FBTyxDQUFDLEdBQUcsQ0FBQyw0Q0FBNEMsQ0FBQyxDQUFDO0lBQzFELE1BQU0sT0FBTyxDQUFDLFNBQVMsQ0FBQyxZQUFZLEVBQUUsRUFBRSxNQUFNLEVBQUUsRUFBRSxrQkFBa0IsRUFBRSxRQUFRLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDcEYsT0FBTyxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0lBRS9CLE9BQU8sQ0FBQyxHQUFHLENBQUMsc0NBQXNDLENBQUMsQ0FBQztJQUNwRCxNQUFNLE9BQU8sQ0FBQyxTQUFTLENBQUMsWUFBWSxFQUFFLEVBQUUsTUFBTSxFQUFFLEVBQUUsa0JBQWtCLEVBQUUsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0FBQ3RGLENBQUMsQ0FBQyxDQUNILENBQUM7QUFFRiw2REFBNkQ7QUFDN0QsK0RBQStEO0FBQy9ELG9FQUFvRTtBQUNwRSwwRUFBMEU7QUFDMUUsdUVBQXVFO0FBQ3ZFLDRFQUE0RTtBQUM1RSx3REFBd0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbnRlZ1Rlc3QsIHdpdGhEZWZhdWx0Rml4dHVyZSB9IGZyb20gJy4uLy4uL2xpYic7XG5cbmplc3Quc2V0VGltZW91dCgyICogNjAgKiA2MF8wMDApOyAvLyBJbmNsdWRlcyB0aGUgdGltZSB0byBhY3F1aXJlIGxvY2tzLCB3b3JzdC1jYXNlIHNpbmdsZS10aHJlYWRlZCBydW50aW1lXG5cbmludGVnVGVzdChcbiAgJ1ZQQyBMb29rdXAnLFxuICB3aXRoRGVmYXVsdEZpeHR1cmUoYXN5bmMgKGZpeHR1cmUpID0+IHtcbiAgICBmaXh0dXJlLmxvZygnTWFraW5nIHN1cmUgd2UgYXJlIGNsZWFuIGJlZm9yZSBzdGFydGluZy4nKTtcbiAgICBhd2FpdCBmaXh0dXJlLmNka0Rlc3Ryb3koJ2RlZmluZS12cGMnLCB7IG1vZEVudjogeyBFTkFCTEVfVlBDX1RFU1RJTkc6ICdERUZJTkUnIH0gfSk7XG5cbiAgICBmaXh0dXJlLmxvZygnU2V0dGluZyB1cDogY3JlYXRpbmcgYSBWUEMgd2l0aCBrbm93biB0YWdzJyk7XG4gICAgYXdhaXQgZml4dHVyZS5jZGtEZXBsb3koJ2RlZmluZS12cGMnLCB7IG1vZEVudjogeyBFTkFCTEVfVlBDX1RFU1RJTkc6ICdERUZJTkUnIH0gfSk7XG4gICAgZml4dHVyZS5sb2coJ1NldHVwIGNvbXBsZXRlIScpO1xuXG4gICAgZml4dHVyZS5sb2coJ1ZlcmlmeWluZyB3ZSBjYW4gbm93IGltcG9ydCB0aGF0IFZQQycpO1xuICAgIGF3YWl0IGZpeHR1cmUuY2RrRGVwbG95KCdpbXBvcnQtdnBjJywgeyBtb2RFbnY6IHsgRU5BQkxFX1ZQQ19URVNUSU5HOiAnSU1QT1JUJyB9IH0pO1xuICB9KSxcbik7XG5cbi8vIHRlc3RpbmcgYSBjb25zdHJ1Y3Qgd2l0aCBhIGJ1aWx0aW4gTm9kZWpzIExhbWJkYSBGdW5jdGlvbi5cbi8vIEluIHRoaXMgY2FzZSB3ZSBhcmUgdGVzdGluZyB0aGUgczMuQnVja2V0IGNvbnN0cnVjdCB3aXRoIHRoZVxuLy8gYXV0b0RlbGV0ZU9iamVjdHMgcHJvcCBzZXQgdG8gdHJ1ZSwgd2hpY2ggY3JlYXRlcyBhIExhbWJkYSBiYWNrZWRcbi8vIEN1c3RvbVJlc291cmNlLiBTaW5jZSB0aGUgY29tcGlsZWQgTGFtYmRhIGNvZGUgKGUuZy4gX19lbnRyeXBvaW50X18uanMpXG4vLyBpcyBidW5kbGVkIGFzIHBhcnQgb2YgdGhlIENESyBwYWNrYWdlLCB3ZSB3YW50IHRvIG1ha2Ugc3VyZSB3ZSBkb24ndFxuLy8gaW50cm9kdWNlIGNoYW5nZXMgdG8gdGhlIGNvbXBpbGVkIGNvZGUgdGhhdCBjb3VsZCBwcmV2ZW50IHRoZSBMYW1iZGEgZnJvbVxuLy8gZXhlY3V0aW5nLiBJZiB3ZSBkbywgdGhpcyB0ZXN0IHdpbGwgdGltZW91dCBhbmQgZmFpbC5cbiJdfQ==
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { integTest, withDefaultFixture } from '../../lib';
|
|
2
|
+
|
|
3
|
+
jest.setTimeout(2 * 60 * 60_000); // Includes the time to acquire locks, worst-case single-threaded runtime
|
|
4
|
+
|
|
5
|
+
integTest(
|
|
6
|
+
'VPC Lookup',
|
|
7
|
+
withDefaultFixture(async (fixture) => {
|
|
8
|
+
fixture.log('Making sure we are clean before starting.');
|
|
9
|
+
await fixture.cdkDestroy('define-vpc', { modEnv: { ENABLE_VPC_TESTING: 'DEFINE' } });
|
|
10
|
+
|
|
11
|
+
fixture.log('Setting up: creating a VPC with known tags');
|
|
12
|
+
await fixture.cdkDeploy('define-vpc', { modEnv: { ENABLE_VPC_TESTING: 'DEFINE' } });
|
|
13
|
+
fixture.log('Setup complete!');
|
|
14
|
+
|
|
15
|
+
fixture.log('Verifying we can now import that VPC');
|
|
16
|
+
await fixture.cdkDeploy('import-vpc', { modEnv: { ENABLE_VPC_TESTING: 'IMPORT' } });
|
|
17
|
+
}),
|
|
18
|
+
);
|
|
19
|
+
|
|
20
|
+
// testing a construct with a builtin Nodejs Lambda Function.
|
|
21
|
+
// In this case we are testing the s3.Bucket construct with the
|
|
22
|
+
// autoDeleteObjects prop set to true, which creates a Lambda backed
|
|
23
|
+
// CustomResource. Since the compiled Lambda code (e.g. __entrypoint__.js)
|
|
24
|
+
// is bundled as part of the CDK package, we want to make sure we don't
|
|
25
|
+
// introduce changes to the compiled code that could prevent the Lambda from
|
|
26
|
+
// executing. If we do, this test will timeout and fail.
|
|
@@ -1,431 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
/* eslint-disable @cdklabs/no-literal-partition */
|
|
4
|
-
const fs = require("fs");
|
|
5
|
-
const path = require("path");
|
|
6
|
-
const client_cloudformation_1 = require("@aws-sdk/client-cloudformation");
|
|
7
|
-
const client_ecr_1 = require("@aws-sdk/client-ecr");
|
|
8
|
-
const client_iam_1 = require("@aws-sdk/client-iam");
|
|
9
|
-
const yaml = require("yaml");
|
|
10
|
-
const lib_1 = require("../../lib");
|
|
11
|
-
const eventually_1 = require("../../lib/eventually");
|
|
12
|
-
jest.setTimeout(2 * 60 * 60000); // Includes the time to acquire locks, worst-case single-threaded runtime
|
|
13
|
-
(0, lib_1.integTest)('can bootstrap without execution', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
14
|
-
var _a;
|
|
15
|
-
const bootstrapStackName = fixture.bootstrapStackName;
|
|
16
|
-
await fixture.cdkBootstrapLegacy({
|
|
17
|
-
toolkitStackName: bootstrapStackName,
|
|
18
|
-
noExecute: true,
|
|
19
|
-
});
|
|
20
|
-
const resp = await fixture.aws.cloudFormation.send(new client_cloudformation_1.DescribeStacksCommand({
|
|
21
|
-
StackName: bootstrapStackName,
|
|
22
|
-
}));
|
|
23
|
-
expect((_a = resp.Stacks) === null || _a === void 0 ? void 0 : _a[0].StackStatus).toEqual('REVIEW_IN_PROGRESS');
|
|
24
|
-
}));
|
|
25
|
-
(0, lib_1.integTest)('upgrade legacy bootstrap stack to new bootstrap stack while in use', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
26
|
-
const bootstrapStackName = fixture.bootstrapStackName;
|
|
27
|
-
const legacyBootstrapBucketName = `aws-cdk-bootstrap-integ-test-legacy-bckt-${(0, lib_1.randomString)()}`;
|
|
28
|
-
const newBootstrapBucketName = `aws-cdk-bootstrap-integ-test-v2-bckt-${(0, lib_1.randomString)()}`;
|
|
29
|
-
fixture.rememberToDeleteBucket(legacyBootstrapBucketName); // This one will leak
|
|
30
|
-
fixture.rememberToDeleteBucket(newBootstrapBucketName); // This one shouldn't leak if the test succeeds, but let's be safe in case it doesn't
|
|
31
|
-
// Legacy bootstrap
|
|
32
|
-
await fixture.cdkBootstrapLegacy({
|
|
33
|
-
toolkitStackName: bootstrapStackName,
|
|
34
|
-
bootstrapBucketName: legacyBootstrapBucketName,
|
|
35
|
-
});
|
|
36
|
-
// Deploy stack that uses file assets
|
|
37
|
-
await fixture.cdkDeploy('lambda', {
|
|
38
|
-
options: [
|
|
39
|
-
'--context', `bootstrapBucket=${legacyBootstrapBucketName}`,
|
|
40
|
-
'--context', 'legacySynth=true',
|
|
41
|
-
'--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,
|
|
42
|
-
'--toolkit-stack-name', bootstrapStackName,
|
|
43
|
-
],
|
|
44
|
-
});
|
|
45
|
-
// Upgrade bootstrap stack to "new" style
|
|
46
|
-
await fixture.cdkBootstrapModern({
|
|
47
|
-
toolkitStackName: bootstrapStackName,
|
|
48
|
-
bootstrapBucketName: newBootstrapBucketName,
|
|
49
|
-
cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
|
|
50
|
-
});
|
|
51
|
-
// (Force) deploy stack again
|
|
52
|
-
// --force to bypass the check which says that the template hasn't changed.
|
|
53
|
-
await fixture.cdkDeploy('lambda', {
|
|
54
|
-
options: [
|
|
55
|
-
'--context', `bootstrapBucket=${newBootstrapBucketName}`,
|
|
56
|
-
'--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,
|
|
57
|
-
'--toolkit-stack-name', bootstrapStackName,
|
|
58
|
-
'--force',
|
|
59
|
-
],
|
|
60
|
-
});
|
|
61
|
-
}));
|
|
62
|
-
(0, lib_1.integTest)('can and deploy if omitting execution policies', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
63
|
-
const bootstrapStackName = fixture.bootstrapStackName;
|
|
64
|
-
await fixture.cdkBootstrapModern({
|
|
65
|
-
toolkitStackName: bootstrapStackName,
|
|
66
|
-
});
|
|
67
|
-
// Deploy stack that uses file assets
|
|
68
|
-
await fixture.cdkDeploy('lambda', {
|
|
69
|
-
options: [
|
|
70
|
-
'--toolkit-stack-name', bootstrapStackName,
|
|
71
|
-
'--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,
|
|
72
|
-
'--context', '@aws-cdk/core:newStyleStackSynthesis=1',
|
|
73
|
-
],
|
|
74
|
-
});
|
|
75
|
-
}));
|
|
76
|
-
(0, lib_1.integTest)('can deploy with session tags on the deploy, lookup, file asset, and image asset publishing roles', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
77
|
-
const bootstrapStackName = fixture.bootstrapStackName;
|
|
78
|
-
await fixture.cdkBootstrapModern({
|
|
79
|
-
toolkitStackName: bootstrapStackName,
|
|
80
|
-
bootstrapTemplate: path.join(__dirname, '..', '..', 'resources', 'bootstrap-templates', 'session-tags.all-roles-deny-all.yaml'),
|
|
81
|
-
});
|
|
82
|
-
await fixture.cdkDeploy('session-tags', {
|
|
83
|
-
options: [
|
|
84
|
-
'--toolkit-stack-name', bootstrapStackName,
|
|
85
|
-
'--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,
|
|
86
|
-
'--context', '@aws-cdk/core:newStyleStackSynthesis=1',
|
|
87
|
-
],
|
|
88
|
-
modEnv: {
|
|
89
|
-
ENABLE_VPC_TESTING: 'IMPORT',
|
|
90
|
-
},
|
|
91
|
-
});
|
|
92
|
-
}));
|
|
93
|
-
(0, lib_1.integTest)('can deploy without execution role and with session tags on deploy role', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
94
|
-
const bootstrapStackName = fixture.bootstrapStackName;
|
|
95
|
-
await fixture.cdkBootstrapModern({
|
|
96
|
-
toolkitStackName: bootstrapStackName,
|
|
97
|
-
bootstrapTemplate: path.join(__dirname, '..', '..', 'resources', 'bootstrap-templates', 'session-tags.deploy-role-deny-sqs.yaml'),
|
|
98
|
-
});
|
|
99
|
-
await fixture.cdkDeploy('session-tags-with-custom-synthesizer', {
|
|
100
|
-
options: [
|
|
101
|
-
'--toolkit-stack-name', bootstrapStackName,
|
|
102
|
-
'--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,
|
|
103
|
-
'--context', '@aws-cdk/core:newStyleStackSynthesis=1',
|
|
104
|
-
],
|
|
105
|
-
});
|
|
106
|
-
}));
|
|
107
|
-
(0, lib_1.integTest)('deploy new style synthesis to new style bootstrap', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
108
|
-
const bootstrapStackName = fixture.bootstrapStackName;
|
|
109
|
-
await fixture.cdkBootstrapModern({
|
|
110
|
-
toolkitStackName: bootstrapStackName,
|
|
111
|
-
cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
|
|
112
|
-
});
|
|
113
|
-
// Deploy stack that uses file assets
|
|
114
|
-
await fixture.cdkDeploy('lambda', {
|
|
115
|
-
options: [
|
|
116
|
-
'--toolkit-stack-name', bootstrapStackName,
|
|
117
|
-
'--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,
|
|
118
|
-
'--context', '@aws-cdk/core:newStyleStackSynthesis=1',
|
|
119
|
-
],
|
|
120
|
-
});
|
|
121
|
-
}));
|
|
122
|
-
(0, lib_1.integTest)('deploy new style synthesis to new style bootstrap (with docker image)', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
123
|
-
const bootstrapStackName = fixture.bootstrapStackName;
|
|
124
|
-
await fixture.cdkBootstrapModern({
|
|
125
|
-
toolkitStackName: bootstrapStackName,
|
|
126
|
-
cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
|
|
127
|
-
});
|
|
128
|
-
// Deploy stack that uses file assets
|
|
129
|
-
await fixture.cdkDeploy('docker', {
|
|
130
|
-
options: [
|
|
131
|
-
'--toolkit-stack-name', bootstrapStackName,
|
|
132
|
-
'--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,
|
|
133
|
-
'--context', '@aws-cdk/core:newStyleStackSynthesis=1',
|
|
134
|
-
],
|
|
135
|
-
});
|
|
136
|
-
}));
|
|
137
|
-
(0, lib_1.integTest)('deploy old style synthesis to new style bootstrap', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
138
|
-
const bootstrapStackName = fixture.bootstrapStackName;
|
|
139
|
-
await fixture.cdkBootstrapModern({
|
|
140
|
-
toolkitStackName: bootstrapStackName,
|
|
141
|
-
cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
|
|
142
|
-
});
|
|
143
|
-
// Deploy stack that uses file assets
|
|
144
|
-
await fixture.cdkDeploy('lambda', {
|
|
145
|
-
options: [
|
|
146
|
-
'--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,
|
|
147
|
-
'--toolkit-stack-name', bootstrapStackName,
|
|
148
|
-
],
|
|
149
|
-
});
|
|
150
|
-
}));
|
|
151
|
-
(0, lib_1.integTest)('can create a legacy bootstrap stack with --public-access-block-configuration=false', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
152
|
-
var _a;
|
|
153
|
-
const bootstrapStackName = fixture.bootstrapStackName;
|
|
154
|
-
await fixture.cdkBootstrapLegacy({
|
|
155
|
-
verbose: true,
|
|
156
|
-
toolkitStackName: bootstrapStackName,
|
|
157
|
-
publicAccessBlockConfiguration: false,
|
|
158
|
-
tags: 'Foo=Bar',
|
|
159
|
-
});
|
|
160
|
-
const response = await fixture.aws.cloudFormation.send(new client_cloudformation_1.DescribeStacksCommand({ StackName: bootstrapStackName }));
|
|
161
|
-
expect((_a = response.Stacks) === null || _a === void 0 ? void 0 : _a[0].Tags).toEqual([
|
|
162
|
-
{ Key: 'Foo', Value: 'Bar' },
|
|
163
|
-
]);
|
|
164
|
-
}));
|
|
165
|
-
(0, lib_1.integTest)('can create multiple legacy bootstrap stacks', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
166
|
-
var _a;
|
|
167
|
-
const bootstrapStackName1 = `${fixture.bootstrapStackName}-1`;
|
|
168
|
-
const bootstrapStackName2 = `${fixture.bootstrapStackName}-2`;
|
|
169
|
-
// deploy two toolkit stacks into the same environment (see #1416)
|
|
170
|
-
// one with tags
|
|
171
|
-
await fixture.cdkBootstrapLegacy({
|
|
172
|
-
verbose: true,
|
|
173
|
-
toolkitStackName: bootstrapStackName1,
|
|
174
|
-
tags: 'Foo=Bar',
|
|
175
|
-
});
|
|
176
|
-
await fixture.cdkBootstrapLegacy({
|
|
177
|
-
verbose: true,
|
|
178
|
-
toolkitStackName: bootstrapStackName2,
|
|
179
|
-
});
|
|
180
|
-
const response = await fixture.aws.cloudFormation.send(new client_cloudformation_1.DescribeStacksCommand({ StackName: bootstrapStackName1 }));
|
|
181
|
-
expect((_a = response.Stacks) === null || _a === void 0 ? void 0 : _a[0].Tags).toEqual([
|
|
182
|
-
{ Key: 'Foo', Value: 'Bar' },
|
|
183
|
-
]);
|
|
184
|
-
}));
|
|
185
|
-
(0, lib_1.integTest)('can dump the template, modify and use it to deploy a custom bootstrap stack', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
186
|
-
let template = await fixture.cdkBootstrapModern({
|
|
187
|
-
// toolkitStackName doesn't matter for this particular invocation
|
|
188
|
-
toolkitStackName: fixture.bootstrapStackName,
|
|
189
|
-
showTemplate: true,
|
|
190
|
-
cliOptions: {
|
|
191
|
-
captureStderr: false,
|
|
192
|
-
},
|
|
193
|
-
});
|
|
194
|
-
expect(template).toContain('BootstrapVersion:');
|
|
195
|
-
template += '\n' + [
|
|
196
|
-
' TwiddleDee:',
|
|
197
|
-
' Value: Template got twiddled',
|
|
198
|
-
].join('\n');
|
|
199
|
-
const filename = path.join(fixture.integTestDir, `${fixture.qualifier}-template.yaml`);
|
|
200
|
-
fs.writeFileSync(filename, template, { encoding: 'utf-8' });
|
|
201
|
-
await fixture.cdkBootstrapModern({
|
|
202
|
-
toolkitStackName: fixture.bootstrapStackName,
|
|
203
|
-
template: filename,
|
|
204
|
-
cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
|
|
205
|
-
});
|
|
206
|
-
}));
|
|
207
|
-
(0, lib_1.integTest)('a customized template vendor will not overwrite the default template', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
208
|
-
// Initial bootstrap
|
|
209
|
-
const toolkitStackName = fixture.bootstrapStackName;
|
|
210
|
-
await fixture.cdkBootstrapModern({
|
|
211
|
-
toolkitStackName,
|
|
212
|
-
cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
|
|
213
|
-
});
|
|
214
|
-
// Customize template
|
|
215
|
-
const templateStr = await fixture.cdkBootstrapModern({
|
|
216
|
-
// toolkitStackName doesn't matter for this particular invocation
|
|
217
|
-
toolkitStackName,
|
|
218
|
-
showTemplate: true,
|
|
219
|
-
cliOptions: {
|
|
220
|
-
captureStderr: false,
|
|
221
|
-
},
|
|
222
|
-
});
|
|
223
|
-
const template = yaml.parse(templateStr, { schema: 'core' });
|
|
224
|
-
template.Parameters.BootstrapVariant.Default = 'CustomizedVendor';
|
|
225
|
-
const filename = path.join(fixture.integTestDir, `${fixture.qualifier}-template.yaml`);
|
|
226
|
-
fs.writeFileSync(filename, yaml.stringify(template, { schema: 'yaml-1.1' }), { encoding: 'utf-8' });
|
|
227
|
-
// Rebootstrap. For some reason, this doesn't cause a failure, it's a successful no-op.
|
|
228
|
-
const output = await fixture.cdkBootstrapModern({
|
|
229
|
-
toolkitStackName,
|
|
230
|
-
template: filename,
|
|
231
|
-
cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
|
|
232
|
-
cliOptions: {
|
|
233
|
-
captureStderr: true,
|
|
234
|
-
},
|
|
235
|
-
});
|
|
236
|
-
expect(output).toContain('Not overwriting it with a template containing');
|
|
237
|
-
}));
|
|
238
|
-
(0, lib_1.integTest)('can use the default permissions boundary to bootstrap', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
239
|
-
let template = await fixture.cdkBootstrapModern({
|
|
240
|
-
// toolkitStackName doesn't matter for this particular invocation
|
|
241
|
-
toolkitStackName: fixture.bootstrapStackName,
|
|
242
|
-
showTemplate: true,
|
|
243
|
-
examplePermissionsBoundary: true,
|
|
244
|
-
});
|
|
245
|
-
expect(template).toContain('PermissionsBoundary');
|
|
246
|
-
}));
|
|
247
|
-
(0, lib_1.integTest)('can use the custom permissions boundary to bootstrap', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
248
|
-
let template = await fixture.cdkBootstrapModern({
|
|
249
|
-
// toolkitStackName doesn't matter for this particular invocation
|
|
250
|
-
toolkitStackName: fixture.bootstrapStackName,
|
|
251
|
-
showTemplate: true,
|
|
252
|
-
customPermissionsBoundary: 'permission-boundary-name',
|
|
253
|
-
});
|
|
254
|
-
expect(template).toContain('permission-boundary-name');
|
|
255
|
-
}));
|
|
256
|
-
(0, lib_1.integTest)('can use the custom permissions boundary (with slashes) to bootstrap', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
257
|
-
let template = await fixture.cdkBootstrapModern({
|
|
258
|
-
// toolkitStackName doesn't matter for this particular invocation
|
|
259
|
-
toolkitStackName: fixture.bootstrapStackName,
|
|
260
|
-
showTemplate: true,
|
|
261
|
-
customPermissionsBoundary: 'permission-boundary-name/with/path',
|
|
262
|
-
});
|
|
263
|
-
expect(template).toContain('permission-boundary-name/with/path');
|
|
264
|
-
}));
|
|
265
|
-
(0, lib_1.integTest)('can remove customPermissionsBoundary', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
266
|
-
var _a, _b, _c;
|
|
267
|
-
const bootstrapStackName = fixture.bootstrapStackName;
|
|
268
|
-
const policyName = `${bootstrapStackName}-pb`;
|
|
269
|
-
let policyArn;
|
|
270
|
-
try {
|
|
271
|
-
const policy = await fixture.aws.iam.send(new client_iam_1.CreatePolicyCommand({
|
|
272
|
-
PolicyName: policyName,
|
|
273
|
-
PolicyDocument: JSON.stringify({
|
|
274
|
-
Version: '2012-10-17',
|
|
275
|
-
Statement: {
|
|
276
|
-
Action: ['*'],
|
|
277
|
-
Resource: ['*'],
|
|
278
|
-
Effect: 'Allow',
|
|
279
|
-
},
|
|
280
|
-
}),
|
|
281
|
-
}));
|
|
282
|
-
policyArn = (_a = policy.Policy) === null || _a === void 0 ? void 0 : _a.Arn;
|
|
283
|
-
// Policy creation and consistency across regions is "almost immediate"
|
|
284
|
-
// See: https://docs.aws.amazon.com/IAM/latest/UserGuide/troubleshoot_general.html#troubleshoot_general_eventual-consistency
|
|
285
|
-
// We will put this in an `eventually` block to retry stack creation with a reasonable timeout
|
|
286
|
-
const createStackWithPermissionBoundary = async () => {
|
|
287
|
-
var _a, _b;
|
|
288
|
-
await fixture.cdkBootstrapModern({
|
|
289
|
-
// toolkitStackName doesn't matter for this particular invocation
|
|
290
|
-
toolkitStackName: bootstrapStackName,
|
|
291
|
-
customPermissionsBoundary: policyName,
|
|
292
|
-
});
|
|
293
|
-
const response = await fixture.aws.cloudFormation.send(new client_cloudformation_1.DescribeStacksCommand({ StackName: bootstrapStackName }));
|
|
294
|
-
expect((_b = (_a = response.Stacks) === null || _a === void 0 ? void 0 : _a[0].Parameters) === null || _b === void 0 ? void 0 : _b.some(param => (param.ParameterKey === 'InputPermissionsBoundary' && param.ParameterValue === policyName))).toEqual(true);
|
|
295
|
-
};
|
|
296
|
-
await (0, eventually_1.default)(createStackWithPermissionBoundary, { maxAttempts: 3 });
|
|
297
|
-
await fixture.cdkBootstrapModern({
|
|
298
|
-
// toolkitStackName doesn't matter for this particular invocation
|
|
299
|
-
toolkitStackName: bootstrapStackName,
|
|
300
|
-
usePreviousParameters: false,
|
|
301
|
-
});
|
|
302
|
-
const response2 = await fixture.aws.cloudFormation.send(new client_cloudformation_1.DescribeStacksCommand({ StackName: bootstrapStackName }));
|
|
303
|
-
expect((_c = (_b = response2.Stacks) === null || _b === void 0 ? void 0 : _b[0].Parameters) === null || _c === void 0 ? void 0 : _c.some(param => (param.ParameterKey === 'InputPermissionsBoundary' && !param.ParameterValue))).toEqual(true);
|
|
304
|
-
const region = fixture.aws.region;
|
|
305
|
-
const account = await fixture.aws.account();
|
|
306
|
-
const role = await fixture.aws.iam.send(new client_iam_1.GetRoleCommand({ RoleName: `cdk-${fixture.qualifier}-cfn-exec-role-${account}-${region}` }));
|
|
307
|
-
if (!role.Role) {
|
|
308
|
-
throw new Error('Role not found');
|
|
309
|
-
}
|
|
310
|
-
expect(role.Role.PermissionsBoundary).toBeUndefined();
|
|
311
|
-
}
|
|
312
|
-
finally {
|
|
313
|
-
if (policyArn) {
|
|
314
|
-
await fixture.aws.iam.send(new client_iam_1.DeletePolicyCommand({ PolicyArn: policyArn }));
|
|
315
|
-
}
|
|
316
|
-
}
|
|
317
|
-
}));
|
|
318
|
-
(0, lib_1.integTest)('switch on termination protection, switch is left alone on re-bootstrap', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
319
|
-
var _a;
|
|
320
|
-
const bootstrapStackName = fixture.bootstrapStackName;
|
|
321
|
-
await fixture.cdkBootstrapModern({
|
|
322
|
-
verbose: true,
|
|
323
|
-
toolkitStackName: bootstrapStackName,
|
|
324
|
-
terminationProtection: true,
|
|
325
|
-
cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
|
|
326
|
-
});
|
|
327
|
-
await fixture.cdkBootstrapModern({
|
|
328
|
-
verbose: true,
|
|
329
|
-
toolkitStackName: bootstrapStackName,
|
|
330
|
-
force: true,
|
|
331
|
-
});
|
|
332
|
-
const response = await fixture.aws.cloudFormation.send(new client_cloudformation_1.DescribeStacksCommand({ StackName: bootstrapStackName }));
|
|
333
|
-
expect((_a = response.Stacks) === null || _a === void 0 ? void 0 : _a[0].EnableTerminationProtection).toEqual(true);
|
|
334
|
-
}));
|
|
335
|
-
(0, lib_1.integTest)('add tags, left alone on re-bootstrap', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
336
|
-
var _a;
|
|
337
|
-
const bootstrapStackName = fixture.bootstrapStackName;
|
|
338
|
-
await fixture.cdkBootstrapModern({
|
|
339
|
-
verbose: true,
|
|
340
|
-
toolkitStackName: bootstrapStackName,
|
|
341
|
-
tags: 'Foo=Bar',
|
|
342
|
-
cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
|
|
343
|
-
});
|
|
344
|
-
await fixture.cdkBootstrapModern({
|
|
345
|
-
verbose: true,
|
|
346
|
-
toolkitStackName: bootstrapStackName,
|
|
347
|
-
force: true,
|
|
348
|
-
});
|
|
349
|
-
const response = await fixture.aws.cloudFormation.send(new client_cloudformation_1.DescribeStacksCommand({ StackName: bootstrapStackName }));
|
|
350
|
-
expect((_a = response.Stacks) === null || _a === void 0 ? void 0 : _a[0].Tags).toEqual([
|
|
351
|
-
{ Key: 'Foo', Value: 'Bar' },
|
|
352
|
-
]);
|
|
353
|
-
}));
|
|
354
|
-
(0, lib_1.integTest)('can add tags then update tags during re-bootstrap', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
355
|
-
var _a;
|
|
356
|
-
const bootstrapStackName = fixture.bootstrapStackName;
|
|
357
|
-
await fixture.cdkBootstrapModern({
|
|
358
|
-
verbose: true,
|
|
359
|
-
toolkitStackName: bootstrapStackName,
|
|
360
|
-
tags: 'Foo=Bar',
|
|
361
|
-
cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
|
|
362
|
-
});
|
|
363
|
-
await fixture.cdkBootstrapModern({
|
|
364
|
-
verbose: true,
|
|
365
|
-
toolkitStackName: bootstrapStackName,
|
|
366
|
-
tags: 'Foo=BarBaz',
|
|
367
|
-
cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
|
|
368
|
-
force: true,
|
|
369
|
-
});
|
|
370
|
-
const response = await fixture.aws.cloudFormation.send(new client_cloudformation_1.DescribeStacksCommand({ StackName: bootstrapStackName }));
|
|
371
|
-
expect((_a = response.Stacks) === null || _a === void 0 ? void 0 : _a[0].Tags).toEqual([
|
|
372
|
-
{ Key: 'Foo', Value: 'BarBaz' },
|
|
373
|
-
]);
|
|
374
|
-
}));
|
|
375
|
-
(0, lib_1.integTest)('can deploy modern-synthesized stack even if bootstrap stack name is unknown', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
376
|
-
const bootstrapStackName = fixture.bootstrapStackName;
|
|
377
|
-
await fixture.cdkBootstrapModern({
|
|
378
|
-
toolkitStackName: bootstrapStackName,
|
|
379
|
-
cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
|
|
380
|
-
});
|
|
381
|
-
// Deploy stack that uses file assets
|
|
382
|
-
await fixture.cdkDeploy('lambda', {
|
|
383
|
-
options: [
|
|
384
|
-
// Explicity pass a name that's sure to not exist, otherwise the CLI might accidentally find a
|
|
385
|
-
// default bootstracp stack if that happens to be in the account already.
|
|
386
|
-
'--toolkit-stack-name', 'DefinitelyDoesNotExist',
|
|
387
|
-
'--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,
|
|
388
|
-
'--context', '@aws-cdk/core:newStyleStackSynthesis=1',
|
|
389
|
-
],
|
|
390
|
-
});
|
|
391
|
-
}));
|
|
392
|
-
(0, lib_1.integTest)('create ECR with tag IMMUTABILITY to set on', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
393
|
-
var _a, _b, _c;
|
|
394
|
-
const bootstrapStackName = fixture.bootstrapStackName;
|
|
395
|
-
await fixture.cdkBootstrapModern({
|
|
396
|
-
verbose: true,
|
|
397
|
-
toolkitStackName: bootstrapStackName,
|
|
398
|
-
});
|
|
399
|
-
const response = await fixture.aws.cloudFormation.send(new client_cloudformation_1.DescribeStackResourcesCommand({
|
|
400
|
-
StackName: bootstrapStackName,
|
|
401
|
-
}));
|
|
402
|
-
const ecrResource = (_a = response.StackResources) === null || _a === void 0 ? void 0 : _a.find(resource => resource.LogicalResourceId === 'ContainerAssetsRepository');
|
|
403
|
-
expect(ecrResource).toBeDefined();
|
|
404
|
-
const ecrResponse = await fixture.aws.ecr.send(new client_ecr_1.DescribeRepositoriesCommand({
|
|
405
|
-
repositoryNames: [
|
|
406
|
-
// This is set, as otherwise we don't end up here
|
|
407
|
-
(_b = ecrResource === null || ecrResource === void 0 ? void 0 : ecrResource.PhysicalResourceId) !== null && _b !== void 0 ? _b : '',
|
|
408
|
-
],
|
|
409
|
-
}));
|
|
410
|
-
expect((_c = ecrResponse.repositories) === null || _c === void 0 ? void 0 : _c[0].imageTagMutability).toEqual('IMMUTABLE');
|
|
411
|
-
}));
|
|
412
|
-
(0, lib_1.integTest)('can remove trusted account', (0, lib_1.withoutBootstrap)(async (fixture) => {
|
|
413
|
-
var _a, _b, _c;
|
|
414
|
-
const bootstrapStackName = fixture.bootstrapStackName;
|
|
415
|
-
await fixture.cdkBootstrapModern({
|
|
416
|
-
verbose: false,
|
|
417
|
-
toolkitStackName: bootstrapStackName,
|
|
418
|
-
cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',
|
|
419
|
-
trust: ['599757620138', '730170552321'],
|
|
420
|
-
});
|
|
421
|
-
await fixture.cdkBootstrapModern({
|
|
422
|
-
verbose: true,
|
|
423
|
-
toolkitStackName: bootstrapStackName,
|
|
424
|
-
cfnExecutionPolicy: ' arn:aws:iam::aws:policy/AdministratorAccess',
|
|
425
|
-
untrust: ['730170552321'],
|
|
426
|
-
});
|
|
427
|
-
const response = await fixture.aws.cloudFormation.send(new client_cloudformation_1.DescribeStacksCommand({ StackName: bootstrapStackName }));
|
|
428
|
-
const trustedAccounts = (_c = (_b = (_a = response.Stacks) === null || _a === void 0 ? void 0 : _a[0].Parameters) === null || _b === void 0 ? void 0 : _b.find(p => p.ParameterKey === 'TrustedAccounts')) === null || _c === void 0 ? void 0 : _c.ParameterValue;
|
|
429
|
-
expect(trustedAccounts).toEqual('599757620138');
|
|
430
|
-
}));
|
|
431
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bootstrapping.integtest.js","sourceRoot":"","sources":["bootstrapping.integtest.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @cdklabs/no-literal-partition */\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { DescribeStackResourcesCommand, DescribeStacksCommand } from '@aws-sdk/client-cloudformation';\nimport { DescribeRepositoriesCommand } from '@aws-sdk/client-ecr';\nimport { CreatePolicyCommand, DeletePolicyCommand, GetRoleCommand } from '@aws-sdk/client-iam';\nimport * as yaml from 'yaml';\nimport { integTest, randomString, withoutBootstrap } from '../../lib';\nimport eventually from '../../lib/eventually';\n\njest.setTimeout(2 * 60 * 60_000); // Includes the time to acquire locks, worst-case single-threaded runtime\n\nintegTest('can bootstrap without execution', withoutBootstrap(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.send(\n    new DescribeStacksCommand({\n      StackName: bootstrapStackName,\n    }),\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', withoutBootstrap(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: [\n      '--context', `bootstrapBucket=${legacyBootstrapBucketName}`,\n      '--context', 'legacySynth=true',\n      '--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,\n      '--toolkit-stack-name', bootstrapStackName,\n    ],\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      '--context', `bootstrapBucket=${newBootstrapBucketName}`,\n      '--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,\n      '--toolkit-stack-name', bootstrapStackName,\n      '--force',\n    ],\n  });\n}));\n\nintegTest('can and deploy if omitting execution policies', withoutBootstrap(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('can deploy with session tags on the deploy, lookup, file asset, and image asset publishing roles', withoutBootstrap(async (fixture) => {\n  const bootstrapStackName = fixture.bootstrapStackName;\n\n  await fixture.cdkBootstrapModern({\n    toolkitStackName: bootstrapStackName,\n    bootstrapTemplate: path.join(__dirname, '..', '..', 'resources', 'bootstrap-templates', 'session-tags.all-roles-deny-all.yaml'),\n  });\n\n  await fixture.cdkDeploy('session-tags', {\n    options: [\n      '--toolkit-stack-name', bootstrapStackName,\n      '--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,\n      '--context', '@aws-cdk/core:newStyleStackSynthesis=1',\n    ],\n    modEnv: {\n      ENABLE_VPC_TESTING: 'IMPORT',\n    },\n  });\n}));\n\nintegTest('can deploy without execution role and with session tags on deploy role', withoutBootstrap(async (fixture) => {\n  const bootstrapStackName = fixture.bootstrapStackName;\n\n  await fixture.cdkBootstrapModern({\n    toolkitStackName: bootstrapStackName,\n    bootstrapTemplate: path.join(__dirname, '..', '..', 'resources', 'bootstrap-templates', 'session-tags.deploy-role-deny-sqs.yaml'),\n  });\n\n  await fixture.cdkDeploy('session-tags-with-custom-synthesizer', {\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', withoutBootstrap(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)', withoutBootstrap(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', withoutBootstrap(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      '--context', `@aws-cdk/core:bootstrapQualifier=${fixture.qualifier}`,\n      '--toolkit-stack-name', bootstrapStackName,\n    ],\n  });\n}));\n\nintegTest('can create a legacy bootstrap stack with --public-access-block-configuration=false', withoutBootstrap(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.send(new DescribeStacksCommand({ StackName: bootstrapStackName }));\n  expect(response.Stacks?.[0].Tags).toEqual([\n    { Key: 'Foo', Value: 'Bar' },\n  ]);\n}));\n\nintegTest('can create multiple legacy bootstrap stacks', withoutBootstrap(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.send(new DescribeStacksCommand({ 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', withoutBootstrap(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('a customized template vendor will not overwrite the default template', withoutBootstrap(async (fixture) => {\n  // Initial bootstrap\n  const toolkitStackName = fixture.bootstrapStackName;\n  await fixture.cdkBootstrapModern({\n    toolkitStackName,\n    cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',\n  });\n\n  // Customize template\n  const templateStr = await fixture.cdkBootstrapModern({\n    // toolkitStackName doesn't matter for this particular invocation\n    toolkitStackName,\n    showTemplate: true,\n    cliOptions: {\n      captureStderr: false,\n    },\n  });\n\n  const template = yaml.parse(templateStr, { schema: 'core' });\n  template.Parameters.BootstrapVariant.Default = 'CustomizedVendor';\n  const filename = path.join(fixture.integTestDir, `${fixture.qualifier}-template.yaml`);\n  fs.writeFileSync(filename, yaml.stringify(template, { schema: 'yaml-1.1' }), { encoding: 'utf-8' });\n\n  // Rebootstrap. For some reason, this doesn't cause a failure, it's a successful no-op.\n  const output = await fixture.cdkBootstrapModern({\n    toolkitStackName,\n    template: filename,\n    cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',\n    cliOptions: {\n      captureStderr: true,\n    },\n  });\n  expect(output).toContain('Not overwriting it with a template containing');\n}));\n\nintegTest('can use the default permissions boundary to bootstrap', withoutBootstrap(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    examplePermissionsBoundary: true,\n  });\n\n  expect(template).toContain('PermissionsBoundary');\n}));\n\nintegTest('can use the custom permissions boundary to bootstrap', withoutBootstrap(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    customPermissionsBoundary: 'permission-boundary-name',\n  });\n\n  expect(template).toContain('permission-boundary-name');\n}));\n\nintegTest('can use the custom permissions boundary (with slashes) to bootstrap', withoutBootstrap(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    customPermissionsBoundary: 'permission-boundary-name/with/path',\n  });\n\n  expect(template).toContain('permission-boundary-name/with/path');\n}));\n\nintegTest('can remove customPermissionsBoundary', withoutBootstrap(async (fixture) => {\n  const bootstrapStackName = fixture.bootstrapStackName;\n  const policyName = `${bootstrapStackName}-pb`;\n  let policyArn;\n  try {\n    const policy = await fixture.aws.iam.send(\n      new CreatePolicyCommand({\n        PolicyName: policyName,\n        PolicyDocument: JSON.stringify({\n          Version: '2012-10-17',\n          Statement: {\n            Action: ['*'],\n            Resource: ['*'],\n            Effect: 'Allow',\n          },\n        }),\n      }),\n    );\n    policyArn = policy.Policy?.Arn;\n\n    // Policy creation and consistency across regions is \"almost immediate\"\n    // See: https://docs.aws.amazon.com/IAM/latest/UserGuide/troubleshoot_general.html#troubleshoot_general_eventual-consistency\n    // We will put this in an `eventually` block to retry stack creation with a reasonable timeout\n    const createStackWithPermissionBoundary = async (): Promise<void> => {\n      await fixture.cdkBootstrapModern({\n        // toolkitStackName doesn't matter for this particular invocation\n        toolkitStackName: bootstrapStackName,\n        customPermissionsBoundary: policyName,\n      });\n\n      const response = await fixture.aws.cloudFormation.send(\n        new DescribeStacksCommand({ StackName: bootstrapStackName }),\n      );\n      expect(\n        response.Stacks?.[0].Parameters?.some(\n          param => (param.ParameterKey === 'InputPermissionsBoundary' && param.ParameterValue === policyName),\n        )).toEqual(true);\n    };\n\n    await eventually(createStackWithPermissionBoundary, { maxAttempts: 3 });\n\n    await fixture.cdkBootstrapModern({\n      // toolkitStackName doesn't matter for this particular invocation\n      toolkitStackName: bootstrapStackName,\n      usePreviousParameters: false,\n    });\n    const response2 = await fixture.aws.cloudFormation.send(\n      new DescribeStacksCommand({ StackName: bootstrapStackName }),\n    );\n    expect(\n      response2.Stacks?.[0].Parameters?.some(\n        param => (param.ParameterKey === 'InputPermissionsBoundary' && !param.ParameterValue),\n      )).toEqual(true);\n\n    const region = fixture.aws.region;\n    const account = await fixture.aws.account();\n    const role = await fixture.aws.iam.send(\n      new GetRoleCommand({ RoleName: `cdk-${fixture.qualifier}-cfn-exec-role-${account}-${region}` }),\n    );\n    if (!role.Role) {\n      throw new Error('Role not found');\n    }\n    expect(role.Role.PermissionsBoundary).toBeUndefined();\n  } finally {\n    if (policyArn) {\n      await fixture.aws.iam.send(new DeletePolicyCommand({ PolicyArn: policyArn }));\n    }\n  }\n}));\n\nintegTest('switch on termination protection, switch is left alone on re-bootstrap', withoutBootstrap(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.send(new DescribeStacksCommand({ StackName: bootstrapStackName }));\n  expect(response.Stacks?.[0].EnableTerminationProtection).toEqual(true);\n}));\n\nintegTest('add tags, left alone on re-bootstrap', withoutBootstrap(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.send(new DescribeStacksCommand({ StackName: bootstrapStackName }));\n  expect(response.Stacks?.[0].Tags).toEqual([\n    { Key: 'Foo', Value: 'Bar' },\n  ]);\n}));\n\nintegTest('can add tags then update tags during re-bootstrap', withoutBootstrap(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    tags: 'Foo=BarBaz',\n    cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',\n    force: true,\n  });\n\n  const response = await fixture.aws.cloudFormation.send(new DescribeStacksCommand({ StackName: bootstrapStackName }));\n  expect(response.Stacks?.[0].Tags).toEqual([\n    { Key: 'Foo', Value: 'BarBaz' },\n  ]);\n}));\n\nintegTest('can deploy modern-synthesized stack even if bootstrap stack name is unknown', withoutBootstrap(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\nintegTest('create ECR with tag IMMUTABILITY to set on', withoutBootstrap(async (fixture) => {\n  const bootstrapStackName = fixture.bootstrapStackName;\n\n  await fixture.cdkBootstrapModern({\n    verbose: true,\n    toolkitStackName: bootstrapStackName,\n  });\n\n  const response = await fixture.aws.cloudFormation.send(\n    new DescribeStackResourcesCommand({\n      StackName: bootstrapStackName,\n    }),\n  );\n  const ecrResource = response.StackResources?.find(resource => resource.LogicalResourceId === 'ContainerAssetsRepository');\n  expect(ecrResource).toBeDefined();\n\n  const ecrResponse = await fixture.aws.ecr.send(\n    new DescribeRepositoriesCommand({\n      repositoryNames: [\n        // This is set, as otherwise we don't end up here\n        ecrResource?.PhysicalResourceId ?? '',\n      ],\n    }),\n  );\n\n  expect(ecrResponse.repositories?.[0].imageTagMutability).toEqual('IMMUTABLE');\n}));\n\nintegTest('can remove trusted account', withoutBootstrap(async (fixture) => {\n  const bootstrapStackName = fixture.bootstrapStackName;\n\n  await fixture.cdkBootstrapModern({\n    verbose: false,\n    toolkitStackName: bootstrapStackName,\n    cfnExecutionPolicy: 'arn:aws:iam::aws:policy/AdministratorAccess',\n    trust: ['599757620138', '730170552321'],\n  });\n\n  await fixture.cdkBootstrapModern({\n    verbose: true,\n    toolkitStackName: bootstrapStackName,\n    cfnExecutionPolicy: ' arn:aws:iam::aws:policy/AdministratorAccess',\n    untrust: ['730170552321'],\n  });\n\n  const response = await fixture.aws.cloudFormation.send(\n    new DescribeStacksCommand({ StackName: bootstrapStackName }),\n  );\n\n  const trustedAccounts = response.Stacks?.[0].Parameters?.find(p => p.ParameterKey === 'TrustedAccounts')?.ParameterValue;\n  expect(trustedAccounts).toEqual('599757620138');\n}));\n\n"]}
|