Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

(@aws-cdk/integ-tests-alpha): Verifying snapshot doesn't read values from cdk.context.json #31069

Open
sfriedlizuehlke opened this issue Aug 9, 2024 · 6 comments
Labels
@aws-cdk/aws-ec2 Related to Amazon Elastic Compute Cloud bug This issue is a bug. effort/medium Medium work item – several days of effort p2

Comments

@sfriedlizuehlke
Copy link

Describe the bug

When running an integration test with integ-runner the verification of the snapshot fails if the integration test contains a VPC.fromLookup(...). The snapshot verification show a difference in the VpcId with the new value being the default VpcID dummy value of vpc-12345.

Expected Behavior

The integ-runner would read the VpcId from the cdk.context.json.

Current Behavior

#> integ-runner integ.bug.ts

Verifying integration test snapshots...

  CHANGED    integ.bug 5.097s
      Resources
[~] AWS::EC2::SecurityGroup sgxxxxxxx replace
 └─ [~] VpcId (requires replacement)
     ├─ [-] vpc-xxxxxxxxxxxxx
     └─ [+] vpc-12345



Snapshot Results: 

Tests:    1 failed, 1 total

As shown in the output above, the VpcId falls back to the default value of vpc-12345.

Reproduction Steps

Define the following integration test:

  1. run with integ-runner --update-on-failed -> this will create the cdk.context.json with the lookup values.
  2. run with integ-runner
import * as cdk from 'aws-cdk-lib';
import * as ec2 from 'aws-cdk-lib/aws-ec2';
import * as integ from '@aws-cdk/integ-tests-alpha';

const REGION = 'eu-central-2';
const ACCOUNT = 'SOME_ACCOUNT_ID';
const VPC_ID = 'some existing vpc id';

const app = new cdk.App({
  context: {
    '@aws-cdk/core:bootstrapQualifier': '<SOME_BOOTSTRAP_QUALIFIER_HERE>',
  },
});

const stack = new cdk.Stack(app, 'integBug', {
  env: {
    account: ACCOUNT,
    region: REGION,
  },
});

const vpc = ec2.Vpc.fromLookup(stack, 'vpc', {
  vpcId: VPC_ID,
});

new ec2.SecurityGroup(stack, 'sg', {
  vpc: vpc,
});

new integ.IntegTest(app, 'integTest', {
  testCases: [stack],
});

Possible Solution

No response

Additional Information/Context

No response

CDK CLI Version

2.148.1 (build 283525d)

Framework Version

No response

Node.js Version

v20.15.0

OS

Linux

Language

TypeScript

Language Version

Typescript (5.5.4)

Other information

No response

@sfriedlizuehlke sfriedlizuehlke added bug This issue is a bug. needs-triage This issue or PR still needs to be triaged. labels Aug 9, 2024
@github-actions github-actions bot added the @aws-cdk/aws-ec2 Related to Amazon Elastic Compute Cloud label Aug 9, 2024
@ashishdhingra ashishdhingra self-assigned this Aug 9, 2024
@ashishdhingra ashishdhingra added investigating This issue is being investigated and/or work is in progress to resolve the issue. and removed needs-triage This issue or PR still needs to be triaged. labels Aug 9, 2024
@ashishdhingra
Copy link
Contributor

ashishdhingra commented Aug 9, 2024

@sfriedlizuehlke Good morning. Thanks for reporting the issue. I was able to reproduce it when my default bootstrapped environment had a different qualifier than the one set here:

const app = new cdk.App({
  context: {
    '@aws-cdk/core:bootstrapQualifier': '<SOME_BOOTSTRAP_QUALIFIER_HERE>',
  },
});

Could you please check:

  • If the qualifier in your bootstrapped environment is same as the one you used in above code for that region (default qualifier is hnb659fds per Use the CDK CLI to customize bootstrapping).
  • If the qualifier is different, then please
    IMPORTANT: Please test re-bootstrapping process in non-prod environment first. I don't think CDK allows to have different environments for different qualifiers (I tried it at my end and it tried to delete existing environment with default qualifier)
    • Re-bootstrap your environment with the --qualifier parameter (check CDK documentation Use the CDK CLI to customize bootstrapping for more details)
    • You would probably need to re-generate snapshots from scratch since it could have references to old qualifier and it my case, it was the default qualifier hnb659fds.

Thanks,
Ashish

@ashishdhingra ashishdhingra added response-requested Waiting on additional info and feedback. Will move to "closing-soon" in 7 days. p3 and removed investigating This issue is being investigated and/or work is in progress to resolve the issue. labels Aug 9, 2024
Copy link

This issue has not received a response in a while. If you want to keep this issue open, please leave a comment below and auto-close will be canceled.

@github-actions github-actions bot added the closing-soon This issue will automatically close in 4 days unless further comments are made. label Aug 12, 2024
@sfriedlizuehlke
Copy link
Author

Hey @ashishdhingra,

The bootstrap qualifier in the integration test is the same that was used for bootstrapping the environment. The deployment of the stacks works fine when I run the integration test with --update-on-failed. So I assume that it is not an issue with the bootstrapQualifier.

Note <SOME_BOOTSTRAP_QUALIFIER_HERE> needs to be replaced in the snippet above, it is just a placeholder.

@github-actions github-actions bot removed closing-soon This issue will automatically close in 4 days unless further comments are made. response-requested Waiting on additional info and feedback. Will move to "closing-soon" in 7 days. labels Aug 12, 2024
@ashishdhingra
Copy link
Contributor

Appears to be reprroducible:

> integ-runner


Verifying integration test snapshots...

  CHANGED    integ.vpc-lookup-test 3.822s
      Resources
[~] AWS::EC2::SecurityGroup sg29196201 replace
 └─ [~] VpcId (requires replacement)
     ├─ [-] vpc-<<redacted>>
     └─ [+] vpc-12345

@ashishdhingra ashishdhingra added p2 effort/medium Medium work item – several days of effort and removed p3 labels Aug 15, 2024
@ashishdhingra ashishdhingra removed their assignment Aug 15, 2024
@graydenshand
Copy link
Contributor

graydenshand commented Jan 23, 2025

This can be resolved using the enableLookups flag. Unfortunately this requires disabling stackUpdateWorkflow.

new integ.IntegTest(app, 'integTest', {
  testCases: [stack],
  enableLookups: true,
  stackUpdateWorkflow: false
});

Enable lookups for this test. If lookups are enabled
then stackUpdateWorkflow must be set to false.
Lookups should only be enabled when you are explicitly testing
lookups

https://github.com/aws/aws-cdk/blob/main/packages/%40aws-cdk/integ-tests-alpha/lib/test-case.ts#L125-L133

@graydenshand
Copy link
Contributor

graydenshand commented Jan 24, 2025

That said... I still hit this issue even with all look ups removed from my tests (creating a new VPC for each test). It doesn't appear to occur when the VPC is the only construct in the test stack. But it does seem to occur when referenced by other constructs.

Using enable_lookups=True, stack_update_workflow=False still is a valid workaround, but it would be nice to enable the update workflow.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
@aws-cdk/aws-ec2 Related to Amazon Elastic Compute Cloud bug This issue is a bug. effort/medium Medium work item – several days of effort p2
Projects
None yet
Development

No branches or pull requests

3 participants