Deployment made from github action does not have branch

I am in the process of migrating from the vercel github integration to the vercel CLI + github actions for build and deployment of preview branches.

I am running into an issue where the CI-created deployments do not get the right branch or commit name, and therefore to not get a branch-specific URL.

Here’s what my deployments look like with the integration:

And here’s what they look like with the ci-based deployment:

I read through this thread about a similar migration, but could not find any solution: Switching from github integration to manual CI/CD through github actions

I tried adding --git-branch=${{ github.head_ref }} to my vercel pull command, but that didn’t help either. It feels like there’s some env variable or argument that the vercel github integration is using that I’m missing.

Would appreciate any help or advice on this! Let me know if more context is needed.

Hey! Glad that thread was at least adjacent to things other people want to do!

Looking at my deploys from my github workflows, I do seem to have the branch correctly attached to the deployment:

image

Though looking through my workflow, I’m not quite sure how Vercel is getting that information. Maybe it grabs it from the git environment somehow during vercel build or vercel publish? How does your workflow check-out the code? I’m using the latest version of actions/checkout to do it. Possibly if you’re manually running git checkout commands, it thinks you’re on a specific commit rather than a whole branch?

1 Like

Hey - thanks for that thread, it was really helpful!

I believe I’m using a very similar job to yours, at least the one from your sample repo:

deploy_preview:
    name: Build and Deploy Preview to Vercel
    runs-on: ubuntu-latest
    needs: optimize_ci
    if: needs.optimize_ci.outputs.skip == 'false'
    outputs:
      preview_url: ${{ steps.preview-deployment.outputs.preview_url }}
    steps:
      - name: Checkout code
        uses: actions/checkout@v4.1.7
      - name: Install Vercel CLI
        run: npm install --global vercel@latest
      - name: Pull Vercel Environment Information
        run: vercel pull --yes --environment=preview --git-branch=${{ github.head_ref }} --token=${{ secrets.VERCEL_ACCESS_TOKEN }}
      - name: Build Project Artifacts
        run: vercel build --token=${{ secrets.VERCEL_ACCESS_TOKEN }}
      - name: Deploy Project Artifacts to Vercel
        id: preview-deployment
        run: |
          preview_url=$(vercel deploy --prebuilt --token=${{ secrets.VERCEL_ACCESS_TOKEN }})
          echo "preview_url=$preview_url" >> $GITHUB_OUTPUT

Its worth noting that I use Graphite, so most of the updates to my PRs are coming as rebases. I don’t see why that would pose a problem as its all still within the same branch…

What’s the top level on directive look like? If it’s set up to run on individual commits rather than on pushes to branches, I’m wondering if github actions populates the environment differently.

1 Like

Pretty basic setup:

name: Preview CI/CD
on: pull_request
permissions: write-all

env:
  VERCEL_ORG_ID: ${{ secrets.VERCEL_ORG_ID }}
  VERCEL_PROJECT_ID: ${{ secrets.VERCEL_PROJECT_ID }}

Ah so it’s a pull request, I have the workflow for it but haven’t tested it out. In bitbucket/gitlab I think that the ref gets set to the PR number, assumed it was the same for github but guess it’s just the commit tag unfortunately. I’m not seeing any options in the deploy command documentation for manually setting the branch name. If someone more familiar with vercel command line can chime in and mention what deploy uses to get the source data, could try mocking that to return github.head_ref possibly?

1 Like

Hm, I didn’t even realize there was a difference in trigger conditions in your example. That seems to be the reason. If there’s not an easy fix (but I hope there is!) I probably can switch my trigger from pull-request to push in order to fix this.

1 Like

I switched the triggering action from pull_request to push and got a surprising and disappointing result:

Somehow vercel correctly learned that there was a branch attached to this deployment, but it did not create the branch-specific URL, which is what my goal is. @omn1coreprocessing-g - does your version of this create the branch-specific URL?

Still something missing here about how Vercel does this. Would love to here from them on the right way to accomplish this and get the same behavior as the integration.