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

cdk import picking false changes for NodejsFunction #31999

Open
1 task
mrlikl opened this issue Nov 3, 2024 · 5 comments
Open
1 task

cdk import picking false changes for NodejsFunction #31999

mrlikl opened this issue Nov 3, 2024 · 5 comments
Assignees
Labels
@aws-cdk/aws-lambda-nodejs bug This issue is a bug. cli Issues related to the CDK CLI effort/medium Medium work item – several days of effort p1

Comments

@mrlikl
Copy link
Contributor

mrlikl commented Nov 3, 2024

Describe the bug

When cdk import is comparing the current template with the synth template, it is picking false changes for NodejsFunction. For example, the below code

const rdsSchemaInitializerFunction = new _lambda_node.NodejsFunction(
      this,
      'rds-schema-initializer',
      {
        bundling: {
          minify: true,
          sourceMap: false,
          sourcesContent: false,
          target: 'ES2020'
        },
        runtime: _lambda.Runtime.NODEJS_18_X,
        entry: path.join(__dirname, 'lambda/index.ts')
      }
    )

During deploy time will have the template:

  rdsschemainitializerC99E4CA7:
    Type: AWS::Lambda::Function
    Properties:
      Code:
        S3Bucket:
          Fn::Sub: cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}
        S3Key: 336c1eb9382f4c0e4c84a0a0ef4cadd5d8df8a4921a98338abedd449e7cdaf12.zip
    Metadata:
      aws:cdk:path: CdktsStack/rds-schema-initializer/Resource
      aws:asset:path: asset.336c1eb9382f4c0e4c84a0a0ef4cadd5d8df8a4921a98338abedd449e7cdaf12
      aws:asset:is-bundled: true
      aws:asset:property: Code

and during synth of cdk import is having

"rdsschemainitializerC99E4CA7": {
            "Type": "AWS::Lambda::Function",
            "Properties": {
                "Code": {
                    "S3Bucket": {
                        "Fn::Sub": "cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}"
                    },
                    "S3Key": "eae9438382815864ae642eab331faf132022d63ea8625cc80b327506fbe57216.zip"
                }, 
            "Metadata": {
                "aws:cdk:path": "CdktsStack/rds-schema-initializer/Resource",
                "aws:asset:path": "/Users/muralikl/Downloads/nov3/cdkts",
                "aws:asset:is-bundled": true,
                "aws:asset:property": "Code"
            }
        },

There is no change in the code, but can see that the s3 key is changing for the time being and asset path is also pointing to the file path.

Performing cdk import with --force will ignore this issue and will successfully import the resources.

Regression Issue

  • Select this option if this issue appears to be a regression.

Last Known Working CDK Version

No response

Expected Behavior

cdk import to pick only the final template after synth and compare with the current deployed template

Current Behavior

cdk throwing a false positive change alongside import

Reproduction Steps

import * as cdk from 'aws-cdk-lib';
import { Construct } from 'constructs';
import * as _lambda_node from 'aws-cdk-lib/aws-lambda-nodejs';
import * as _lambda from 'aws-cdk-lib/aws-lambda';
import * as s3 from 'aws-cdk-lib/aws-s3';
import path = require('path/posix')

export class CdktsStack extends cdk.Stack {
  constructor(scope: Construct, id: string, props?: cdk.StackProps) {
    super(scope, id, props);

    const rdsSchemaInitializerFunction = new _lambda_node.NodejsFunction(
      this,
      'rds-schema-initializer',
      {
        bundling: {
          minify: true,
          sourceMap: false,
          sourcesContent: false,
          target: 'ES2020'
        },
        runtime: _lambda.Runtime.NODEJS_18_X,
        entry: path.join(__dirname, 'lambda/index.ts')
      }
    )
   // deploy the above code first and then add the below code to run cdk import
    new s3.Bucket(this, 'test', {
      removalPolicy: cdk.RemovalPolicy.DESTROY
    })
  }
}

Possible Solution

No response

Additional Information/Context

No response

CDK CLI Version

2.165.0

Framework Version

No response

Node.js Version

20.17.0

OS

macos

Language

TypeScript

Language Version

No response

Other information

No response

@mrlikl mrlikl added bug This issue is a bug. needs-triage This issue or PR still needs to be triaged. labels Nov 3, 2024
@ashishdhingra ashishdhingra self-assigned this Nov 4, 2024
@ashishdhingra ashishdhingra added p2 needs-reproduction This issue needs reproduction. and removed needs-triage This issue or PR still needs to be triaged. labels Nov 4, 2024
@khushail
Copy link
Contributor

khushail commented Nov 4, 2024

Hi @mrlikl , thanks for reaching out.

The issue is not reproducible at my end. Sharing the steps and instructions which I did -

  1. Synthesized and deployed this code -
    const rdsSchemaInitializerFunction = new _lambda_node.NodejsFunction(
      this,
      'rds-schema-initializer',
      {
        bundling: {
          minify: true,
          sourceMap: false,
          sourcesContent: false,
          target: 'ES2020'
        },
        runtime: _lambda.Runtime.NODEJS_18_X,
        entry: path.join(__dirname, 'lambda/index.ts')
      }
    )

which produced this template -

"rdsschemainitializerC99E4CA7": {
      "Type": "AWS::Lambda::Function",
      "Properties": {
        "Code": {
          "S3Bucket": {
            "Fn::Sub": "cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}"
          },
          "S3Key": "e0690592dd9efac22e9fedd9ad94ef31d0e6b404bbf9142b33bba636f8bd9287.zip"
        },
        "Handler": "index.handler",
        "Role": {
          "Fn::GetAtt": [
            "rdsschemainitializerServiceRoleBA36691A",
            "Arn"
          ]
        },
        "Runtime": "nodejs18.x"
      },
      "DependsOn": [
        "rdsschemainitializerServiceRoleBA36691A"
      ],
      "Metadata": {
        "aws:cdk:path": "CdkImportIssueStack/rds-schema-initializer/Resource",
        "aws:asset:path": "asset.e0690592dd9efac22e9fedd9ad94ef31d0e6b404bbf9142b33bba636f8bd9287",
        "aws:asset:is-bundled": true,
        "aws:asset:property": "Code"
      }
    },

then I added this section of code -

    new s3.Bucket(this, 'test', {
      removalPolicy: cdk.RemovalPolicy.DESTROY
    })

which synthesized into this -

 "rdsschemainitializerC99E4CA7": {
   "Type": "AWS::Lambda::Function",
   "Properties": {
    "Code": {
     "S3Bucket": {
      "Fn::Sub": "cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}"
     },
     "S3Key": "e0690592dd9efac22e9fedd9ad94ef31d0e6b404bbf9142b33bba636f8bd9287.zip"
    },
    "Handler": "index.handler",
    "Role": {
     "Fn::GetAtt": [
      "rdsschemainitializerServiceRoleBA36691A",
      "Arn"
     ]
    },
    "Runtime": "nodejs18.x"
   },
   "DependsOn": [
    "rdsschemainitializerServiceRoleBA36691A"
   ],
   "Metadata": {
    "aws:cdk:path": "CdkImportIssueStack/rds-schema-initializer/Resource",
    "aws:asset:path": "asset.e0690592dd9efac22e9fedd9ad94ef31d0e6b404bbf9142b33bba636f8bd9287",
    "aws:asset:is-bundled": true,
    "aws:asset:property": "Code"
   }
  },
  "testAF53AC38": {
   "Type": "AWS::S3::Bucket",
   "UpdateReplacePolicy": "Delete",
   "DeletionPolicy": "Delete",
   "Metadata": {
    "aws:cdk:path": "CdkImportIssueStack/test/Resource"
   }
  },

Running cdk diff shows this result -
Screenshot 2024-11-04 at 3 21 11 PM

So in this case, no BucketKey or path is replaced or changed at all.

Could you please share more information on how to repro this scenario?

Thanks

@khushail khushail added response-requested Waiting on additional info and feedback. Will move to "closing-soon" in 7 days. and removed needs-reproduction This issue needs reproduction. labels Nov 4, 2024
@mrlikl
Copy link
Contributor Author

mrlikl commented Nov 6, 2024

Hey @khushail, thank you for taking a look. cdk diff will not have any changes. Do run a cdk import -v, you would get the warning / errors.

@github-actions github-actions bot removed the response-requested Waiting on additional info and feedback. Will move to "closing-soon" in 7 days. label Nov 6, 2024
@khushail khushail added the investigating This issue is being investigated and/or work is in progress to resolve the issue. label Nov 6, 2024
@khushail
Copy link
Contributor

khushail commented Nov 6, 2024

@mrlikl , thanks for sharing that information. I am able to repro the scenario and can see the asset:path being updated to local directory and s3 key also changing -

"rdsschemainitializerC99E4CA7": {
   "Type": "AWS::Lambda::Function",
   "Properties": {
    "Code": {
     "S3Bucket": {
      "Fn::Sub": "cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}"
     },
     "S3Key": "25c1c6edef08cbc19df7e2d16cc9e48e38ca6b33cd05c21ed00741c8754ecaad.zip"
    },
    "Handler": "index.handler",
    "Role": {
     "Fn::GetAtt": [
      "rdsschemainitializerServiceRoleBA36691A",
      "Arn"
     ]
    },
    "Runtime": "nodejs18.x"
   },
   "DependsOn": [
    "rdsschemainitializerServiceRoleBA36691A"
   ],
   "Metadata": {
    "aws:cdk:path": "CdkImportIssueStack/rds-schema-initializer/Resource",
    "aws:asset:path": "/Users/khushail/cdkImportIssue",
    "aws:asset:is-bundled": true,
    "aws:asset:property": "Code"
   }
  },

However I found a somewhat similar issue opened in the past -#31677.
on diving deep into the code implementation. here is what I observed -

  1. Metadata support for aws:assets:path was introduced to support the SAM CLI I to find local assets used by resources in the template. here is an RFC which clearly mentions about adding these Metadata properties during bundling and using lambda function.
    /~https://github.com/aws/aws-cdk/blob/18c19fd49f2b83fee3d1cdb7de8b53ea310729b4/design/code-asset-metadata.md?plain=1#L25C1-L40C4
  2. This statement also mentions how assets path is used -
    * `aws:asset:path` points to the local path of the asset.

so when I am doing cdk import , I see these flag values added -

  'aws:cdk:enable-path-metadata': true,
  'aws:cdk:enable-asset-metadata': true,
  'aws:cdk:version-reporting': true,
  'aws:cdk:bundling-stacks': []

which I think are causing the asset path to change.

However I would reach out to team for getting their insights on this issue and share inputs here as well.

@khushail khushail added p1 effort/medium Medium work item – several days of effort and removed p2 investigating This issue is being investigated and/or work is in progress to resolve the issue. labels Nov 7, 2024
@khushail khushail removed their assignment Nov 7, 2024
@rix0rrr
Copy link
Contributor

rix0rrr commented Nov 13, 2024

Good debugging @khushail, it's definitely about the flags that are being used for synth. Apparently the flags are different between and import-synth and a deploy-synth.

That shouldn't be the case.

However, since this is an issue that affects not too many people and has a clear workaround (--force as mentioned in the report), I'm marking it as p2. Very happy to have this solved, but probably not something we'll prioritize any time soon.

@rix0rrr rix0rrr added p2 cli Issues related to the CDK CLI and removed p1 labels Nov 13, 2024
@iliapolo
Copy link
Contributor

iliapolo commented Jan 8, 2025

Adding some additional context after my investigation.

I'm not sure its actually related to the asset metadata keys because even disabling them (with assetMetadata: false in cdk.json) doesn't resolve the hash discrepancy, although the metadata keys will no longer be there.

@jiayiwang7 jiayiwang7 added the p1 label Jan 13, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
@aws-cdk/aws-lambda-nodejs bug This issue is a bug. cli Issues related to the CDK CLI effort/medium Medium work item – several days of effort p1
Projects
None yet
Development

No branches or pull requests

7 participants