pulumi-terraform-to-pulumi▌
pulumi/agent-skills · updated Apr 8, 2026
Critical constraints — read before acting:
Migrating from Terraform to Pulumi
Critical constraints — read before acting:
- Do NOT run
pulumi convert— use the terraform-migrate plugin instead, which preserves state mapping.- Do NOT run
pulumi package add terraform-module— this is for a different workflow.- Do NOT create the Pulumi project under
/workspace— create it inside the checked-out repo.- Replace
${terraform_dir}and${pulumi_dir}below with the actual paths confirmed with the user.
First establish scope and plan the migration by working out with the user:
- where the Terraform sources are (
${terraform_dir}) - where the migrated Pulumi project lives (
${pulumi_dir}) - what is the target Pulumi language (such as TypeScript, Python, YAML)
- whether migration aims to setup Pulumi stack states, or only translate source code
Confirm the plan with the user before proceeding.
Create a new Pulumi project in ${pulumi_dir} in the chosen language. Edit sources to be empty and not declare any
resources. Ensure a Pulumi stack exists.
You must run pulumi_up tool before proceeding to ensure initial stack state is written.
If no local .tfstate file exists in ${terraform_dir}, the state may be in a remote backend (S3, Pulumi Cloud, Terraform Cloud, etc.). Pull it before proceeding:
cd ${terraform_dir} && terraform state pull > terraform.tfstate
This works for all backends, including Pulumi Cloud. If terraform is not available, try tofu state pull instead.
Now produce a draft Pulumi state translation:
pulumi plugin run terraform-migrate -- stack \
--from ${terraform_dir} \
--to ${pulumi_dir} \
--out /tmp/pulumi-state.json \
--plugins /tmp/required-providers.json
Do NOT install the plugin as it will auto-install as needed.
Sometimes terraform-migrate plugin fails because tofu refresh is not authorized. DO NOT skip this step. Work with the
user to find or build a Pulumi ESC environment that provides the necessary credentials so the command can succeed. If setting up an ESC environment is not feasible, inform the user that the migration cannot proceed automatically.
Read the generated /tmp/required-providers.json and install all these Pulumi providers into the new project,
respecting the suggested versions even if they downgrade an already installed provider. The file will contain records
such as [{"name":"aws","version":"7.12.0"}].
Install providers as project dependencies using the language-specific package manager (NOT pulumi plugin install,
which only downloads plugins without adding dependencies):
# TypeScript/JavaScript
npm install @pulumi/aws@7.12.0
# Python
pip install pulumi_aws==7.12.0
# Go
go get github.com/pulumi/pulumi-aws/sdk/v7@v7.12.0
# C#
dotnet add package Pulumi.Aws --version 7.12.0
Import the translated state draft (/tmp/pulumi-state.json) into the Pulumi stack:
pulumi stack import --file /tmp/pulumi-state.json
Translate source code to match both the Terraform source and the translated state. Aim for exact match. You can consult
the state draft /tmp/pulumi-state.json for Pulumi resource types and names to use.
Iterate on fixing the source code until pulumi_preview tool confirms that there are no changes to make and the diff
is empty or almost empty. Provider diffs or diffs on tags may be OK.
Offer the user to link an ESC environment to the stack so that each Pulumi stack can seamlessly have access to the provider credentials it needs.
When all looks good, create a Pull Request with the migrated source code.
Discussion
Product Hunt–style comments (not star reviews)- No comments yet — start the thread.
Ratings
4.5★★★★★46 reviews- ★★★★★Sophia Brown· Dec 28, 2024
pulumi-terraform-to-pulumi fits our agent workflows well — practical, well scoped, and easy to wire into existing repos.
- ★★★★★Aarav Mensah· Dec 24, 2024
I recommend pulumi-terraform-to-pulumi for anyone iterating fast on agent tooling; clear intent and a small, reviewable surface area.
- ★★★★★Aisha Johnson· Nov 19, 2024
pulumi-terraform-to-pulumi is among the better-maintained entries we tried; worth keeping pinned for repeat workflows.
- ★★★★★Maya Park· Nov 15, 2024
Solid pick for teams standardizing on skills: pulumi-terraform-to-pulumi is focused, and the summary matches what you get after install.
- ★★★★★Sakshi Patil· Nov 11, 2024
Registry listing for pulumi-terraform-to-pulumi matched our evaluation — installs cleanly and behaves as described in the markdown.
- ★★★★★Aanya Taylor· Nov 7, 2024
pulumi-terraform-to-pulumi reduced setup friction for our internal harness; good balance of opinion and flexibility.
- ★★★★★Aanya Sethi· Oct 26, 2024
Registry listing for pulumi-terraform-to-pulumi matched our evaluation — installs cleanly and behaves as described in the markdown.
- ★★★★★Aisha Garcia· Oct 10, 2024
Keeps context tight: pulumi-terraform-to-pulumi is the kind of skill you can hand to a new teammate without a long onboarding doc.
- ★★★★★Maya Nasser· Oct 6, 2024
pulumi-terraform-to-pulumi has been reliable in day-to-day use. Documentation quality is above average for community skills.
- ★★★★★Chaitanya Patil· Oct 2, 2024
pulumi-terraform-to-pulumi reduced setup friction for our internal harness; good balance of opinion and flexibility.
showing 1-10 of 46