Skip to content

feat(cli): add vercel env run command#14582

Merged
julianbenegas merged 6 commits intomainfrom
jb/env-run-command
Jan 12, 2026
Merged

feat(cli): add vercel env run command#14582
julianbenegas merged 6 commits intomainfrom
jb/env-run-command

Conversation

@julianbenegas
Copy link
Copy Markdown
Contributor

Adds a new subcommand that runs any command with environment variables from the linked Vercel project, without writing them to the filesystem.

Usage

vercel env run -- next dev
vercel env run -e preview --git-branch feature-x -- npm test

Options

  • --environment, -e - Target environment (default: development)
  • --git-branch - Git branch for env overrides

How it works

  1. Fetches environment variables using the same API as vercel env pull
  2. Does NOT write them to the filesystem
  3. Spawns the user's command with all env vars exported
  4. Returns the child process exit code

Adds a new subcommand that runs any command with environment variables
from the linked Vercel project, without writing them to the filesystem.

Usage:
  vercel env run -- next dev
  vercel env run -e preview --git-branch feature-x -- npm test

Options:
  --environment, -e  Target environment (default: development)
  --git-branch       Git branch for env overrides
@changeset-bot
Copy link
Copy Markdown

changeset-bot bot commented Jan 11, 2026

🦋 Changeset detected

Latest commit: 7c6b6fc

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 1 package
Name Type
vercel Minor

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@github-actions
Copy link
Copy Markdown
Contributor

github-actions bot commented Jan 11, 2026

📦 CLI Tarball Ready

The Vercel CLI tarball for this PR is now available!

Quick Test

You can test this PR's CLI directly by running:

npx https://vercel-22ob6djpj.vercel.sh/tarballs/vercel.tgz --help

Use in vercel.json

To use this CLI version in your project builds, add to your vercel.json:

{
  "build": {
    "env": {
      "VERCEL_CLI_VERSION": "vercel@https://vercel-22ob6djpj.vercel.sh/tarballs/vercel.tgz"
    }
  }
}

@julianbenegas julianbenegas marked this pull request as ready for review January 11, 2026 18:19
@julianbenegas julianbenegas requested a review from a team as a code owner January 11, 2026 18:19
@github-actions
Copy link
Copy Markdown
Contributor

github-actions bot commented Jan 11, 2026

🧪 Test Strategy

Comparing: 3400d777c6b6fc (view diff)

Strategy: Affected packages only

✅ Only testing packages that have been modified or depend on modified packages.

Affected packages - 1 (3%)
  1. vercel
Unaffected packages - 39 (98%)
  1. @vercel-internals/get-package-json
  2. @vercel/backends
  3. @vercel/build-utils
  4. @vercel/cervel
  5. @vercel/cli-auth
  6. @vercel/client
  7. @vercel/config
  8. @vercel/detect-agent
  9. @vercel/edge
  10. @vercel/elysia
  11. @vercel/error-utils
  12. @vercel/express
  13. @vercel/fastify
  14. @vercel/firewall
  15. @vercel/frameworks
  16. @vercel/fs-detectors
  17. @vercel/functions
  18. @vercel/gatsby-plugin-vercel-builder
  19. @vercel/go
  20. @vercel/h3
  21. @vercel/hono
  22. @vercel/hydrogen
  23. @vercel/introspection
  24. @vercel/nestjs
  25. @vercel/next
  26. @vercel/node
  27. @vercel/oidc
  28. @vercel/oidc-aws-credentials-provider
  29. @vercel/python
  30. @vercel/python-analysis
  31. @vercel/redwood
  32. @vercel/related-projects
  33. @vercel/remix-builder
  34. @vercel/routing-utils
  35. @vercel/ruby
  36. @vercel/rust
  37. @vercel/static-build
  38. @vercel/static-config
  39. examples

Results

  • Unit tests: Only affected packages will run unit tests
  • E2E tests: Only affected packages will run e2e tests
  • Type checks: Only affected packages will run type checks

This comment is automatically generated based on the affected testing strategy

Copy link
Copy Markdown
Member

@tknickman tknickman left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good, no main blockers. One thing that may be nice to add would be mentioning when -- is required. For example If a user runs vercel env run echo hello (without --), This will just show "No command provided".

It might be slightly more helpful to hint that -- is required, e.g., "No command provided. Use -- to separate vercel flags from your command."

Copy link
Copy Markdown
Member

@tknickman tknickman left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Approving to unblock

@julianbenegas
Copy link
Copy Markdown
Contributor Author

Looks good, no main blockers. One thing that may be nice to add would be mentioning when -- is required. For example If a user runs vercel env run echo hello (without --), This will just show "No command provided".

It might be slightly more helpful to hint that -- is required, e.g., "No command provided. Use -- to separate vercel flags from your command."

fixed 7c6b6fc

@julianbenegas julianbenegas merged commit e809438 into main Jan 12, 2026
309 of 326 checks passed
@julianbenegas julianbenegas deleted the jb/env-run-command branch January 12, 2026 18:03
tknickman pushed a commit that referenced this pull request Jan 12, 2026
This PR was opened by the [Changesets
release](https://github.com/changesets/action) GitHub action. When
you're ready to do a release, you can merge this and the packages will
be published to npm automatically. If you're not ready to do a release
yet, that's fine, whenever you add more changesets to main, this PR will
be updated.


# Releases
## vercel@50.2.0

### Minor Changes

- Add `vercel env run` command to run commands with environment
variables from the linked Vercel project without writing them to the
filesystem ([#14582](#14582))

- Merge computed rewrites/redirects to routes in Vercel config
([#14518](#14518))

### Patch Changes

- Adding in user configured deploymentId to build output type
([#14497](#14497))

- skip secondary installation for vercel.ts
([#14471](#14471))

- Updated dependencies
\[[`2eb1b7678bece13e442f8404d519bd07891eb500`](2eb1b76),
[`39c95ff6b643a63509571818e67a792df09fd71f`](39c95ff),
[`d63084dac296ccb2077ed742bc2ade0264da851d`](d63084d)]:
    -   @vercel/next@4.15.11
    -   @vercel/build-utils@13.2.5
    -   @vercel/redwood@2.4.6
    -   @vercel/rust@1.0.4
    -   @vercel/static-build@2.8.16
    -   @vercel/backends@0.0.18
    -   @vercel/elysia@0.1.16
    -   @vercel/express@0.1.23
    -   @vercel/fastify@0.1.19
    -   @vercel/go@3.3.0
    -   @vercel/h3@0.1.25
    -   @vercel/hono@0.2.19
    -   @vercel/hydrogen@1.3.3
    -   @vercel/nestjs@0.2.20
    -   @vercel/node@5.5.17
    -   @vercel/python@6.1.6
    -   @vercel/remix-builder@5.5.6
    -   @vercel/ruby@2.2.4

## @vercel/build-utils@13.2.5

### Patch Changes

- Adding in user configured deploymentId to build output type
([#14497](#14497))

- skip secondary installation for vercel.ts
([#14471](#14471))

## @vercel/client@17.2.19

### Patch Changes

- Updated dependencies
\[[`e725853a6c41bed634d1e3e2382596f17a18f342`](e725853),
[`39c95ff6b643a63509571818e67a792df09fd71f`](39c95ff),
[`d63084dac296ccb2077ed742bc2ade0264da851d`](d63084d),
[`567d2d41e685cd949274411ce0e60e61a3dc3942`](567d2d4)]:
    -   @vercel/routing-utils@5.3.2
    -   @vercel/build-utils@13.2.5

## @vercel/elysia@0.1.16

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.5.17

## @vercel/express@0.1.23

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.5.17

## @vercel/fastify@0.1.19

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.5.17

## @vercel/fs-detectors@5.7.12

### Patch Changes

- Updated dependencies
\[[`e725853a6c41bed634d1e3e2382596f17a18f342`](e725853),
[`567d2d41e685cd949274411ce0e60e61a3dc3942`](567d2d4)]:
    -   @vercel/routing-utils@5.3.2
    -   @vercel/frameworks@3.15.4

## @vercel/gatsby-plugin-vercel-builder@2.0.115

### Patch Changes

- Updated dependencies
\[[`39c95ff6b643a63509571818e67a792df09fd71f`](39c95ff),
[`d63084dac296ccb2077ed742bc2ade0264da851d`](d63084d)]:
    -   @vercel/build-utils@13.2.5

## @vercel/h3@0.1.25

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.5.17

## @vercel/hono@0.2.19

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.5.17

## @vercel/nestjs@0.2.20

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/node@5.5.17

## @vercel/next@4.15.11

### Patch Changes

- Add early validation for Next.js output directory and improve error
messages to guide users when the output directory is missing, empty, or
misconfigured. Introduces new error codes `NEXT_OUTPUT_DIR_MISSING` and
`NEXT_OUTPUT_DIR_EMPTY` with actionable guidance for common issues like
Turborepo cache misconfiguration.
([#14542](#14542))

## @vercel/node@5.5.17

### Patch Changes

- Updated dependencies
\[[`39c95ff6b643a63509571818e67a792df09fd71f`](39c95ff),
[`d63084dac296ccb2077ed742bc2ade0264da851d`](d63084d)]:
    -   @vercel/build-utils@13.2.5

## @vercel/routing-utils@5.3.2

### Patch Changes

- Add respectOriginCacheControl to rewritesSchema
([#14506](#14506))

- Add respectOriginCacheControl to routes schema
([#14565](#14565))

## @vercel/static-build@2.8.16

### Patch Changes

-   Updated dependencies \[]:
    -   @vercel/gatsby-plugin-vercel-builder@2.0.115

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants