@aws-cdk/integ-runner 2.174.0-alpha.0 → 2.175.0-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -50,6 +50,8 @@
|
|
|
50
50
|
"@aws-cdk/aws-ecs:removeDefaultDeploymentAlarm": true,
|
|
51
51
|
"@aws-cdk/custom-resources:logApiResponseDataPropertyTrueDefault": false,
|
|
52
52
|
"@aws-cdk/aws-s3:keepNotificationInImportedBucket": false,
|
|
53
|
+
"@aws-cdk/aws-ecs:enableImdsBlockingDeprecatedFeature": false,
|
|
54
|
+
"@aws-cdk/aws-ecs:disableEcsImdsBlocking": true,
|
|
53
55
|
"@aws-cdk/aws-ecs:reduceEc2FargateCloudWatchPermissions": true,
|
|
54
56
|
"@aws-cdk/aws-dynamodb:resourcePolicyPerReplica": true,
|
|
55
57
|
"@aws-cdk/aws-ec2:ec2SumTImeoutEnabled": true,
|
|
@@ -212,6 +212,69 @@ export declare const DEFAULT_SYNTH_OPTIONS: {
|
|
|
212
212
|
/**
|
|
213
213
|
* Return the currently recommended flags for `aws-cdk-lib`.
|
|
214
214
|
*
|
|
215
|
-
* These have been built into the CLI at build time.
|
|
215
|
+
* These have been built into the CLI at build time. If this ever gets changed
|
|
216
|
+
* back to a dynamic load, remember that this source file may be bundled into
|
|
217
|
+
* a JavaScript bundle, and `__dirname` might not point where you think it does.
|
|
216
218
|
*/
|
|
217
|
-
export declare function currentlyRecommendedAwsCdkLibFlags():
|
|
219
|
+
export declare function currentlyRecommendedAwsCdkLibFlags(): {
|
|
220
|
+
"@aws-cdk/aws-lambda:recognizeLayerVersion": boolean;
|
|
221
|
+
"@aws-cdk/core:checkSecretUsage": boolean;
|
|
222
|
+
"@aws-cdk/core:target-partitions": string[];
|
|
223
|
+
"@aws-cdk-containers/ecs-service-extensions:enableDefaultLogDriver": boolean;
|
|
224
|
+
"@aws-cdk/aws-ec2:uniqueImdsv2TemplateName": boolean;
|
|
225
|
+
"@aws-cdk/aws-ecs:arnFormatIncludesClusterName": boolean;
|
|
226
|
+
"@aws-cdk/aws-iam:minimizePolicies": boolean;
|
|
227
|
+
"@aws-cdk/core:validateSnapshotRemovalPolicy": boolean;
|
|
228
|
+
"@aws-cdk/aws-codepipeline:crossAccountKeyAliasStackSafeResourceName": boolean;
|
|
229
|
+
"@aws-cdk/aws-s3:createDefaultLoggingPolicy": boolean;
|
|
230
|
+
"@aws-cdk/aws-sns-subscriptions:restrictSqsDescryption": boolean;
|
|
231
|
+
"@aws-cdk/aws-apigateway:disableCloudWatchRole": boolean;
|
|
232
|
+
"@aws-cdk/core:enablePartitionLiterals": boolean;
|
|
233
|
+
"@aws-cdk/aws-events:eventsTargetQueueSameAccount": boolean;
|
|
234
|
+
"@aws-cdk/aws-ecs:disableExplicitDeploymentControllerForCircuitBreaker": boolean;
|
|
235
|
+
"@aws-cdk/aws-iam:importedRoleStackSafeDefaultPolicyName": boolean;
|
|
236
|
+
"@aws-cdk/aws-s3:serverAccessLogsUseBucketPolicy": boolean;
|
|
237
|
+
"@aws-cdk/aws-route53-patters:useCertificate": boolean;
|
|
238
|
+
"@aws-cdk/customresources:installLatestAwsSdkDefault": boolean;
|
|
239
|
+
"@aws-cdk/aws-rds:databaseProxyUniqueResourceName": boolean;
|
|
240
|
+
"@aws-cdk/aws-codedeploy:removeAlarmsFromDeploymentGroup": boolean;
|
|
241
|
+
"@aws-cdk/aws-apigateway:authorizerChangeDeploymentLogicalId": boolean;
|
|
242
|
+
"@aws-cdk/aws-ec2:launchTemplateDefaultUserData": boolean;
|
|
243
|
+
"@aws-cdk/aws-secretsmanager:useAttachedSecretResourcePolicyForSecretTargetAttachments": boolean;
|
|
244
|
+
"@aws-cdk/aws-redshift:columnId": boolean;
|
|
245
|
+
"@aws-cdk/aws-stepfunctions-tasks:enableEmrServicePolicyV2": boolean;
|
|
246
|
+
"@aws-cdk/aws-ec2:restrictDefaultSecurityGroup": boolean;
|
|
247
|
+
"@aws-cdk/aws-apigateway:requestValidatorUniqueId": boolean;
|
|
248
|
+
"@aws-cdk/aws-kms:aliasNameRef": boolean;
|
|
249
|
+
"@aws-cdk/aws-autoscaling:generateLaunchTemplateInsteadOfLaunchConfig": boolean;
|
|
250
|
+
"@aws-cdk/core:includePrefixInUniqueNameGeneration": boolean;
|
|
251
|
+
"@aws-cdk/aws-efs:denyAnonymousAccess": boolean;
|
|
252
|
+
"@aws-cdk/aws-opensearchservice:enableOpensearchMultiAzWithStandby": boolean;
|
|
253
|
+
"@aws-cdk/aws-lambda-nodejs:useLatestRuntimeVersion": boolean;
|
|
254
|
+
"@aws-cdk/aws-efs:mountTargetOrderInsensitiveLogicalId": boolean;
|
|
255
|
+
"@aws-cdk/aws-rds:auroraClusterChangeScopeOfInstanceParameterGroupWithEachParameters": boolean;
|
|
256
|
+
"@aws-cdk/aws-appsync:useArnForSourceApiAssociationIdentifier": boolean;
|
|
257
|
+
"@aws-cdk/aws-rds:preventRenderingDeprecatedCredentials": boolean;
|
|
258
|
+
"@aws-cdk/aws-codepipeline-actions:useNewDefaultBranchForCodeCommitSource": boolean;
|
|
259
|
+
"@aws-cdk/aws-cloudwatch-actions:changeLambdaPermissionLogicalIdForLambdaAction": boolean;
|
|
260
|
+
"@aws-cdk/aws-codepipeline:crossAccountKeysDefaultValueToFalse": boolean;
|
|
261
|
+
"@aws-cdk/aws-codepipeline:defaultPipelineTypeToV2": boolean;
|
|
262
|
+
"@aws-cdk/aws-kms:reduceCrossAccountRegionPolicyScope": boolean;
|
|
263
|
+
"@aws-cdk/aws-eks:nodegroupNameAttribute": boolean;
|
|
264
|
+
"@aws-cdk/aws-ec2:ebsDefaultGp3Volume": boolean;
|
|
265
|
+
"@aws-cdk/aws-ecs:removeDefaultDeploymentAlarm": boolean;
|
|
266
|
+
"@aws-cdk/custom-resources:logApiResponseDataPropertyTrueDefault": boolean;
|
|
267
|
+
"@aws-cdk/aws-s3:keepNotificationInImportedBucket": boolean;
|
|
268
|
+
"@aws-cdk/aws-ecs:enableImdsBlockingDeprecatedFeature": boolean;
|
|
269
|
+
"@aws-cdk/aws-ecs:disableEcsImdsBlocking": boolean;
|
|
270
|
+
"@aws-cdk/aws-ecs:reduceEc2FargateCloudWatchPermissions": boolean;
|
|
271
|
+
"@aws-cdk/aws-dynamodb:resourcePolicyPerReplica": boolean;
|
|
272
|
+
"@aws-cdk/aws-ec2:ec2SumTImeoutEnabled": boolean;
|
|
273
|
+
"@aws-cdk/aws-appsync:appSyncGraphQLAPIScopeLambdaPermission": boolean;
|
|
274
|
+
"@aws-cdk/aws-rds:setCorrectValueForDatabaseInstanceReadReplicaInstanceResourceId": boolean;
|
|
275
|
+
"@aws-cdk/core:cfnIncludeRejectComplexResourceUpdateCreatePolicyIntrinsics": boolean;
|
|
276
|
+
"@aws-cdk/aws-lambda-nodejs:sdkV3ExcludeSmithyPackages": boolean;
|
|
277
|
+
"@aws-cdk/aws-stepfunctions-tasks:fixRunEcsTaskPolicy": boolean;
|
|
278
|
+
"@aws-cdk/aws-ec2:bastionHostUseAmazonLinux2023ByDefault": boolean;
|
|
279
|
+
"@aws-cdk/aws-route53-targets:userPoolDomainNameMethodWithoutCustomResource": boolean;
|
|
280
|
+
};
|
|
@@ -8,6 +8,7 @@ const cdk_cli_wrapper_1 = require("@aws-cdk/cdk-cli-wrapper");
|
|
|
8
8
|
const cx_api_1 = require("@aws-cdk/cx-api");
|
|
9
9
|
const fs = require("fs-extra");
|
|
10
10
|
const integ_test_suite_1 = require("./integ-test-suite");
|
|
11
|
+
const recommendedFlagsFile = require("../recommended-feature-flags.json");
|
|
11
12
|
const utils_1 = require("../utils");
|
|
12
13
|
const cloud_assembly_1 = require("./private/cloud-assembly");
|
|
13
14
|
const DESTRUCTIVE_CHANGES = '!!DESTRUCTIVE_CHANGES:';
|
|
@@ -314,10 +315,11 @@ exports.DEFAULT_SYNTH_OPTIONS = {
|
|
|
314
315
|
/**
|
|
315
316
|
* Return the currently recommended flags for `aws-cdk-lib`.
|
|
316
317
|
*
|
|
317
|
-
* These have been built into the CLI at build time.
|
|
318
|
+
* These have been built into the CLI at build time. If this ever gets changed
|
|
319
|
+
* back to a dynamic load, remember that this source file may be bundled into
|
|
320
|
+
* a JavaScript bundle, and `__dirname` might not point where you think it does.
|
|
318
321
|
*/
|
|
319
322
|
function currentlyRecommendedAwsCdkLibFlags() {
|
|
320
|
-
|
|
321
|
-
return JSON.parse(fs.readFileSync(recommendedFlagsFile, { encoding: 'utf-8' }));
|
|
323
|
+
return recommendedFlagsFile;
|
|
322
324
|
}
|
|
323
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runner-base.js","sourceRoot":"","sources":["runner-base.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @cdklabs/no-literal-partition */\nimport * as path from 'path';\nimport { CdkCliWrapper, ICdk } from '@aws-cdk/cdk-cli-wrapper';\nimport { TestCase, DefaultCdkOptions } from '@aws-cdk/cloud-assembly-schema';\nimport { AVAILABILITY_ZONE_FALLBACK_CONTEXT_KEY, TARGET_PARTITIONS } from '@aws-cdk/cx-api';\nimport * as fs from 'fs-extra';\nimport { IntegTestSuite, LegacyIntegTestSuite } from './integ-test-suite';\nimport { IntegTest } from './integration-tests';\nimport { flatten } from '../utils';\nimport { AssemblyManifestReader, ManifestTrace } from './private/cloud-assembly';\nimport { DestructiveChange } from '../workers/common';\n\nconst DESTRUCTIVE_CHANGES = '!!DESTRUCTIVE_CHANGES:';\n\n/**\n * Options for creating an integration test runner\n */\nexport interface IntegRunnerOptions {\n  /**\n   * Information about the test to run\n   */\n  readonly test: IntegTest;\n\n  /**\n   * The AWS profile to use when invoking the CDK CLI\n   *\n   * @default - no profile is passed, the default profile is used\n   */\n  readonly profile?: string;\n\n  /**\n   * Additional environment variables that will be available\n   * to the CDK CLI\n   *\n   * @default - no additional environment variables\n   */\n  readonly env?: { [name: string]: string };\n\n  /**\n   * tmp cdk.out directory\n   *\n   * @default - directory will be `cdk-integ.out.${testName}`\n   */\n  readonly integOutDir?: string;\n\n  /**\n   * Instance of the CDK CLI to use\n   *\n   * @default - CdkCliWrapper\n   */\n  readonly cdk?: ICdk;\n\n  /**\n   * Show output from running integration tests\n   *\n   * @default false\n   */\n  readonly showOutput?: boolean;\n}\n\n/**\n * The different components of a test name\n */\n/**\n * Represents an Integration test runner\n */\nexport abstract class IntegRunner {\n  /**\n   * The directory where the snapshot will be stored\n   */\n  public readonly snapshotDir: string;\n\n  /**\n   * An instance of the CDK  CLI\n   */\n  public readonly cdk: ICdk;\n\n  /**\n   * Pretty name of the test\n   */\n  public readonly testName: string;\n\n  /**\n   * The value used in the '--app' CLI parameter\n   *\n   * Path to the integ test source file, relative to `this.directory`.\n   */\n  protected readonly cdkApp: string;\n\n  /**\n   * The path where the `cdk.context.json` file\n   * will be created\n   */\n  protected readonly cdkContextPath: string;\n\n  /**\n   * The test suite from the existing snapshot\n   */\n  protected readonly expectedTestSuite?: IntegTestSuite | LegacyIntegTestSuite;\n\n  /**\n   * The test suite from the new \"actual\" snapshot\n   */\n  protected readonly actualTestSuite: IntegTestSuite | LegacyIntegTestSuite;\n\n  /**\n   * The working directory that the integration tests will be\n   * executed from\n   */\n  protected readonly directory: string;\n\n  /**\n   * The test to run\n   */\n  protected readonly test: IntegTest;\n\n  /**\n   * Default options to pass to the CDK CLI\n   */\n  protected readonly defaultArgs: DefaultCdkOptions = {\n    pathMetadata: false,\n    assetMetadata: false,\n    versionReporting: false,\n  };\n\n  /**\n   * The directory where the CDK will be synthed to\n   *\n   * Relative to cwd.\n   */\n  protected readonly cdkOutDir: string;\n\n  protected readonly profile?: string;\n\n  protected _destructiveChanges?: DestructiveChange[];\n  private legacyContext?: Record<string, any>;\n  protected isLegacyTest?: boolean;\n\n  constructor(options: IntegRunnerOptions) {\n    this.test = options.test;\n    this.directory = this.test.directory;\n    this.testName = this.test.testName;\n    this.snapshotDir = this.test.snapshotDir;\n    this.cdkContextPath = path.join(this.directory, 'cdk.context.json');\n\n    this.cdk = options.cdk ?? new CdkCliWrapper({\n      directory: this.directory,\n      showOutput: options.showOutput,\n      env: {\n        ...options.env,\n      },\n    });\n    this.cdkOutDir = options.integOutDir ?? this.test.temporaryOutputDir;\n\n    const testRunCommand = this.test.appCommand;\n    this.cdkApp = testRunCommand.replace('{filePath}', path.relative(this.directory, this.test.fileName));\n\n    this.profile = options.profile;\n    if (this.hasSnapshot()) {\n      this.expectedTestSuite = this.loadManifest();\n    }\n    this.actualTestSuite = this.generateActualSnapshot();\n  }\n\n  /**\n   * Return the list of expected (i.e. existing) test cases for this integration test\n   */\n  public expectedTests(): { [testName: string]: TestCase } | undefined {\n    return this.expectedTestSuite?.testSuite;\n  }\n\n  /**\n   * Return the list of actual (i.e. new) test cases for this integration test\n   */\n  public actualTests(): { [testName: string]: TestCase } | undefined {\n    return this.actualTestSuite.testSuite;\n  }\n\n  /**\n   * Generate a new \"actual\" snapshot which will be compared to the\n   * existing \"expected\" snapshot\n   * This will synth and then load the integration test manifest\n   */\n  public generateActualSnapshot(): IntegTestSuite | LegacyIntegTestSuite {\n    this.cdk.synthFast({\n      execCmd: this.cdkApp.split(' '),\n      env: {\n        ...DEFAULT_SYNTH_OPTIONS.env,\n        // we don't know the \"actual\" context yet (this method is what generates it) so just\n        // use the \"expected\" context. This is only run in order to read the manifest\n        CDK_CONTEXT_JSON: JSON.stringify(this.getContext(this.expectedTestSuite?.synthContext)),\n      },\n      output: path.relative(this.directory, this.cdkOutDir),\n    });\n    const manifest = this.loadManifest(this.cdkOutDir);\n    // after we load the manifest remove the tmp snapshot\n    // so that it doesn't mess up the real snapshot created later\n    this.cleanup();\n    return manifest;\n  }\n\n  /**\n   * Returns true if a snapshot already exists for this test\n   */\n  public hasSnapshot(): boolean {\n    return fs.existsSync(this.snapshotDir);\n  }\n\n  /**\n   * Load the integ manifest which contains information\n   * on how to execute the tests\n   * First we try and load the manifest from the integ manifest (i.e. integ.json)\n   * from the cloud assembly. If it doesn't exist, then we fallback to the\n   * \"legacy mode\" and create a manifest from pragma\n   */\n  protected loadManifest(dir?: string): IntegTestSuite | LegacyIntegTestSuite {\n    try {\n      const testSuite = IntegTestSuite.fromPath(dir ?? this.snapshotDir);\n      return testSuite;\n    } catch {\n      const testCases = LegacyIntegTestSuite.fromLegacy({\n        cdk: this.cdk,\n        testName: this.test.normalizedTestName,\n        integSourceFilePath: this.test.fileName,\n        listOptions: {\n          ...this.defaultArgs,\n          all: true,\n          app: this.cdkApp,\n          profile: this.profile,\n          output: path.relative(this.directory, this.cdkOutDir),\n        },\n      });\n      this.legacyContext = LegacyIntegTestSuite.getPragmaContext(this.test.fileName);\n      this.isLegacyTest = true;\n      return testCases;\n    }\n  }\n\n  protected cleanup(): void {\n    const cdkOutPath = this.cdkOutDir;\n    if (fs.existsSync(cdkOutPath)) {\n      fs.removeSync(cdkOutPath);\n    }\n  }\n\n  /**\n   * If there are any destructive changes to a stack then this will record\n   * those in the manifest.json file\n   */\n  private renderTraceData(): ManifestTrace {\n    const traceData: ManifestTrace = new Map();\n    const destructiveChanges = this._destructiveChanges ?? [];\n    destructiveChanges.forEach(change => {\n      const trace = traceData.get(change.stackName);\n      if (trace) {\n        trace.set(change.logicalId, `${DESTRUCTIVE_CHANGES} ${change.impact}`);\n      } else {\n        traceData.set(change.stackName, new Map([\n          [change.logicalId, `${DESTRUCTIVE_CHANGES} ${change.impact}`],\n        ]));\n      }\n    });\n    return traceData;\n  }\n\n  /**\n   * In cases where we do not want to retain the assets,\n   * for example, if the assets are very large.\n   *\n   * Since it is possible to disable the update workflow for individual test\n   * cases, this needs to first get a list of stacks that have the update workflow\n   * disabled and then delete assets that relate to that stack. It does that\n   * by reading the asset manifest for the stack and deleting the asset source\n   */\n  protected removeAssetsFromSnapshot(): void {\n    const stacks = this.actualTestSuite.getStacksWithoutUpdateWorkflow() ?? [];\n    const manifest = AssemblyManifestReader.fromPath(this.snapshotDir);\n    const assets = flatten(stacks.map(stack => {\n      return manifest.getAssetLocationsForStack(stack) ?? [];\n    }));\n\n    assets.forEach(asset => {\n      const fileName = path.join(this.snapshotDir, asset);\n      if (fs.existsSync(fileName)) {\n        if (fs.lstatSync(fileName).isDirectory()) {\n          fs.removeSync(fileName);\n        } else {\n          fs.unlinkSync(fileName);\n        }\n      }\n    });\n  }\n\n  /**\n   * Remove the asset cache (.cache/) files from the snapshot.\n   * These are a cache of the asset zips, but we are fine with\n   * re-zipping on deploy\n   */\n  protected removeAssetsCacheFromSnapshot(): void {\n    const files = fs.readdirSync(this.snapshotDir);\n    files.forEach(file => {\n      const fileName = path.join(this.snapshotDir, file);\n      if (fs.lstatSync(fileName).isDirectory() && file === '.cache') {\n        fs.emptyDirSync(fileName);\n        fs.rmdirSync(fileName);\n      }\n    });\n  }\n\n  /**\n   * Create the new snapshot.\n   *\n   * If lookups are enabled, then we need create the snapshot by synthing again\n   * with the dummy context so that each time the test is run on different machines\n   * (and with different context/env) the diff will not change.\n   *\n   * If lookups are disabled (which means the stack is env agnostic) then just copy\n   * the assembly that was output by the deployment\n   */\n  protected createSnapshot(): void {\n    if (fs.existsSync(this.snapshotDir)) {\n      fs.removeSync(this.snapshotDir);\n    }\n\n    // if lookups are enabled then we need to synth again\n    // using dummy context and save that as the snapshot\n    if (this.actualTestSuite.enableLookups) {\n      this.cdk.synthFast({\n        execCmd: this.cdkApp.split(' '),\n        env: {\n          ...DEFAULT_SYNTH_OPTIONS.env,\n          CDK_CONTEXT_JSON: JSON.stringify(this.getContext(DEFAULT_SYNTH_OPTIONS.context)),\n        },\n        output: path.relative(this.directory, this.snapshotDir),\n      });\n    } else {\n      fs.moveSync(this.cdkOutDir, this.snapshotDir, { overwrite: true });\n    }\n\n    this.cleanupSnapshot();\n  }\n\n  /**\n   * Perform some cleanup steps after the snapshot is created\n   * Anytime the snapshot needs to be modified after creation\n   * the logic should live here.\n   */\n  private cleanupSnapshot(): void {\n    if (fs.existsSync(this.snapshotDir)) {\n      this.removeAssetsFromSnapshot();\n      this.removeAssetsCacheFromSnapshot();\n      const assembly = AssemblyManifestReader.fromPath(this.snapshotDir);\n      assembly.cleanManifest();\n      assembly.recordTrace(this.renderTraceData());\n    }\n\n    // if this is a legacy test then create an integ manifest\n    // in the snapshot directory which can be used for the\n    // update workflow. Save any legacyContext as well so that it can be read\n    // the next time\n    if (this.actualTestSuite.type === 'legacy-test-suite') {\n      (this.actualTestSuite as LegacyIntegTestSuite).saveManifest(this.snapshotDir, this.legacyContext);\n    }\n  }\n\n  protected getContext(additionalContext?: Record<string, any>): Record<string, any> {\n    return {\n      ...currentlyRecommendedAwsCdkLibFlags(),\n      ...this.legacyContext,\n      ...additionalContext,\n\n      // We originally had PLANNED to set this to ['aws', 'aws-cn'], but due to a programming mistake\n      // it was set to everything. In this PR, set it to everything to not mess up all the snapshots.\n      [TARGET_PARTITIONS]: undefined,\n\n      /* ---------------- THE FUTURE LIVES BELOW----------------------------\n      // Restricting to these target partitions makes most service principals synthesize to\n      // `service.${URL_SUFFIX}`, which is technically *incorrect* (it's only `amazonaws.com`\n      // or `amazonaws.com.cn`, never UrlSuffix for any of the restricted regions) but it's what\n      // most existing integ tests contain, and we want to disturb as few as possible.\n      // [TARGET_PARTITIONS]: ['aws', 'aws-cn'],\n      /* ---------------- END OF THE FUTURE ------------------------------- */\n    };\n  }\n}\n\n// Default context we run all integ tests with, so they don't depend on the\n// account of the exercising user.\nexport const DEFAULT_SYNTH_OPTIONS = {\n  context: {\n    [AVAILABILITY_ZONE_FALLBACK_CONTEXT_KEY]: ['test-region-1a', 'test-region-1b', 'test-region-1c'],\n    'availability-zones:account=12345678:region=test-region': ['test-region-1a', 'test-region-1b', 'test-region-1c'],\n    'ssm:account=12345678:parameterName=/aws/service/ami-amazon-linux-latest/amzn-ami-hvm-x86_64-gp2:region=test-region': 'ami-1234',\n    'ssm:account=12345678:parameterName=/aws/service/ami-amazon-linux-latest/amzn2-ami-hvm-x86_64-gp2:region=test-region': 'ami-1234',\n    'ssm:account=12345678:parameterName=/aws/service/ecs/optimized-ami/amazon-linux/recommended:region=test-region': '{\"image_id\": \"ami-1234\"}',\n    // eslint-disable-next-line max-len\n    'ami:account=12345678:filters.image-type.0=machine:filters.name.0=amzn-ami-vpc-nat-*:filters.state.0=available:owners.0=amazon:region=test-region': 'ami-1234',\n    'vpc-provider:account=12345678:filter.isDefault=true:region=test-region:returnAsymmetricSubnets=true': {\n      vpcId: 'vpc-60900905',\n      subnetGroups: [\n        {\n          type: 'Public',\n          name: 'Public',\n          subnets: [\n            {\n              subnetId: 'subnet-e19455ca',\n              availabilityZone: 'us-east-1a',\n              routeTableId: 'rtb-e19455ca',\n            },\n            {\n              subnetId: 'subnet-e0c24797',\n              availabilityZone: 'us-east-1b',\n              routeTableId: 'rtb-e0c24797',\n            },\n            {\n              subnetId: 'subnet-ccd77395',\n              availabilityZone: 'us-east-1c',\n              routeTableId: 'rtb-ccd77395',\n            },\n          ],\n        },\n      ],\n    },\n  },\n  env: {\n    CDK_INTEG_ACCOUNT: '12345678',\n    CDK_INTEG_REGION: 'test-region',\n    CDK_INTEG_HOSTED_ZONE_ID: 'Z23ABC4XYZL05B',\n    CDK_INTEG_HOSTED_ZONE_NAME: 'example.com',\n    CDK_INTEG_DOMAIN_NAME: '*.example.com',\n    CDK_INTEG_CERT_ARN: 'arn:aws:acm:test-region:12345678:certificate/86468209-a272-595d-b831-0efb6421265z',\n    CDK_INTEG_SUBNET_ID: 'subnet-0dff1a399d8f6f92c',\n  },\n};\n\n/**\n * Return the currently recommended flags for `aws-cdk-lib`.\n *\n * These have been built into the CLI at build time.\n */\nexport function currentlyRecommendedAwsCdkLibFlags() {\n  const recommendedFlagsFile = path.join(__dirname, '..', 'recommended-feature-flags.json');\n  return JSON.parse(fs.readFileSync(recommendedFlagsFile, { encoding: 'utf-8' }));\n}\n"]}
|
|
325
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runner-base.js","sourceRoot":"","sources":["runner-base.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @cdklabs/no-literal-partition */\nimport * as path from 'path';\nimport { CdkCliWrapper, ICdk } from '@aws-cdk/cdk-cli-wrapper';\nimport { TestCase, DefaultCdkOptions } from '@aws-cdk/cloud-assembly-schema';\nimport { AVAILABILITY_ZONE_FALLBACK_CONTEXT_KEY, TARGET_PARTITIONS } from '@aws-cdk/cx-api';\nimport * as fs from 'fs-extra';\nimport { IntegTestSuite, LegacyIntegTestSuite } from './integ-test-suite';\nimport { IntegTest } from './integration-tests';\nimport * as recommendedFlagsFile from '../recommended-feature-flags.json';\nimport { flatten } from '../utils';\nimport { AssemblyManifestReader, ManifestTrace } from './private/cloud-assembly';\nimport { DestructiveChange } from '../workers/common';\n\nconst DESTRUCTIVE_CHANGES = '!!DESTRUCTIVE_CHANGES:';\n\n/**\n * Options for creating an integration test runner\n */\nexport interface IntegRunnerOptions {\n  /**\n   * Information about the test to run\n   */\n  readonly test: IntegTest;\n\n  /**\n   * The AWS profile to use when invoking the CDK CLI\n   *\n   * @default - no profile is passed, the default profile is used\n   */\n  readonly profile?: string;\n\n  /**\n   * Additional environment variables that will be available\n   * to the CDK CLI\n   *\n   * @default - no additional environment variables\n   */\n  readonly env?: { [name: string]: string };\n\n  /**\n   * tmp cdk.out directory\n   *\n   * @default - directory will be `cdk-integ.out.${testName}`\n   */\n  readonly integOutDir?: string;\n\n  /**\n   * Instance of the CDK CLI to use\n   *\n   * @default - CdkCliWrapper\n   */\n  readonly cdk?: ICdk;\n\n  /**\n   * Show output from running integration tests\n   *\n   * @default false\n   */\n  readonly showOutput?: boolean;\n}\n\n/**\n * The different components of a test name\n */\n/**\n * Represents an Integration test runner\n */\nexport abstract class IntegRunner {\n  /**\n   * The directory where the snapshot will be stored\n   */\n  public readonly snapshotDir: string;\n\n  /**\n   * An instance of the CDK  CLI\n   */\n  public readonly cdk: ICdk;\n\n  /**\n   * Pretty name of the test\n   */\n  public readonly testName: string;\n\n  /**\n   * The value used in the '--app' CLI parameter\n   *\n   * Path to the integ test source file, relative to `this.directory`.\n   */\n  protected readonly cdkApp: string;\n\n  /**\n   * The path where the `cdk.context.json` file\n   * will be created\n   */\n  protected readonly cdkContextPath: string;\n\n  /**\n   * The test suite from the existing snapshot\n   */\n  protected readonly expectedTestSuite?: IntegTestSuite | LegacyIntegTestSuite;\n\n  /**\n   * The test suite from the new \"actual\" snapshot\n   */\n  protected readonly actualTestSuite: IntegTestSuite | LegacyIntegTestSuite;\n\n  /**\n   * The working directory that the integration tests will be\n   * executed from\n   */\n  protected readonly directory: string;\n\n  /**\n   * The test to run\n   */\n  protected readonly test: IntegTest;\n\n  /**\n   * Default options to pass to the CDK CLI\n   */\n  protected readonly defaultArgs: DefaultCdkOptions = {\n    pathMetadata: false,\n    assetMetadata: false,\n    versionReporting: false,\n  };\n\n  /**\n   * The directory where the CDK will be synthed to\n   *\n   * Relative to cwd.\n   */\n  protected readonly cdkOutDir: string;\n\n  protected readonly profile?: string;\n\n  protected _destructiveChanges?: DestructiveChange[];\n  private legacyContext?: Record<string, any>;\n  protected isLegacyTest?: boolean;\n\n  constructor(options: IntegRunnerOptions) {\n    this.test = options.test;\n    this.directory = this.test.directory;\n    this.testName = this.test.testName;\n    this.snapshotDir = this.test.snapshotDir;\n    this.cdkContextPath = path.join(this.directory, 'cdk.context.json');\n\n    this.cdk = options.cdk ?? new CdkCliWrapper({\n      directory: this.directory,\n      showOutput: options.showOutput,\n      env: {\n        ...options.env,\n      },\n    });\n    this.cdkOutDir = options.integOutDir ?? this.test.temporaryOutputDir;\n\n    const testRunCommand = this.test.appCommand;\n    this.cdkApp = testRunCommand.replace('{filePath}', path.relative(this.directory, this.test.fileName));\n\n    this.profile = options.profile;\n    if (this.hasSnapshot()) {\n      this.expectedTestSuite = this.loadManifest();\n    }\n    this.actualTestSuite = this.generateActualSnapshot();\n  }\n\n  /**\n   * Return the list of expected (i.e. existing) test cases for this integration test\n   */\n  public expectedTests(): { [testName: string]: TestCase } | undefined {\n    return this.expectedTestSuite?.testSuite;\n  }\n\n  /**\n   * Return the list of actual (i.e. new) test cases for this integration test\n   */\n  public actualTests(): { [testName: string]: TestCase } | undefined {\n    return this.actualTestSuite.testSuite;\n  }\n\n  /**\n   * Generate a new \"actual\" snapshot which will be compared to the\n   * existing \"expected\" snapshot\n   * This will synth and then load the integration test manifest\n   */\n  public generateActualSnapshot(): IntegTestSuite | LegacyIntegTestSuite {\n    this.cdk.synthFast({\n      execCmd: this.cdkApp.split(' '),\n      env: {\n        ...DEFAULT_SYNTH_OPTIONS.env,\n        // we don't know the \"actual\" context yet (this method is what generates it) so just\n        // use the \"expected\" context. This is only run in order to read the manifest\n        CDK_CONTEXT_JSON: JSON.stringify(this.getContext(this.expectedTestSuite?.synthContext)),\n      },\n      output: path.relative(this.directory, this.cdkOutDir),\n    });\n    const manifest = this.loadManifest(this.cdkOutDir);\n    // after we load the manifest remove the tmp snapshot\n    // so that it doesn't mess up the real snapshot created later\n    this.cleanup();\n    return manifest;\n  }\n\n  /**\n   * Returns true if a snapshot already exists for this test\n   */\n  public hasSnapshot(): boolean {\n    return fs.existsSync(this.snapshotDir);\n  }\n\n  /**\n   * Load the integ manifest which contains information\n   * on how to execute the tests\n   * First we try and load the manifest from the integ manifest (i.e. integ.json)\n   * from the cloud assembly. If it doesn't exist, then we fallback to the\n   * \"legacy mode\" and create a manifest from pragma\n   */\n  protected loadManifest(dir?: string): IntegTestSuite | LegacyIntegTestSuite {\n    try {\n      const testSuite = IntegTestSuite.fromPath(dir ?? this.snapshotDir);\n      return testSuite;\n    } catch {\n      const testCases = LegacyIntegTestSuite.fromLegacy({\n        cdk: this.cdk,\n        testName: this.test.normalizedTestName,\n        integSourceFilePath: this.test.fileName,\n        listOptions: {\n          ...this.defaultArgs,\n          all: true,\n          app: this.cdkApp,\n          profile: this.profile,\n          output: path.relative(this.directory, this.cdkOutDir),\n        },\n      });\n      this.legacyContext = LegacyIntegTestSuite.getPragmaContext(this.test.fileName);\n      this.isLegacyTest = true;\n      return testCases;\n    }\n  }\n\n  protected cleanup(): void {\n    const cdkOutPath = this.cdkOutDir;\n    if (fs.existsSync(cdkOutPath)) {\n      fs.removeSync(cdkOutPath);\n    }\n  }\n\n  /**\n   * If there are any destructive changes to a stack then this will record\n   * those in the manifest.json file\n   */\n  private renderTraceData(): ManifestTrace {\n    const traceData: ManifestTrace = new Map();\n    const destructiveChanges = this._destructiveChanges ?? [];\n    destructiveChanges.forEach(change => {\n      const trace = traceData.get(change.stackName);\n      if (trace) {\n        trace.set(change.logicalId, `${DESTRUCTIVE_CHANGES} ${change.impact}`);\n      } else {\n        traceData.set(change.stackName, new Map([\n          [change.logicalId, `${DESTRUCTIVE_CHANGES} ${change.impact}`],\n        ]));\n      }\n    });\n    return traceData;\n  }\n\n  /**\n   * In cases where we do not want to retain the assets,\n   * for example, if the assets are very large.\n   *\n   * Since it is possible to disable the update workflow for individual test\n   * cases, this needs to first get a list of stacks that have the update workflow\n   * disabled and then delete assets that relate to that stack. It does that\n   * by reading the asset manifest for the stack and deleting the asset source\n   */\n  protected removeAssetsFromSnapshot(): void {\n    const stacks = this.actualTestSuite.getStacksWithoutUpdateWorkflow() ?? [];\n    const manifest = AssemblyManifestReader.fromPath(this.snapshotDir);\n    const assets = flatten(stacks.map(stack => {\n      return manifest.getAssetLocationsForStack(stack) ?? [];\n    }));\n\n    assets.forEach(asset => {\n      const fileName = path.join(this.snapshotDir, asset);\n      if (fs.existsSync(fileName)) {\n        if (fs.lstatSync(fileName).isDirectory()) {\n          fs.removeSync(fileName);\n        } else {\n          fs.unlinkSync(fileName);\n        }\n      }\n    });\n  }\n\n  /**\n   * Remove the asset cache (.cache/) files from the snapshot.\n   * These are a cache of the asset zips, but we are fine with\n   * re-zipping on deploy\n   */\n  protected removeAssetsCacheFromSnapshot(): void {\n    const files = fs.readdirSync(this.snapshotDir);\n    files.forEach(file => {\n      const fileName = path.join(this.snapshotDir, file);\n      if (fs.lstatSync(fileName).isDirectory() && file === '.cache') {\n        fs.emptyDirSync(fileName);\n        fs.rmdirSync(fileName);\n      }\n    });\n  }\n\n  /**\n   * Create the new snapshot.\n   *\n   * If lookups are enabled, then we need create the snapshot by synthing again\n   * with the dummy context so that each time the test is run on different machines\n   * (and with different context/env) the diff will not change.\n   *\n   * If lookups are disabled (which means the stack is env agnostic) then just copy\n   * the assembly that was output by the deployment\n   */\n  protected createSnapshot(): void {\n    if (fs.existsSync(this.snapshotDir)) {\n      fs.removeSync(this.snapshotDir);\n    }\n\n    // if lookups are enabled then we need to synth again\n    // using dummy context and save that as the snapshot\n    if (this.actualTestSuite.enableLookups) {\n      this.cdk.synthFast({\n        execCmd: this.cdkApp.split(' '),\n        env: {\n          ...DEFAULT_SYNTH_OPTIONS.env,\n          CDK_CONTEXT_JSON: JSON.stringify(this.getContext(DEFAULT_SYNTH_OPTIONS.context)),\n        },\n        output: path.relative(this.directory, this.snapshotDir),\n      });\n    } else {\n      fs.moveSync(this.cdkOutDir, this.snapshotDir, { overwrite: true });\n    }\n\n    this.cleanupSnapshot();\n  }\n\n  /**\n   * Perform some cleanup steps after the snapshot is created\n   * Anytime the snapshot needs to be modified after creation\n   * the logic should live here.\n   */\n  private cleanupSnapshot(): void {\n    if (fs.existsSync(this.snapshotDir)) {\n      this.removeAssetsFromSnapshot();\n      this.removeAssetsCacheFromSnapshot();\n      const assembly = AssemblyManifestReader.fromPath(this.snapshotDir);\n      assembly.cleanManifest();\n      assembly.recordTrace(this.renderTraceData());\n    }\n\n    // if this is a legacy test then create an integ manifest\n    // in the snapshot directory which can be used for the\n    // update workflow. Save any legacyContext as well so that it can be read\n    // the next time\n    if (this.actualTestSuite.type === 'legacy-test-suite') {\n      (this.actualTestSuite as LegacyIntegTestSuite).saveManifest(this.snapshotDir, this.legacyContext);\n    }\n  }\n\n  protected getContext(additionalContext?: Record<string, any>): Record<string, any> {\n    return {\n      ...currentlyRecommendedAwsCdkLibFlags(),\n      ...this.legacyContext,\n      ...additionalContext,\n\n      // We originally had PLANNED to set this to ['aws', 'aws-cn'], but due to a programming mistake\n      // it was set to everything. In this PR, set it to everything to not mess up all the snapshots.\n      [TARGET_PARTITIONS]: undefined,\n\n      /* ---------------- THE FUTURE LIVES BELOW----------------------------\n      // Restricting to these target partitions makes most service principals synthesize to\n      // `service.${URL_SUFFIX}`, which is technically *incorrect* (it's only `amazonaws.com`\n      // or `amazonaws.com.cn`, never UrlSuffix for any of the restricted regions) but it's what\n      // most existing integ tests contain, and we want to disturb as few as possible.\n      // [TARGET_PARTITIONS]: ['aws', 'aws-cn'],\n      /* ---------------- END OF THE FUTURE ------------------------------- */\n    };\n  }\n}\n\n// Default context we run all integ tests with, so they don't depend on the\n// account of the exercising user.\nexport const DEFAULT_SYNTH_OPTIONS = {\n  context: {\n    [AVAILABILITY_ZONE_FALLBACK_CONTEXT_KEY]: ['test-region-1a', 'test-region-1b', 'test-region-1c'],\n    'availability-zones:account=12345678:region=test-region': ['test-region-1a', 'test-region-1b', 'test-region-1c'],\n    'ssm:account=12345678:parameterName=/aws/service/ami-amazon-linux-latest/amzn-ami-hvm-x86_64-gp2:region=test-region': 'ami-1234',\n    'ssm:account=12345678:parameterName=/aws/service/ami-amazon-linux-latest/amzn2-ami-hvm-x86_64-gp2:region=test-region': 'ami-1234',\n    'ssm:account=12345678:parameterName=/aws/service/ecs/optimized-ami/amazon-linux/recommended:region=test-region': '{\"image_id\": \"ami-1234\"}',\n    // eslint-disable-next-line max-len\n    'ami:account=12345678:filters.image-type.0=machine:filters.name.0=amzn-ami-vpc-nat-*:filters.state.0=available:owners.0=amazon:region=test-region': 'ami-1234',\n    'vpc-provider:account=12345678:filter.isDefault=true:region=test-region:returnAsymmetricSubnets=true': {\n      vpcId: 'vpc-60900905',\n      subnetGroups: [\n        {\n          type: 'Public',\n          name: 'Public',\n          subnets: [\n            {\n              subnetId: 'subnet-e19455ca',\n              availabilityZone: 'us-east-1a',\n              routeTableId: 'rtb-e19455ca',\n            },\n            {\n              subnetId: 'subnet-e0c24797',\n              availabilityZone: 'us-east-1b',\n              routeTableId: 'rtb-e0c24797',\n            },\n            {\n              subnetId: 'subnet-ccd77395',\n              availabilityZone: 'us-east-1c',\n              routeTableId: 'rtb-ccd77395',\n            },\n          ],\n        },\n      ],\n    },\n  },\n  env: {\n    CDK_INTEG_ACCOUNT: '12345678',\n    CDK_INTEG_REGION: 'test-region',\n    CDK_INTEG_HOSTED_ZONE_ID: 'Z23ABC4XYZL05B',\n    CDK_INTEG_HOSTED_ZONE_NAME: 'example.com',\n    CDK_INTEG_DOMAIN_NAME: '*.example.com',\n    CDK_INTEG_CERT_ARN: 'arn:aws:acm:test-region:12345678:certificate/86468209-a272-595d-b831-0efb6421265z',\n    CDK_INTEG_SUBNET_ID: 'subnet-0dff1a399d8f6f92c',\n  },\n};\n\n/**\n * Return the currently recommended flags for `aws-cdk-lib`.\n *\n * These have been built into the CLI at build time. If this ever gets changed\n * back to a dynamic load, remember that this source file may be bundled into\n * a JavaScript bundle, and `__dirname` might not point where you think it does.\n */\nexport function currentlyRecommendedAwsCdkLibFlags() {\n  return recommendedFlagsFile;\n}\n"]}
|
|
@@ -7960,6 +7960,7 @@ __export(features_exports, {
|
|
|
7960
7960
|
DATABASE_PROXY_UNIQUE_RESOURCE_NAME: () => DATABASE_PROXY_UNIQUE_RESOURCE_NAME,
|
|
7961
7961
|
DOCKER_IGNORE_SUPPORT: () => DOCKER_IGNORE_SUPPORT,
|
|
7962
7962
|
DYNAMODB_TABLEV2_RESOURCE_POLICY_PER_REPLICA: () => DYNAMODB_TABLEV2_RESOURCE_POLICY_PER_REPLICA,
|
|
7963
|
+
Disable_ECS_IMDS_Blocking: () => Disable_ECS_IMDS_Blocking,
|
|
7963
7964
|
EBS_DEFAULT_GP3: () => EBS_DEFAULT_GP3,
|
|
7964
7965
|
EC2_LAUNCH_TEMPLATE_DEFAULT_USER_DATA: () => EC2_LAUNCH_TEMPLATE_DEFAULT_USER_DATA,
|
|
7965
7966
|
EC2_RESTRICT_DEFAULT_SECURITY_GROUP: () => EC2_RESTRICT_DEFAULT_SECURITY_GROUP,
|
|
@@ -7981,6 +7982,7 @@ __export(features_exports, {
|
|
|
7981
7982
|
ENABLE_PARTITION_LITERALS: () => ENABLE_PARTITION_LITERALS,
|
|
7982
7983
|
ENABLE_STACK_NAME_DUPLICATES_CONTEXT: () => ENABLE_STACK_NAME_DUPLICATES_CONTEXT,
|
|
7983
7984
|
EVENTS_TARGET_QUEUE_SAME_ACCOUNT: () => EVENTS_TARGET_QUEUE_SAME_ACCOUNT,
|
|
7985
|
+
Enable_IMDS_Blocking_Deprecated_Feature: () => Enable_IMDS_Blocking_Deprecated_Feature,
|
|
7984
7986
|
FLAGS: () => FLAGS,
|
|
7985
7987
|
FUTURE_FLAGS: () => FUTURE_FLAGS,
|
|
7986
7988
|
FUTURE_FLAGS_EXPIRED: () => FUTURE_FLAGS_EXPIRED,
|
|
@@ -8027,7 +8029,7 @@ function futureFlagDefault(flag) {
|
|
|
8027
8029
|
}
|
|
8028
8030
|
return value;
|
|
8029
8031
|
}
|
|
8030
|
-
var ENABLE_STACK_NAME_DUPLICATES_CONTEXT, ENABLE_DIFF_NO_FAIL_CONTEXT, ENABLE_DIFF_NO_FAIL, NEW_STYLE_STACK_SYNTHESIS_CONTEXT, STACK_RELATIVE_EXPORTS_CONTEXT, DOCKER_IGNORE_SUPPORT, SECRETS_MANAGER_PARSE_OWNED_SECRET_NAME, KMS_DEFAULT_KEY_POLICIES, S3_GRANT_WRITE_WITHOUT_ACL, ECS_REMOVE_DEFAULT_DESIRED_COUNT, RDS_LOWERCASE_DB_IDENTIFIER, APIGATEWAY_USAGEPLANKEY_ORDERINSENSITIVE_ID, EFS_DEFAULT_ENCRYPTION_AT_REST, LAMBDA_RECOGNIZE_VERSION_PROPS, LAMBDA_RECOGNIZE_LAYER_VERSION, CLOUDFRONT_DEFAULT_SECURITY_POLICY_TLS_V1_2_2021, CHECK_SECRET_USAGE, TARGET_PARTITIONS, ECS_SERVICE_EXTENSIONS_ENABLE_DEFAULT_LOG_DRIVER, EC2_UNIQUE_IMDSV2_LAUNCH_TEMPLATE_NAME, ECS_ARN_FORMAT_INCLUDES_CLUSTER_NAME, IAM_MINIMIZE_POLICIES, IAM_IMPORTED_ROLE_STACK_SAFE_DEFAULT_POLICY_NAME, VALIDATE_SNAPSHOT_REMOVAL_POLICY, CODEPIPELINE_CROSS_ACCOUNT_KEY_ALIAS_STACK_SAFE_RESOURCE_NAME, S3_CREATE_DEFAULT_LOGGING_POLICY, SNS_SUBSCRIPTIONS_SQS_DECRYPTION_POLICY, APIGATEWAY_DISABLE_CLOUDWATCH_ROLE, ENABLE_PARTITION_LITERALS, EVENTS_TARGET_QUEUE_SAME_ACCOUNT, ECS_DISABLE_EXPLICIT_DEPLOYMENT_CONTROLLER_FOR_CIRCUIT_BREAKER, S3_SERVER_ACCESS_LOGS_USE_BUCKET_POLICY, ROUTE53_PATTERNS_USE_CERTIFICATE, AWS_CUSTOM_RESOURCE_LATEST_SDK_DEFAULT, DATABASE_PROXY_UNIQUE_RESOURCE_NAME, CODEDEPLOY_REMOVE_ALARMS_FROM_DEPLOYMENT_GROUP, APIGATEWAY_AUTHORIZER_CHANGE_DEPLOYMENT_LOGICAL_ID, EC2_LAUNCH_TEMPLATE_DEFAULT_USER_DATA, SECRETS_MANAGER_TARGET_ATTACHMENT_RESOURCE_POLICY, REDSHIFT_COLUMN_ID, ENABLE_EMR_SERVICE_POLICY_V2, EC2_RESTRICT_DEFAULT_SECURITY_GROUP, APIGATEWAY_REQUEST_VALIDATOR_UNIQUE_ID, INCLUDE_PREFIX_IN_UNIQUE_NAME_GENERATION, KMS_ALIAS_NAME_REF, EFS_DENY_ANONYMOUS_ACCESS, EFS_MOUNTTARGET_ORDERINSENSITIVE_LOGICAL_ID, AUTOSCALING_GENERATE_LAUNCH_TEMPLATE, ENABLE_OPENSEARCH_MULTIAZ_WITH_STANDBY, LAMBDA_NODEJS_USE_LATEST_RUNTIME, RDS_PREVENT_RENDERING_DEPRECATED_CREDENTIALS, AURORA_CLUSTER_CHANGE_SCOPE_OF_INSTANCE_PARAMETER_GROUP_WITH_EACH_PARAMETERS, APPSYNC_ENABLE_USE_ARN_IDENTIFIER_SOURCE_API_ASSOCIATION, CODECOMMIT_SOURCE_ACTION_DEFAULT_BRANCH_NAME, LAMBDA_PERMISSION_LOGICAL_ID_FOR_LAMBDA_ACTION, CODEPIPELINE_CROSS_ACCOUNT_KEYS_DEFAULT_VALUE_TO_FALSE, CODEPIPELINE_DEFAULT_PIPELINE_TYPE_TO_V2, KMS_REDUCE_CROSS_ACCOUNT_REGION_POLICY_SCOPE, PIPELINE_REDUCE_ASSET_ROLE_TRUST_SCOPE, EKS_NODEGROUP_NAME, EBS_DEFAULT_GP3, ECS_REMOVE_DEFAULT_DEPLOYMENT_ALARM, LOG_API_RESPONSE_DATA_PROPERTY_TRUE_DEFAULT, S3_KEEP_NOTIFICATION_IN_IMPORTED_BUCKET, USE_NEW_S3URI_PARAMETERS_FOR_BEDROCK_INVOKE_MODEL_TASK, REDUCE_EC2_FARGATE_CLOUDWATCH_PERMISSIONS, DYNAMODB_TABLEV2_RESOURCE_POLICY_PER_REPLICA, EC2_SUM_TIMEOUT_ENABLED, APPSYNC_GRAPHQLAPI_SCOPE_LAMBDA_FUNCTION_PERMISSION, USE_CORRECT_VALUE_FOR_INSTANCE_RESOURCE_ID_PROPERTY, CFN_INCLUDE_REJECT_COMPLEX_RESOURCE_UPDATE_CREATE_POLICY_INTRINSICS, LAMBDA_NODEJS_SDK_V3_EXCLUDE_SMITHY_PACKAGES, STEPFUNCTIONS_TASKS_FIX_RUN_ECS_TASK_POLICY, BASTION_HOST_USE_AMAZON_LINUX_2023_BY_DEFAULT, ASPECT_STABILIZATION, USER_POOL_DOMAIN_NAME_METHOD_WITHOUT_CUSTOM_RESOURCE, FLAGS, CURRENT_MV, CURRENT_VERSION_EXPIRED_FLAGS, CURRENTLY_RECOMMENDED_FLAGS, CURRENT_VERSION_FLAG_DEFAULTS, FUTURE_FLAGS_EXPIRED, FUTURE_FLAGS, NEW_PROJECT_DEFAULT_CONTEXT;
|
|
8032
|
+
var ENABLE_STACK_NAME_DUPLICATES_CONTEXT, ENABLE_DIFF_NO_FAIL_CONTEXT, ENABLE_DIFF_NO_FAIL, NEW_STYLE_STACK_SYNTHESIS_CONTEXT, STACK_RELATIVE_EXPORTS_CONTEXT, DOCKER_IGNORE_SUPPORT, SECRETS_MANAGER_PARSE_OWNED_SECRET_NAME, KMS_DEFAULT_KEY_POLICIES, S3_GRANT_WRITE_WITHOUT_ACL, ECS_REMOVE_DEFAULT_DESIRED_COUNT, RDS_LOWERCASE_DB_IDENTIFIER, APIGATEWAY_USAGEPLANKEY_ORDERINSENSITIVE_ID, EFS_DEFAULT_ENCRYPTION_AT_REST, LAMBDA_RECOGNIZE_VERSION_PROPS, LAMBDA_RECOGNIZE_LAYER_VERSION, CLOUDFRONT_DEFAULT_SECURITY_POLICY_TLS_V1_2_2021, CHECK_SECRET_USAGE, TARGET_PARTITIONS, ECS_SERVICE_EXTENSIONS_ENABLE_DEFAULT_LOG_DRIVER, EC2_UNIQUE_IMDSV2_LAUNCH_TEMPLATE_NAME, ECS_ARN_FORMAT_INCLUDES_CLUSTER_NAME, IAM_MINIMIZE_POLICIES, IAM_IMPORTED_ROLE_STACK_SAFE_DEFAULT_POLICY_NAME, VALIDATE_SNAPSHOT_REMOVAL_POLICY, CODEPIPELINE_CROSS_ACCOUNT_KEY_ALIAS_STACK_SAFE_RESOURCE_NAME, S3_CREATE_DEFAULT_LOGGING_POLICY, SNS_SUBSCRIPTIONS_SQS_DECRYPTION_POLICY, APIGATEWAY_DISABLE_CLOUDWATCH_ROLE, ENABLE_PARTITION_LITERALS, EVENTS_TARGET_QUEUE_SAME_ACCOUNT, ECS_DISABLE_EXPLICIT_DEPLOYMENT_CONTROLLER_FOR_CIRCUIT_BREAKER, S3_SERVER_ACCESS_LOGS_USE_BUCKET_POLICY, ROUTE53_PATTERNS_USE_CERTIFICATE, AWS_CUSTOM_RESOURCE_LATEST_SDK_DEFAULT, DATABASE_PROXY_UNIQUE_RESOURCE_NAME, CODEDEPLOY_REMOVE_ALARMS_FROM_DEPLOYMENT_GROUP, APIGATEWAY_AUTHORIZER_CHANGE_DEPLOYMENT_LOGICAL_ID, EC2_LAUNCH_TEMPLATE_DEFAULT_USER_DATA, SECRETS_MANAGER_TARGET_ATTACHMENT_RESOURCE_POLICY, REDSHIFT_COLUMN_ID, ENABLE_EMR_SERVICE_POLICY_V2, EC2_RESTRICT_DEFAULT_SECURITY_GROUP, APIGATEWAY_REQUEST_VALIDATOR_UNIQUE_ID, INCLUDE_PREFIX_IN_UNIQUE_NAME_GENERATION, KMS_ALIAS_NAME_REF, EFS_DENY_ANONYMOUS_ACCESS, EFS_MOUNTTARGET_ORDERINSENSITIVE_LOGICAL_ID, AUTOSCALING_GENERATE_LAUNCH_TEMPLATE, ENABLE_OPENSEARCH_MULTIAZ_WITH_STANDBY, LAMBDA_NODEJS_USE_LATEST_RUNTIME, RDS_PREVENT_RENDERING_DEPRECATED_CREDENTIALS, AURORA_CLUSTER_CHANGE_SCOPE_OF_INSTANCE_PARAMETER_GROUP_WITH_EACH_PARAMETERS, APPSYNC_ENABLE_USE_ARN_IDENTIFIER_SOURCE_API_ASSOCIATION, CODECOMMIT_SOURCE_ACTION_DEFAULT_BRANCH_NAME, LAMBDA_PERMISSION_LOGICAL_ID_FOR_LAMBDA_ACTION, CODEPIPELINE_CROSS_ACCOUNT_KEYS_DEFAULT_VALUE_TO_FALSE, CODEPIPELINE_DEFAULT_PIPELINE_TYPE_TO_V2, KMS_REDUCE_CROSS_ACCOUNT_REGION_POLICY_SCOPE, PIPELINE_REDUCE_ASSET_ROLE_TRUST_SCOPE, EKS_NODEGROUP_NAME, EBS_DEFAULT_GP3, ECS_REMOVE_DEFAULT_DEPLOYMENT_ALARM, LOG_API_RESPONSE_DATA_PROPERTY_TRUE_DEFAULT, S3_KEEP_NOTIFICATION_IN_IMPORTED_BUCKET, USE_NEW_S3URI_PARAMETERS_FOR_BEDROCK_INVOKE_MODEL_TASK, REDUCE_EC2_FARGATE_CLOUDWATCH_PERMISSIONS, DYNAMODB_TABLEV2_RESOURCE_POLICY_PER_REPLICA, EC2_SUM_TIMEOUT_ENABLED, APPSYNC_GRAPHQLAPI_SCOPE_LAMBDA_FUNCTION_PERMISSION, USE_CORRECT_VALUE_FOR_INSTANCE_RESOURCE_ID_PROPERTY, CFN_INCLUDE_REJECT_COMPLEX_RESOURCE_UPDATE_CREATE_POLICY_INTRINSICS, LAMBDA_NODEJS_SDK_V3_EXCLUDE_SMITHY_PACKAGES, STEPFUNCTIONS_TASKS_FIX_RUN_ECS_TASK_POLICY, BASTION_HOST_USE_AMAZON_LINUX_2023_BY_DEFAULT, ASPECT_STABILIZATION, USER_POOL_DOMAIN_NAME_METHOD_WITHOUT_CUSTOM_RESOURCE, Enable_IMDS_Blocking_Deprecated_Feature, Disable_ECS_IMDS_Blocking, FLAGS, CURRENT_MV, CURRENT_VERSION_EXPIRED_FLAGS, CURRENTLY_RECOMMENDED_FLAGS, CURRENT_VERSION_FLAG_DEFAULTS, FUTURE_FLAGS_EXPIRED, FUTURE_FLAGS, NEW_PROJECT_DEFAULT_CONTEXT;
|
|
8031
8033
|
var init_features = __esm({
|
|
8032
8034
|
"../cx-api/lib/features.ts"() {
|
|
8033
8035
|
"use strict";
|
|
@@ -8108,6 +8110,8 @@ var init_features = __esm({
|
|
|
8108
8110
|
BASTION_HOST_USE_AMAZON_LINUX_2023_BY_DEFAULT = "@aws-cdk/aws-ec2:bastionHostUseAmazonLinux2023ByDefault";
|
|
8109
8111
|
ASPECT_STABILIZATION = "@aws-cdk/core:aspectStabilization";
|
|
8110
8112
|
USER_POOL_DOMAIN_NAME_METHOD_WITHOUT_CUSTOM_RESOURCE = "@aws-cdk/aws-route53-targets:userPoolDomainNameMethodWithoutCustomResource";
|
|
8113
|
+
Enable_IMDS_Blocking_Deprecated_Feature = "@aws-cdk/aws-ecs:enableImdsBlockingDeprecatedFeature";
|
|
8114
|
+
Disable_ECS_IMDS_Blocking = "@aws-cdk/aws-ecs:disableEcsImdsBlocking";
|
|
8111
8115
|
FLAGS = {
|
|
8112
8116
|
//////////////////////////////////////////////////////////////////////
|
|
8113
8117
|
[ENABLE_STACK_NAME_DUPLICATES_CONTEXT]: {
|
|
@@ -9064,6 +9068,37 @@ var init_features = __esm({
|
|
|
9064
9068
|
compatibilityWithOldBehaviorMd: "Disable the feature flag to use input and output path fields for s3 URI"
|
|
9065
9069
|
},
|
|
9066
9070
|
//////////////////////////////////////////////////////////////////////
|
|
9071
|
+
[Enable_IMDS_Blocking_Deprecated_Feature]: {
|
|
9072
|
+
type: 3 /* Temporary */,
|
|
9073
|
+
summary: "When set to true along with canContainersAccessInstanceRole=false in ECS cluster, new updated commands will be added to UserData to block container accessing IMDS. **Applicable to Linux only. IMPORTANT: See [details.](#aws-cdkaws-ecsenableImdsBlockingDeprecatedFeature)**",
|
|
9074
|
+
detailsMd: `
|
|
9075
|
+
In an ECS Cluster with \`MachineImageType.AMAZON_LINUX_2\`, the canContainersAccessInstanceRole=false option attempts to add commands to block containers from
|
|
9076
|
+
accessing IMDS. Set this flag to true in order to use new and updated commands. Please note that this
|
|
9077
|
+
feature alone with this feature flag will be deprecated by <ins>**end of 2025**</ins> as CDK cannot
|
|
9078
|
+
guarantee the correct execution of the feature in all platforms. See [Github discussion](https://github.com/aws/aws-cdk/discussions/32609) for more information.
|
|
9079
|
+
It is recommended to follow ECS documentation to block IMDS for your specific platform and cluster configuration.
|
|
9080
|
+
`,
|
|
9081
|
+
introducedIn: { v2: "2.175.0" },
|
|
9082
|
+
recommendedValue: false,
|
|
9083
|
+
compatibilityWithOldBehaviorMd: "Set this flag to false in order to continue using old and outdated commands. However, it is **not** recommended."
|
|
9084
|
+
},
|
|
9085
|
+
//////////////////////////////////////////////////////////////////////
|
|
9086
|
+
[Disable_ECS_IMDS_Blocking]: {
|
|
9087
|
+
type: 3 /* Temporary */,
|
|
9088
|
+
summary: "When set to true, CDK synth will throw exception if canContainersAccessInstanceRole is false. **IMPORTANT: See [details.](#aws-cdkaws-ecsdisableEcsImdsBlocking)**",
|
|
9089
|
+
detailsMd: `
|
|
9090
|
+
In an ECS Cluster with \`MachineImageType.AMAZON_LINUX_2\`, the canContainersAccessInstanceRole=false option attempts to add commands to block containers from
|
|
9091
|
+
accessing IMDS. CDK cannot guarantee the correct execution of the feature in all platforms. Setting this feature flag
|
|
9092
|
+
to true will ensure CDK does not attempt to implement IMDS blocking. By <ins>**end of 2025**</ins>, CDK will remove the
|
|
9093
|
+
IMDS blocking feature. See [Github discussion](https://github.com/aws/aws-cdk/discussions/32609) for more information.
|
|
9094
|
+
|
|
9095
|
+
It is recommended to follow ECS documentation to block IMDS for your specific platform and cluster configuration.
|
|
9096
|
+
`,
|
|
9097
|
+
introducedIn: { v2: "2.175.0" },
|
|
9098
|
+
recommendedValue: true,
|
|
9099
|
+
compatibilityWithOldBehaviorMd: "It is strongly recommended to set this flag to true. However, if necessary, set this flag to false to continue using the old implementation."
|
|
9100
|
+
},
|
|
9101
|
+
//////////////////////////////////////////////////////////////////////
|
|
9067
9102
|
[REDUCE_EC2_FARGATE_CLOUDWATCH_PERMISSIONS]: {
|
|
9068
9103
|
type: 1 /* BugFix */,
|
|
9069
9104
|
summary: "When enabled, we will only grant the necessary permissions when users specify cloudwatch log group through logConfiguration",
|
|
@@ -11611,7 +11646,7 @@ var require_jsonfile = __commonJS({
|
|
|
11611
11646
|
return obj;
|
|
11612
11647
|
}
|
|
11613
11648
|
var readFile = universalify.fromPromise(_readFile);
|
|
11614
|
-
function
|
|
11649
|
+
function readFileSync4(file, options = {}) {
|
|
11615
11650
|
if (typeof options === "string") {
|
|
11616
11651
|
options = { encoding: options };
|
|
11617
11652
|
}
|
|
@@ -11643,7 +11678,7 @@ var require_jsonfile = __commonJS({
|
|
|
11643
11678
|
}
|
|
11644
11679
|
var jsonfile = {
|
|
11645
11680
|
readFile,
|
|
11646
|
-
readFileSync:
|
|
11681
|
+
readFileSync: readFileSync4,
|
|
11647
11682
|
writeFile,
|
|
11648
11683
|
writeFileSync: writeFileSync3
|
|
11649
11684
|
};
|
|
@@ -12165,6 +12200,202 @@ var init_integ_test_suite = __esm({
|
|
|
12165
12200
|
}
|
|
12166
12201
|
});
|
|
12167
12202
|
|
|
12203
|
+
// lib/recommended-feature-flags.json
|
|
12204
|
+
var recommended_feature_flags_exports = {};
|
|
12205
|
+
__export(recommended_feature_flags_exports, {
|
|
12206
|
+
"@aws-cdk-containers/ecs-service-extensions:enableDefaultLogDriver": () => _aws_cdk_containers_ecs_service_extensions_enableDefaultLogDriver,
|
|
12207
|
+
"@aws-cdk/aws-apigateway:authorizerChangeDeploymentLogicalId": () => _aws_cdk_aws_apigateway_authorizerChangeDeploymentLogicalId,
|
|
12208
|
+
"@aws-cdk/aws-apigateway:disableCloudWatchRole": () => _aws_cdk_aws_apigateway_disableCloudWatchRole,
|
|
12209
|
+
"@aws-cdk/aws-apigateway:requestValidatorUniqueId": () => _aws_cdk_aws_apigateway_requestValidatorUniqueId,
|
|
12210
|
+
"@aws-cdk/aws-appsync:appSyncGraphQLAPIScopeLambdaPermission": () => _aws_cdk_aws_appsync_appSyncGraphQLAPIScopeLambdaPermission,
|
|
12211
|
+
"@aws-cdk/aws-appsync:useArnForSourceApiAssociationIdentifier": () => _aws_cdk_aws_appsync_useArnForSourceApiAssociationIdentifier,
|
|
12212
|
+
"@aws-cdk/aws-autoscaling:generateLaunchTemplateInsteadOfLaunchConfig": () => _aws_cdk_aws_autoscaling_generateLaunchTemplateInsteadOfLaunchConfig,
|
|
12213
|
+
"@aws-cdk/aws-cloudwatch-actions:changeLambdaPermissionLogicalIdForLambdaAction": () => _aws_cdk_aws_cloudwatch_actions_changeLambdaPermissionLogicalIdForLambdaAction,
|
|
12214
|
+
"@aws-cdk/aws-codedeploy:removeAlarmsFromDeploymentGroup": () => _aws_cdk_aws_codedeploy_removeAlarmsFromDeploymentGroup,
|
|
12215
|
+
"@aws-cdk/aws-codepipeline-actions:useNewDefaultBranchForCodeCommitSource": () => _aws_cdk_aws_codepipeline_actions_useNewDefaultBranchForCodeCommitSource,
|
|
12216
|
+
"@aws-cdk/aws-codepipeline:crossAccountKeyAliasStackSafeResourceName": () => _aws_cdk_aws_codepipeline_crossAccountKeyAliasStackSafeResourceName,
|
|
12217
|
+
"@aws-cdk/aws-codepipeline:crossAccountKeysDefaultValueToFalse": () => _aws_cdk_aws_codepipeline_crossAccountKeysDefaultValueToFalse,
|
|
12218
|
+
"@aws-cdk/aws-codepipeline:defaultPipelineTypeToV2": () => _aws_cdk_aws_codepipeline_defaultPipelineTypeToV2,
|
|
12219
|
+
"@aws-cdk/aws-dynamodb:resourcePolicyPerReplica": () => _aws_cdk_aws_dynamodb_resourcePolicyPerReplica,
|
|
12220
|
+
"@aws-cdk/aws-ec2:bastionHostUseAmazonLinux2023ByDefault": () => _aws_cdk_aws_ec2_bastionHostUseAmazonLinux2023ByDefault,
|
|
12221
|
+
"@aws-cdk/aws-ec2:ebsDefaultGp3Volume": () => _aws_cdk_aws_ec2_ebsDefaultGp3Volume,
|
|
12222
|
+
"@aws-cdk/aws-ec2:ec2SumTImeoutEnabled": () => _aws_cdk_aws_ec2_ec2SumTImeoutEnabled,
|
|
12223
|
+
"@aws-cdk/aws-ec2:launchTemplateDefaultUserData": () => _aws_cdk_aws_ec2_launchTemplateDefaultUserData,
|
|
12224
|
+
"@aws-cdk/aws-ec2:restrictDefaultSecurityGroup": () => _aws_cdk_aws_ec2_restrictDefaultSecurityGroup,
|
|
12225
|
+
"@aws-cdk/aws-ec2:uniqueImdsv2TemplateName": () => _aws_cdk_aws_ec2_uniqueImdsv2TemplateName,
|
|
12226
|
+
"@aws-cdk/aws-ecs:arnFormatIncludesClusterName": () => _aws_cdk_aws_ecs_arnFormatIncludesClusterName,
|
|
12227
|
+
"@aws-cdk/aws-ecs:disableEcsImdsBlocking": () => _aws_cdk_aws_ecs_disableEcsImdsBlocking,
|
|
12228
|
+
"@aws-cdk/aws-ecs:disableExplicitDeploymentControllerForCircuitBreaker": () => _aws_cdk_aws_ecs_disableExplicitDeploymentControllerForCircuitBreaker,
|
|
12229
|
+
"@aws-cdk/aws-ecs:enableImdsBlockingDeprecatedFeature": () => _aws_cdk_aws_ecs_enableImdsBlockingDeprecatedFeature,
|
|
12230
|
+
"@aws-cdk/aws-ecs:reduceEc2FargateCloudWatchPermissions": () => _aws_cdk_aws_ecs_reduceEc2FargateCloudWatchPermissions,
|
|
12231
|
+
"@aws-cdk/aws-ecs:removeDefaultDeploymentAlarm": () => _aws_cdk_aws_ecs_removeDefaultDeploymentAlarm,
|
|
12232
|
+
"@aws-cdk/aws-efs:denyAnonymousAccess": () => _aws_cdk_aws_efs_denyAnonymousAccess,
|
|
12233
|
+
"@aws-cdk/aws-efs:mountTargetOrderInsensitiveLogicalId": () => _aws_cdk_aws_efs_mountTargetOrderInsensitiveLogicalId,
|
|
12234
|
+
"@aws-cdk/aws-eks:nodegroupNameAttribute": () => _aws_cdk_aws_eks_nodegroupNameAttribute,
|
|
12235
|
+
"@aws-cdk/aws-events:eventsTargetQueueSameAccount": () => _aws_cdk_aws_events_eventsTargetQueueSameAccount,
|
|
12236
|
+
"@aws-cdk/aws-iam:importedRoleStackSafeDefaultPolicyName": () => _aws_cdk_aws_iam_importedRoleStackSafeDefaultPolicyName,
|
|
12237
|
+
"@aws-cdk/aws-iam:minimizePolicies": () => _aws_cdk_aws_iam_minimizePolicies,
|
|
12238
|
+
"@aws-cdk/aws-kms:aliasNameRef": () => _aws_cdk_aws_kms_aliasNameRef,
|
|
12239
|
+
"@aws-cdk/aws-kms:reduceCrossAccountRegionPolicyScope": () => _aws_cdk_aws_kms_reduceCrossAccountRegionPolicyScope,
|
|
12240
|
+
"@aws-cdk/aws-lambda-nodejs:sdkV3ExcludeSmithyPackages": () => _aws_cdk_aws_lambda_nodejs_sdkV3ExcludeSmithyPackages,
|
|
12241
|
+
"@aws-cdk/aws-lambda-nodejs:useLatestRuntimeVersion": () => _aws_cdk_aws_lambda_nodejs_useLatestRuntimeVersion,
|
|
12242
|
+
"@aws-cdk/aws-lambda:recognizeLayerVersion": () => _aws_cdk_aws_lambda_recognizeLayerVersion,
|
|
12243
|
+
"@aws-cdk/aws-opensearchservice:enableOpensearchMultiAzWithStandby": () => _aws_cdk_aws_opensearchservice_enableOpensearchMultiAzWithStandby,
|
|
12244
|
+
"@aws-cdk/aws-rds:auroraClusterChangeScopeOfInstanceParameterGroupWithEachParameters": () => _aws_cdk_aws_rds_auroraClusterChangeScopeOfInstanceParameterGroupWithEachParameters,
|
|
12245
|
+
"@aws-cdk/aws-rds:databaseProxyUniqueResourceName": () => _aws_cdk_aws_rds_databaseProxyUniqueResourceName,
|
|
12246
|
+
"@aws-cdk/aws-rds:preventRenderingDeprecatedCredentials": () => _aws_cdk_aws_rds_preventRenderingDeprecatedCredentials,
|
|
12247
|
+
"@aws-cdk/aws-rds:setCorrectValueForDatabaseInstanceReadReplicaInstanceResourceId": () => _aws_cdk_aws_rds_setCorrectValueForDatabaseInstanceReadReplicaInstanceResourceId,
|
|
12248
|
+
"@aws-cdk/aws-redshift:columnId": () => _aws_cdk_aws_redshift_columnId,
|
|
12249
|
+
"@aws-cdk/aws-route53-patters:useCertificate": () => _aws_cdk_aws_route53_patters_useCertificate,
|
|
12250
|
+
"@aws-cdk/aws-route53-targets:userPoolDomainNameMethodWithoutCustomResource": () => _aws_cdk_aws_route53_targets_userPoolDomainNameMethodWithoutCustomResource,
|
|
12251
|
+
"@aws-cdk/aws-s3:createDefaultLoggingPolicy": () => _aws_cdk_aws_s3_createDefaultLoggingPolicy,
|
|
12252
|
+
"@aws-cdk/aws-s3:keepNotificationInImportedBucket": () => _aws_cdk_aws_s3_keepNotificationInImportedBucket,
|
|
12253
|
+
"@aws-cdk/aws-s3:serverAccessLogsUseBucketPolicy": () => _aws_cdk_aws_s3_serverAccessLogsUseBucketPolicy,
|
|
12254
|
+
"@aws-cdk/aws-secretsmanager:useAttachedSecretResourcePolicyForSecretTargetAttachments": () => _aws_cdk_aws_secretsmanager_useAttachedSecretResourcePolicyForSecretTargetAttachments,
|
|
12255
|
+
"@aws-cdk/aws-sns-subscriptions:restrictSqsDescryption": () => _aws_cdk_aws_sns_subscriptions_restrictSqsDescryption,
|
|
12256
|
+
"@aws-cdk/aws-stepfunctions-tasks:enableEmrServicePolicyV2": () => _aws_cdk_aws_stepfunctions_tasks_enableEmrServicePolicyV2,
|
|
12257
|
+
"@aws-cdk/aws-stepfunctions-tasks:fixRunEcsTaskPolicy": () => _aws_cdk_aws_stepfunctions_tasks_fixRunEcsTaskPolicy,
|
|
12258
|
+
"@aws-cdk/core:cfnIncludeRejectComplexResourceUpdateCreatePolicyIntrinsics": () => _aws_cdk_core_cfnIncludeRejectComplexResourceUpdateCreatePolicyIntrinsics,
|
|
12259
|
+
"@aws-cdk/core:checkSecretUsage": () => _aws_cdk_core_checkSecretUsage,
|
|
12260
|
+
"@aws-cdk/core:enablePartitionLiterals": () => _aws_cdk_core_enablePartitionLiterals,
|
|
12261
|
+
"@aws-cdk/core:includePrefixInUniqueNameGeneration": () => _aws_cdk_core_includePrefixInUniqueNameGeneration,
|
|
12262
|
+
"@aws-cdk/core:target-partitions": () => _aws_cdk_core_target_partitions,
|
|
12263
|
+
"@aws-cdk/core:validateSnapshotRemovalPolicy": () => _aws_cdk_core_validateSnapshotRemovalPolicy,
|
|
12264
|
+
"@aws-cdk/custom-resources:logApiResponseDataPropertyTrueDefault": () => _aws_cdk_custom_resources_logApiResponseDataPropertyTrueDefault,
|
|
12265
|
+
"@aws-cdk/customresources:installLatestAwsSdkDefault": () => _aws_cdk_customresources_installLatestAwsSdkDefault,
|
|
12266
|
+
default: () => recommended_feature_flags_default
|
|
12267
|
+
});
|
|
12268
|
+
var _aws_cdk_aws_lambda_recognizeLayerVersion, _aws_cdk_core_checkSecretUsage, _aws_cdk_core_target_partitions, _aws_cdk_containers_ecs_service_extensions_enableDefaultLogDriver, _aws_cdk_aws_ec2_uniqueImdsv2TemplateName, _aws_cdk_aws_ecs_arnFormatIncludesClusterName, _aws_cdk_aws_iam_minimizePolicies, _aws_cdk_core_validateSnapshotRemovalPolicy, _aws_cdk_aws_codepipeline_crossAccountKeyAliasStackSafeResourceName, _aws_cdk_aws_s3_createDefaultLoggingPolicy, _aws_cdk_aws_sns_subscriptions_restrictSqsDescryption, _aws_cdk_aws_apigateway_disableCloudWatchRole, _aws_cdk_core_enablePartitionLiterals, _aws_cdk_aws_events_eventsTargetQueueSameAccount, _aws_cdk_aws_ecs_disableExplicitDeploymentControllerForCircuitBreaker, _aws_cdk_aws_iam_importedRoleStackSafeDefaultPolicyName, _aws_cdk_aws_s3_serverAccessLogsUseBucketPolicy, _aws_cdk_aws_route53_patters_useCertificate, _aws_cdk_customresources_installLatestAwsSdkDefault, _aws_cdk_aws_rds_databaseProxyUniqueResourceName, _aws_cdk_aws_codedeploy_removeAlarmsFromDeploymentGroup, _aws_cdk_aws_apigateway_authorizerChangeDeploymentLogicalId, _aws_cdk_aws_ec2_launchTemplateDefaultUserData, _aws_cdk_aws_secretsmanager_useAttachedSecretResourcePolicyForSecretTargetAttachments, _aws_cdk_aws_redshift_columnId, _aws_cdk_aws_stepfunctions_tasks_enableEmrServicePolicyV2, _aws_cdk_aws_ec2_restrictDefaultSecurityGroup, _aws_cdk_aws_apigateway_requestValidatorUniqueId, _aws_cdk_aws_kms_aliasNameRef, _aws_cdk_aws_autoscaling_generateLaunchTemplateInsteadOfLaunchConfig, _aws_cdk_core_includePrefixInUniqueNameGeneration, _aws_cdk_aws_efs_denyAnonymousAccess, _aws_cdk_aws_opensearchservice_enableOpensearchMultiAzWithStandby, _aws_cdk_aws_lambda_nodejs_useLatestRuntimeVersion, _aws_cdk_aws_efs_mountTargetOrderInsensitiveLogicalId, _aws_cdk_aws_rds_auroraClusterChangeScopeOfInstanceParameterGroupWithEachParameters, _aws_cdk_aws_appsync_useArnForSourceApiAssociationIdentifier, _aws_cdk_aws_rds_preventRenderingDeprecatedCredentials, _aws_cdk_aws_codepipeline_actions_useNewDefaultBranchForCodeCommitSource, _aws_cdk_aws_cloudwatch_actions_changeLambdaPermissionLogicalIdForLambdaAction, _aws_cdk_aws_codepipeline_crossAccountKeysDefaultValueToFalse, _aws_cdk_aws_codepipeline_defaultPipelineTypeToV2, _aws_cdk_aws_kms_reduceCrossAccountRegionPolicyScope, _aws_cdk_aws_eks_nodegroupNameAttribute, _aws_cdk_aws_ec2_ebsDefaultGp3Volume, _aws_cdk_aws_ecs_removeDefaultDeploymentAlarm, _aws_cdk_custom_resources_logApiResponseDataPropertyTrueDefault, _aws_cdk_aws_s3_keepNotificationInImportedBucket, _aws_cdk_aws_ecs_enableImdsBlockingDeprecatedFeature, _aws_cdk_aws_ecs_disableEcsImdsBlocking, _aws_cdk_aws_ecs_reduceEc2FargateCloudWatchPermissions, _aws_cdk_aws_dynamodb_resourcePolicyPerReplica, _aws_cdk_aws_ec2_ec2SumTImeoutEnabled, _aws_cdk_aws_appsync_appSyncGraphQLAPIScopeLambdaPermission, _aws_cdk_aws_rds_setCorrectValueForDatabaseInstanceReadReplicaInstanceResourceId, _aws_cdk_core_cfnIncludeRejectComplexResourceUpdateCreatePolicyIntrinsics, _aws_cdk_aws_lambda_nodejs_sdkV3ExcludeSmithyPackages, _aws_cdk_aws_stepfunctions_tasks_fixRunEcsTaskPolicy, _aws_cdk_aws_ec2_bastionHostUseAmazonLinux2023ByDefault, _aws_cdk_aws_route53_targets_userPoolDomainNameMethodWithoutCustomResource, recommended_feature_flags_default;
|
|
12269
|
+
var init_recommended_feature_flags = __esm({
|
|
12270
|
+
"lib/recommended-feature-flags.json"() {
|
|
12271
|
+
_aws_cdk_aws_lambda_recognizeLayerVersion = true;
|
|
12272
|
+
_aws_cdk_core_checkSecretUsage = true;
|
|
12273
|
+
_aws_cdk_core_target_partitions = [
|
|
12274
|
+
"aws",
|
|
12275
|
+
"aws-cn"
|
|
12276
|
+
];
|
|
12277
|
+
_aws_cdk_containers_ecs_service_extensions_enableDefaultLogDriver = true;
|
|
12278
|
+
_aws_cdk_aws_ec2_uniqueImdsv2TemplateName = true;
|
|
12279
|
+
_aws_cdk_aws_ecs_arnFormatIncludesClusterName = true;
|
|
12280
|
+
_aws_cdk_aws_iam_minimizePolicies = true;
|
|
12281
|
+
_aws_cdk_core_validateSnapshotRemovalPolicy = true;
|
|
12282
|
+
_aws_cdk_aws_codepipeline_crossAccountKeyAliasStackSafeResourceName = true;
|
|
12283
|
+
_aws_cdk_aws_s3_createDefaultLoggingPolicy = true;
|
|
12284
|
+
_aws_cdk_aws_sns_subscriptions_restrictSqsDescryption = true;
|
|
12285
|
+
_aws_cdk_aws_apigateway_disableCloudWatchRole = true;
|
|
12286
|
+
_aws_cdk_core_enablePartitionLiterals = true;
|
|
12287
|
+
_aws_cdk_aws_events_eventsTargetQueueSameAccount = true;
|
|
12288
|
+
_aws_cdk_aws_ecs_disableExplicitDeploymentControllerForCircuitBreaker = true;
|
|
12289
|
+
_aws_cdk_aws_iam_importedRoleStackSafeDefaultPolicyName = true;
|
|
12290
|
+
_aws_cdk_aws_s3_serverAccessLogsUseBucketPolicy = true;
|
|
12291
|
+
_aws_cdk_aws_route53_patters_useCertificate = true;
|
|
12292
|
+
_aws_cdk_customresources_installLatestAwsSdkDefault = false;
|
|
12293
|
+
_aws_cdk_aws_rds_databaseProxyUniqueResourceName = true;
|
|
12294
|
+
_aws_cdk_aws_codedeploy_removeAlarmsFromDeploymentGroup = true;
|
|
12295
|
+
_aws_cdk_aws_apigateway_authorizerChangeDeploymentLogicalId = true;
|
|
12296
|
+
_aws_cdk_aws_ec2_launchTemplateDefaultUserData = true;
|
|
12297
|
+
_aws_cdk_aws_secretsmanager_useAttachedSecretResourcePolicyForSecretTargetAttachments = true;
|
|
12298
|
+
_aws_cdk_aws_redshift_columnId = true;
|
|
12299
|
+
_aws_cdk_aws_stepfunctions_tasks_enableEmrServicePolicyV2 = true;
|
|
12300
|
+
_aws_cdk_aws_ec2_restrictDefaultSecurityGroup = true;
|
|
12301
|
+
_aws_cdk_aws_apigateway_requestValidatorUniqueId = true;
|
|
12302
|
+
_aws_cdk_aws_kms_aliasNameRef = true;
|
|
12303
|
+
_aws_cdk_aws_autoscaling_generateLaunchTemplateInsteadOfLaunchConfig = true;
|
|
12304
|
+
_aws_cdk_core_includePrefixInUniqueNameGeneration = true;
|
|
12305
|
+
_aws_cdk_aws_efs_denyAnonymousAccess = true;
|
|
12306
|
+
_aws_cdk_aws_opensearchservice_enableOpensearchMultiAzWithStandby = true;
|
|
12307
|
+
_aws_cdk_aws_lambda_nodejs_useLatestRuntimeVersion = true;
|
|
12308
|
+
_aws_cdk_aws_efs_mountTargetOrderInsensitiveLogicalId = true;
|
|
12309
|
+
_aws_cdk_aws_rds_auroraClusterChangeScopeOfInstanceParameterGroupWithEachParameters = true;
|
|
12310
|
+
_aws_cdk_aws_appsync_useArnForSourceApiAssociationIdentifier = true;
|
|
12311
|
+
_aws_cdk_aws_rds_preventRenderingDeprecatedCredentials = true;
|
|
12312
|
+
_aws_cdk_aws_codepipeline_actions_useNewDefaultBranchForCodeCommitSource = true;
|
|
12313
|
+
_aws_cdk_aws_cloudwatch_actions_changeLambdaPermissionLogicalIdForLambdaAction = true;
|
|
12314
|
+
_aws_cdk_aws_codepipeline_crossAccountKeysDefaultValueToFalse = true;
|
|
12315
|
+
_aws_cdk_aws_codepipeline_defaultPipelineTypeToV2 = true;
|
|
12316
|
+
_aws_cdk_aws_kms_reduceCrossAccountRegionPolicyScope = true;
|
|
12317
|
+
_aws_cdk_aws_eks_nodegroupNameAttribute = true;
|
|
12318
|
+
_aws_cdk_aws_ec2_ebsDefaultGp3Volume = true;
|
|
12319
|
+
_aws_cdk_aws_ecs_removeDefaultDeploymentAlarm = true;
|
|
12320
|
+
_aws_cdk_custom_resources_logApiResponseDataPropertyTrueDefault = false;
|
|
12321
|
+
_aws_cdk_aws_s3_keepNotificationInImportedBucket = false;
|
|
12322
|
+
_aws_cdk_aws_ecs_enableImdsBlockingDeprecatedFeature = false;
|
|
12323
|
+
_aws_cdk_aws_ecs_disableEcsImdsBlocking = true;
|
|
12324
|
+
_aws_cdk_aws_ecs_reduceEc2FargateCloudWatchPermissions = true;
|
|
12325
|
+
_aws_cdk_aws_dynamodb_resourcePolicyPerReplica = true;
|
|
12326
|
+
_aws_cdk_aws_ec2_ec2SumTImeoutEnabled = true;
|
|
12327
|
+
_aws_cdk_aws_appsync_appSyncGraphQLAPIScopeLambdaPermission = true;
|
|
12328
|
+
_aws_cdk_aws_rds_setCorrectValueForDatabaseInstanceReadReplicaInstanceResourceId = true;
|
|
12329
|
+
_aws_cdk_core_cfnIncludeRejectComplexResourceUpdateCreatePolicyIntrinsics = true;
|
|
12330
|
+
_aws_cdk_aws_lambda_nodejs_sdkV3ExcludeSmithyPackages = true;
|
|
12331
|
+
_aws_cdk_aws_stepfunctions_tasks_fixRunEcsTaskPolicy = true;
|
|
12332
|
+
_aws_cdk_aws_ec2_bastionHostUseAmazonLinux2023ByDefault = true;
|
|
12333
|
+
_aws_cdk_aws_route53_targets_userPoolDomainNameMethodWithoutCustomResource = true;
|
|
12334
|
+
recommended_feature_flags_default = {
|
|
12335
|
+
"@aws-cdk/aws-lambda:recognizeLayerVersion": _aws_cdk_aws_lambda_recognizeLayerVersion,
|
|
12336
|
+
"@aws-cdk/core:checkSecretUsage": _aws_cdk_core_checkSecretUsage,
|
|
12337
|
+
"@aws-cdk/core:target-partitions": _aws_cdk_core_target_partitions,
|
|
12338
|
+
"@aws-cdk-containers/ecs-service-extensions:enableDefaultLogDriver": _aws_cdk_containers_ecs_service_extensions_enableDefaultLogDriver,
|
|
12339
|
+
"@aws-cdk/aws-ec2:uniqueImdsv2TemplateName": _aws_cdk_aws_ec2_uniqueImdsv2TemplateName,
|
|
12340
|
+
"@aws-cdk/aws-ecs:arnFormatIncludesClusterName": _aws_cdk_aws_ecs_arnFormatIncludesClusterName,
|
|
12341
|
+
"@aws-cdk/aws-iam:minimizePolicies": _aws_cdk_aws_iam_minimizePolicies,
|
|
12342
|
+
"@aws-cdk/core:validateSnapshotRemovalPolicy": _aws_cdk_core_validateSnapshotRemovalPolicy,
|
|
12343
|
+
"@aws-cdk/aws-codepipeline:crossAccountKeyAliasStackSafeResourceName": _aws_cdk_aws_codepipeline_crossAccountKeyAliasStackSafeResourceName,
|
|
12344
|
+
"@aws-cdk/aws-s3:createDefaultLoggingPolicy": _aws_cdk_aws_s3_createDefaultLoggingPolicy,
|
|
12345
|
+
"@aws-cdk/aws-sns-subscriptions:restrictSqsDescryption": _aws_cdk_aws_sns_subscriptions_restrictSqsDescryption,
|
|
12346
|
+
"@aws-cdk/aws-apigateway:disableCloudWatchRole": _aws_cdk_aws_apigateway_disableCloudWatchRole,
|
|
12347
|
+
"@aws-cdk/core:enablePartitionLiterals": _aws_cdk_core_enablePartitionLiterals,
|
|
12348
|
+
"@aws-cdk/aws-events:eventsTargetQueueSameAccount": _aws_cdk_aws_events_eventsTargetQueueSameAccount,
|
|
12349
|
+
"@aws-cdk/aws-ecs:disableExplicitDeploymentControllerForCircuitBreaker": _aws_cdk_aws_ecs_disableExplicitDeploymentControllerForCircuitBreaker,
|
|
12350
|
+
"@aws-cdk/aws-iam:importedRoleStackSafeDefaultPolicyName": _aws_cdk_aws_iam_importedRoleStackSafeDefaultPolicyName,
|
|
12351
|
+
"@aws-cdk/aws-s3:serverAccessLogsUseBucketPolicy": _aws_cdk_aws_s3_serverAccessLogsUseBucketPolicy,
|
|
12352
|
+
"@aws-cdk/aws-route53-patters:useCertificate": _aws_cdk_aws_route53_patters_useCertificate,
|
|
12353
|
+
"@aws-cdk/customresources:installLatestAwsSdkDefault": _aws_cdk_customresources_installLatestAwsSdkDefault,
|
|
12354
|
+
"@aws-cdk/aws-rds:databaseProxyUniqueResourceName": _aws_cdk_aws_rds_databaseProxyUniqueResourceName,
|
|
12355
|
+
"@aws-cdk/aws-codedeploy:removeAlarmsFromDeploymentGroup": _aws_cdk_aws_codedeploy_removeAlarmsFromDeploymentGroup,
|
|
12356
|
+
"@aws-cdk/aws-apigateway:authorizerChangeDeploymentLogicalId": _aws_cdk_aws_apigateway_authorizerChangeDeploymentLogicalId,
|
|
12357
|
+
"@aws-cdk/aws-ec2:launchTemplateDefaultUserData": _aws_cdk_aws_ec2_launchTemplateDefaultUserData,
|
|
12358
|
+
"@aws-cdk/aws-secretsmanager:useAttachedSecretResourcePolicyForSecretTargetAttachments": _aws_cdk_aws_secretsmanager_useAttachedSecretResourcePolicyForSecretTargetAttachments,
|
|
12359
|
+
"@aws-cdk/aws-redshift:columnId": _aws_cdk_aws_redshift_columnId,
|
|
12360
|
+
"@aws-cdk/aws-stepfunctions-tasks:enableEmrServicePolicyV2": _aws_cdk_aws_stepfunctions_tasks_enableEmrServicePolicyV2,
|
|
12361
|
+
"@aws-cdk/aws-ec2:restrictDefaultSecurityGroup": _aws_cdk_aws_ec2_restrictDefaultSecurityGroup,
|
|
12362
|
+
"@aws-cdk/aws-apigateway:requestValidatorUniqueId": _aws_cdk_aws_apigateway_requestValidatorUniqueId,
|
|
12363
|
+
"@aws-cdk/aws-kms:aliasNameRef": _aws_cdk_aws_kms_aliasNameRef,
|
|
12364
|
+
"@aws-cdk/aws-autoscaling:generateLaunchTemplateInsteadOfLaunchConfig": _aws_cdk_aws_autoscaling_generateLaunchTemplateInsteadOfLaunchConfig,
|
|
12365
|
+
"@aws-cdk/core:includePrefixInUniqueNameGeneration": _aws_cdk_core_includePrefixInUniqueNameGeneration,
|
|
12366
|
+
"@aws-cdk/aws-efs:denyAnonymousAccess": _aws_cdk_aws_efs_denyAnonymousAccess,
|
|
12367
|
+
"@aws-cdk/aws-opensearchservice:enableOpensearchMultiAzWithStandby": _aws_cdk_aws_opensearchservice_enableOpensearchMultiAzWithStandby,
|
|
12368
|
+
"@aws-cdk/aws-lambda-nodejs:useLatestRuntimeVersion": _aws_cdk_aws_lambda_nodejs_useLatestRuntimeVersion,
|
|
12369
|
+
"@aws-cdk/aws-efs:mountTargetOrderInsensitiveLogicalId": _aws_cdk_aws_efs_mountTargetOrderInsensitiveLogicalId,
|
|
12370
|
+
"@aws-cdk/aws-rds:auroraClusterChangeScopeOfInstanceParameterGroupWithEachParameters": _aws_cdk_aws_rds_auroraClusterChangeScopeOfInstanceParameterGroupWithEachParameters,
|
|
12371
|
+
"@aws-cdk/aws-appsync:useArnForSourceApiAssociationIdentifier": _aws_cdk_aws_appsync_useArnForSourceApiAssociationIdentifier,
|
|
12372
|
+
"@aws-cdk/aws-rds:preventRenderingDeprecatedCredentials": _aws_cdk_aws_rds_preventRenderingDeprecatedCredentials,
|
|
12373
|
+
"@aws-cdk/aws-codepipeline-actions:useNewDefaultBranchForCodeCommitSource": _aws_cdk_aws_codepipeline_actions_useNewDefaultBranchForCodeCommitSource,
|
|
12374
|
+
"@aws-cdk/aws-cloudwatch-actions:changeLambdaPermissionLogicalIdForLambdaAction": _aws_cdk_aws_cloudwatch_actions_changeLambdaPermissionLogicalIdForLambdaAction,
|
|
12375
|
+
"@aws-cdk/aws-codepipeline:crossAccountKeysDefaultValueToFalse": _aws_cdk_aws_codepipeline_crossAccountKeysDefaultValueToFalse,
|
|
12376
|
+
"@aws-cdk/aws-codepipeline:defaultPipelineTypeToV2": _aws_cdk_aws_codepipeline_defaultPipelineTypeToV2,
|
|
12377
|
+
"@aws-cdk/aws-kms:reduceCrossAccountRegionPolicyScope": _aws_cdk_aws_kms_reduceCrossAccountRegionPolicyScope,
|
|
12378
|
+
"@aws-cdk/aws-eks:nodegroupNameAttribute": _aws_cdk_aws_eks_nodegroupNameAttribute,
|
|
12379
|
+
"@aws-cdk/aws-ec2:ebsDefaultGp3Volume": _aws_cdk_aws_ec2_ebsDefaultGp3Volume,
|
|
12380
|
+
"@aws-cdk/aws-ecs:removeDefaultDeploymentAlarm": _aws_cdk_aws_ecs_removeDefaultDeploymentAlarm,
|
|
12381
|
+
"@aws-cdk/custom-resources:logApiResponseDataPropertyTrueDefault": _aws_cdk_custom_resources_logApiResponseDataPropertyTrueDefault,
|
|
12382
|
+
"@aws-cdk/aws-s3:keepNotificationInImportedBucket": _aws_cdk_aws_s3_keepNotificationInImportedBucket,
|
|
12383
|
+
"@aws-cdk/aws-ecs:enableImdsBlockingDeprecatedFeature": _aws_cdk_aws_ecs_enableImdsBlockingDeprecatedFeature,
|
|
12384
|
+
"@aws-cdk/aws-ecs:disableEcsImdsBlocking": _aws_cdk_aws_ecs_disableEcsImdsBlocking,
|
|
12385
|
+
"@aws-cdk/aws-ecs:reduceEc2FargateCloudWatchPermissions": _aws_cdk_aws_ecs_reduceEc2FargateCloudWatchPermissions,
|
|
12386
|
+
"@aws-cdk/aws-dynamodb:resourcePolicyPerReplica": _aws_cdk_aws_dynamodb_resourcePolicyPerReplica,
|
|
12387
|
+
"@aws-cdk/aws-ec2:ec2SumTImeoutEnabled": _aws_cdk_aws_ec2_ec2SumTImeoutEnabled,
|
|
12388
|
+
"@aws-cdk/aws-appsync:appSyncGraphQLAPIScopeLambdaPermission": _aws_cdk_aws_appsync_appSyncGraphQLAPIScopeLambdaPermission,
|
|
12389
|
+
"@aws-cdk/aws-rds:setCorrectValueForDatabaseInstanceReadReplicaInstanceResourceId": _aws_cdk_aws_rds_setCorrectValueForDatabaseInstanceReadReplicaInstanceResourceId,
|
|
12390
|
+
"@aws-cdk/core:cfnIncludeRejectComplexResourceUpdateCreatePolicyIntrinsics": _aws_cdk_core_cfnIncludeRejectComplexResourceUpdateCreatePolicyIntrinsics,
|
|
12391
|
+
"@aws-cdk/aws-lambda-nodejs:sdkV3ExcludeSmithyPackages": _aws_cdk_aws_lambda_nodejs_sdkV3ExcludeSmithyPackages,
|
|
12392
|
+
"@aws-cdk/aws-stepfunctions-tasks:fixRunEcsTaskPolicy": _aws_cdk_aws_stepfunctions_tasks_fixRunEcsTaskPolicy,
|
|
12393
|
+
"@aws-cdk/aws-ec2:bastionHostUseAmazonLinux2023ByDefault": _aws_cdk_aws_ec2_bastionHostUseAmazonLinux2023ByDefault,
|
|
12394
|
+
"@aws-cdk/aws-route53-targets:userPoolDomainNameMethodWithoutCustomResource": _aws_cdk_aws_route53_targets_userPoolDomainNameMethodWithoutCustomResource
|
|
12395
|
+
};
|
|
12396
|
+
}
|
|
12397
|
+
});
|
|
12398
|
+
|
|
12168
12399
|
// lib/utils.ts
|
|
12169
12400
|
function exec2(commandLine, options = {}) {
|
|
12170
12401
|
const proc = (0, import_child_process2.spawnSync)(commandLine[0], commandLine.slice(1), {
|
|
@@ -12656,8 +12887,7 @@ var init_cloud_assembly2 = __esm({
|
|
|
12656
12887
|
|
|
12657
12888
|
// lib/runner/runner-base.ts
|
|
12658
12889
|
function currentlyRecommendedAwsCdkLibFlags() {
|
|
12659
|
-
|
|
12660
|
-
return JSON.parse(fs7.readFileSync(recommendedFlagsFile, { encoding: "utf-8" }));
|
|
12890
|
+
return recommended_feature_flags_exports;
|
|
12661
12891
|
}
|
|
12662
12892
|
var path7, import_cdk_cli_wrapper, import_cx_api, fs7, DESTRUCTIVE_CHANGES, IntegRunner, DEFAULT_SYNTH_OPTIONS;
|
|
12663
12893
|
var init_runner_base = __esm({
|
|
@@ -12668,6 +12898,7 @@ var init_runner_base = __esm({
|
|
|
12668
12898
|
import_cx_api = __toESM(require_lib4());
|
|
12669
12899
|
fs7 = __toESM(require_lib5());
|
|
12670
12900
|
init_integ_test_suite();
|
|
12901
|
+
init_recommended_feature_flags();
|
|
12671
12902
|
init_utils2();
|
|
12672
12903
|
init_cloud_assembly2();
|
|
12673
12904
|
DESTRUCTIVE_CHANGES = "!!DESTRUCTIVE_CHANGES:";
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@aws-cdk/integ-runner",
|
|
3
3
|
"description": "CDK Integration Testing Tool",
|
|
4
|
-
"version": "2.
|
|
4
|
+
"version": "2.175.0-alpha.0",
|
|
5
5
|
"main": "lib/index.js",
|
|
6
6
|
"types": "lib/index.d.ts",
|
|
7
7
|
"bin": {
|
|
@@ -57,9 +57,9 @@
|
|
|
57
57
|
},
|
|
58
58
|
"license": "Apache-2.0",
|
|
59
59
|
"devDependencies": {
|
|
60
|
-
"@aws-cdk/cdk-build-tools": "2.
|
|
61
|
-
"aws-cdk-lib": "2.
|
|
62
|
-
"@aws-cdk/pkglint": "2.
|
|
60
|
+
"@aws-cdk/cdk-build-tools": "2.175.0-alpha.0",
|
|
61
|
+
"aws-cdk-lib": "2.175.0",
|
|
62
|
+
"@aws-cdk/pkglint": "2.175.0-alpha.0",
|
|
63
63
|
"@types/fs-extra": "^9.0.13",
|
|
64
64
|
"@types/jest": "^29.5.12",
|
|
65
65
|
"@types/mock-fs": "^4.13.4",
|
|
@@ -71,20 +71,20 @@
|
|
|
71
71
|
"ts-node": "^10.9.2",
|
|
72
72
|
"chokidar": "^3.6.0",
|
|
73
73
|
"@aws-cdk/cloud-assembly-schema": "^39.0.0",
|
|
74
|
-
"@aws-cdk/cloudformation-diff": "2.
|
|
75
|
-
"@aws-cdk/cx-api": "2.
|
|
76
|
-
"@aws-cdk/aws-service-spec": "^0.1.
|
|
74
|
+
"@aws-cdk/cloudformation-diff": "2.175.0",
|
|
75
|
+
"@aws-cdk/cx-api": "2.175.0",
|
|
76
|
+
"@aws-cdk/aws-service-spec": "^0.1.46",
|
|
77
77
|
"cdk-assets": "3.0.0-rc.111",
|
|
78
|
-
"@aws-cdk/cdk-cli-wrapper": "2.
|
|
79
|
-
"aws-cdk": "2.
|
|
78
|
+
"@aws-cdk/cdk-cli-wrapper": "2.175.0-alpha.0",
|
|
79
|
+
"aws-cdk": "2.175.0",
|
|
80
80
|
"chalk": "^4",
|
|
81
81
|
"fs-extra": "^9.1.0",
|
|
82
82
|
"workerpool": "^6.5.1",
|
|
83
83
|
"yargs": "^16.2.0"
|
|
84
84
|
},
|
|
85
85
|
"dependencies": {
|
|
86
|
-
"@aws-cdk/aws-service-spec": "0.1.
|
|
87
|
-
"aws-cdk": "2.
|
|
86
|
+
"@aws-cdk/aws-service-spec": "0.1.46",
|
|
87
|
+
"aws-cdk": "2.175.0"
|
|
88
88
|
},
|
|
89
89
|
"repository": {
|
|
90
90
|
"url": "https://github.com/aws/aws-cdk.git",
|