Automate Your Vue Deployment: A Step-by-Step Guide to Using GitHub Actions
Purbayan Chowdhury
Posted on August 1, 2024
Deploying a Vue application can be a tedious and error-prone process, especially when done manually. But what if you could automate this process, ensuring that your app is deployed quickly, reliably, and with minimal effort? Enter GitHub Actions, a powerful tool that allows you to automate your deployment workflow directly within your GitHub repository.
In this blog post, we'll take you through a step-by-step guide on how to deploy your Vue application using GitHub Actions. We'll cover the benefits of automation, the basics of GitHub Actions, and provide a hands-on tutorial on setting up your first workflow. By the end of this article, you'll be able to streamline your deployment process, focus on building amazing Vue apps, and take your development workflow to the next level.
Getting Started
We start with a VueJS project already pushed to GitHub and use GitHub Actions to deploy it.
Understanding workflow structure
All workflow files should be stored in the .github/workflows
directory. To achieve this, utilize the actions/checkout
and actions/setup-node
actions.
name: Vue app deployment
on:
push:
branches: ["vuetify"]
pull_request:
branches: ["vuetify"]
jobs:
build:
runs-on: ubuntu-latest
strategy:
matrix:
node-version: [18.x, 20.x]
steps:
- uses: actions/checkout@v3
with:
token: ${{ secrets.GH_TOKEN }}
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v3
with:
node-version: ${{ matrix.node-version }}
- name: Build the dist
run: |
npm ci
npm run build --if-present
- name: Commit build to gp-vue
run: |
git config user.name github-actions
git config user.email github-actions@github.com
git --work-tree dist add --all
git commit -m "Vue deployment run by github-actions"
git push origin HEAD:gp-vue --force
shell: bash
Defining the workflow name and the actions to be used. Using a node version of 20.x. and we are welcome to rename the user name and email. The branch name for the deployment is gp-vue, you can change it too.
Create a vuetify branch and push to github
We don't have a branch named vuetify, let's create one
git branch vuetify
git checkout vuetify
git push -u origin vuetify
After successful push, we go to Actions tab in the repo of Github.
Select the recent workflow, to see details if there is a green tick ✅ then the run is successful else check FAQ section of articles for list of errors in details. The details of workflow page is similar to image below:
Setting up the root folder
The final setup for the github pages is selecting the branch and root folder.
Select the Settings tab and click on Pages option in sidebar.
Select branch gp-vue
in Source option and /root
as root folder.
The url for the site is available in the same page as visible above.
There is a custom workflow for github-pages deployment that is also available in Actions tab.
Fixing subdirectory hosting
The subdirectory is not supported by github pages by default. We have to configure the homepage
in our package.json
and configure vue.config.js
to use the subdirectory url.
For example, in the given instance, our url is https://shivishbrahma.github.io/kodakriti/
. So our homepage
should be https://shivishbrahma.github.io/kodakriti/
and the config looks something like below:
{
...
"browserslist": [
"> 1%",
"last 2 versions",
"not dead",
"not ie 11"
],
"homepage": "https://shivishbrahma.github.io/vue-tools/",
"description": "Web Tools built in Vue",
"keywords": [
"portfolio",
"web-tools",
"vue3"
],
...
}
For vue.config.js
file, use the below code:
const { defineConfig } = require("@vue/cli-service");
module.exports = defineConfig({
transpileDependencies: true,
publicPath: (process.env.NODE_ENV === "production") ? "/kodakriti/" : "/"
});
Now the /kodakriti
will be the relative url to the subdirectory, customise accordingly.
FAQs
-
Why using multiple versions for node-setup?
Ans: We are using 18.x and 20.x node versions, because there might be some new or old packages that won't be compiled in one of the 2. But it is advisable to use the node version that you are using in the local setup.
-
What are the possible reasons for failing vue compilation in Github Workflow?
Ans: Here a list of reasons where vue compilation might fail:
- If there are depreciation warnings or any other vue or eslint warnings showing in terminal after
npm run serve
in local. - If you miss to create the same branch name mentioned as trigger on push or pull_request.
- If the node packages being used doesn't support node versions mentioned in the node versions array.
- If there are depreciation warnings or any other vue or eslint warnings showing in terminal after
References
Posted on August 1, 2024
Join Our Newsletter. No Spam, Only the good stuff.
Sign up to receive the latest update from our blog.