🥳📱 What If Expo Previews Were as Seamless as Vercel Deployments? 🫰
If you’ve ever used Vercel’s Preview Deployments, you know how magical it feels: open a PR, and boom—a live URL is ready to share. No manual deployments, no waiting around.
data:image/s3,"s3://crabby-images/ec5c3/ec5c31568a84f646cf90b9e5366ebc6792cb418b" alt="notion image"
Wouldn’t it be great if we had something just as seamless for Expo mobile apps?
That’s exactly what we built. With a simple GitHub Action, every PR now automatically generates an Expo QR Code, allowing you to preview changes instantly on your phone—just like Vercel!
And the best part? It takes less than a minute to set up! ⏳
Let’s dive in. 👇
🔧 Step 1: Add the Required Secrets to GitHub
1️⃣ Create a GitHub Personal Access Token (GH_PAT
)
- Click "Generate new token (classic)"
- Set an Expiration Date (choose a long duration to avoid frequent updates)
- Select the following scopes:
- ✅
repo
(Full control of private repositories) - ✅
workflow
(Allows GitHub Actions to access workflows) - ✅
read:packages
(If you use private npm packages)
- Click "Generate token" and copy it
- Go to your GitHub Repo → Settings → Secrets
- Add a new secret with the name
GH_PAT
and paste the token
2️⃣ Create an Expo Token (EXPO_TOKEN
)
You can create this token directly from your Expo project settings:
- Open Expo.dev
- Go to Account Settings → Access Tokens
- Click "Generate New Token"
- Copy the token and add it as a GitHub Secret named
EXPO_TOKEN
🛠️ Step 2: Add the GitHub Action for Expo Previews
Now that we have our tokens, we need to set up GitHub Actions:
- Create a new file in your repo:
.github/workflows/expo-preview.yml
- Copy and paste the following GitHub Actions workflow:
🎯 Step 3: Open a PR and Get Your Expo Preview
Now, whenever you open or update a PR, GitHub Actions will:
✅ Start an Expo preview server
✅ Generate a QR code
✅ Automatically comment on the PR with the preview link
data:image/s3,"s3://crabby-images/3e24e/3e24edf7c8e8997a7c44bc68c43c587c3c2a2256" alt="notion image"
🥳 And that’s all folks, enjoy your new automated Expo PR process! 🥳
🔍 Why This Works So Well (and Why We Built It This Way)
🔹 Inspired by Vercel’s Previews
Vercel changed how we ship frontend apps. We wanted that same smooth experience for Expo & React Native projects.
🔹 Mobile-First Collaboration
No need to manually start an Expo server and send links in Slack. Now, every PR comes with a built-in preview link.
🔹 Faster Testing, Fewer Headaches
Easier QA testing and faster feedback loops from designers, PMs, and stakeholders.
⚡ Common Issues & Troubleshooting
❌ GitHub Actions Failing?
Make sure:
- You added both
GH_PAT
andEXPO_TOKEN
to GitHub Secrets
- Your Expo account has permissions to generate a preview
- Try restarting Expo CLI in your local environment to see if it works.
❌ QR Code Isn’t Showing in PR Comments?
Check the PR Actions Logs in GitHub to see if the Expo server started correctly.
❌ Still having issues?
👉 Email us or join our Discord for help!
💡 Final Thoughts
With this simple GitHub Action, you can completely automate Expo previews for your PRs, just like Vercel does for web apps.
No more manually sharing links. No more waiting for someone to start an Expo server. Just scan the QR code and test instantly.
🚀 Want More Guides Like This? Get our best tips in your inbox by joining our Newsletter!