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

Generated program that uses, say, pulumi.asset module doesn't import the module in the program #87

Open
MitchellGerdisch opened this issue May 22, 2024 · 0 comments
Labels
kind/bug Some behavior is incorrect or out of spec

Comments

@MitchellGerdisch
Copy link

What happened?

I asked AI the following:

I want a lambda hello-world function with the function code in the pulumi program and I want the program to output a link that can be used to test the lambda

The program it generates includes

// Define the inline code for the Lambda function
const lambdaCode = `exports.handler = async (event) => {
    console.log("Hello World");
    return {
        statusCode: 200,
        body: JSON.stringify('Hello World'),
    };
};`;

// Create the Lambda function with the inline code
const lambdaFunction = new aws.lambda.Function("helloWorldFunction", {
    code: new pulumi.asset.AssetArchive({
        "index.js": new pulumi.asset.StringAsset(lambdaCode),
    }),
    role: lambdaRole.arn,
    handler: "index.handler",
    runtime: aws.lambda.Runtime.NodeJS12dX,
});

As you can see it uses pulumi.asset.StringAsset but the generated program does not include
`import * as pulumi from "@pulumi/pulumi";

This is especially vexing when using Pulumi AI in new project wizard since the deployment naturally fails.

Example

See above.

Output of pulumi about

N/A

Additional context

There is an additional problem in the above code in that it uses specifies node 12 for the lambda runtime but AWS no longer supports node 12 for lambda.

And FWIW, the following prompt generates usable code:

I want a lambda hello-world function with the function code in the pulumi program and I want the program to output a link that can be used to test the lambda and don't forget to include the pulumi/pulumi package and be sure to use node 18 for the lambda runtime

Contributing

Vote on this issue by adding a 👍 reaction.
To contribute a fix for this issue, leave a comment (and link to your pull request, if you've opened one already).

@MitchellGerdisch MitchellGerdisch added kind/bug Some behavior is incorrect or out of spec needs-triage Needs attention from the triage team labels May 22, 2024
@AaronFriel AaronFriel removed the needs-triage Needs attention from the triage team label Jun 3, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
kind/bug Some behavior is incorrect or out of spec
Projects
None yet
Development

No branches or pull requests

2 participants