React apps are one of my favorites when I need to build with Firebase. The main reason is the simplicity of the framework and the community support that backs it. But when it comes to continuous deployment, it’s always a big challenge. I always used to use Netlify for that since it supports automatic deployment with Github Push.
Thankfully Firebase recently came up with their own Github Actions workflow for deploying directly to Firebase Hosting on your trigger. So let’s get started with it!
Setting Up React App
For this demo, I’ve used create-react-app to create a simple new React app that I’ll be publishing to Firebase Hosting.
Creating a React app with this tool is pretty straightforward, all you need to do is to run the below script,
This will create a folder named firebase-hosting-demo
in your project folder and installs all the dependencies. The repo is generated along with the git integration so we don’t have to initialize it separately.
You can also follow the next steps in your old react app project.
Setting up Github Repository
This is one of the most common and important steps software developers do when they handle any project. Still, I would like to go through this for the beginners.
Create a new GitHub repository by visiting this link: https://repo.new/ .
Once you’ve created the remote repository in GitHub, now it’s our turn to push the local repository to GitHub. By default the React create app will initialize a git repository, but in case if it didn’t or you’re using a React Project created by a different tool use the following command to initialize a git repository inside your folder.
Once you initialize the repo, you need to add all the files for git to track and then commit.
Finally, now that the changes and new files are committed, we can push it to our remote repo. But before pushing you need to add the remote repo to your local repository and then push it.
Setting up Github Actions
Now that we’ve configured the local and remote repo, let’s create the new Github action configuration to auto-deploy to firebase.
Navigate to the Actions tab in your GitHub repo and click on the “set up a workflow yourself”.
And in the file, copy the below configuration and commit.
According to this workflow, the React app is installed and built with the following config
And the compiled code is published to Firebase with the below config.
If you notice the above configuration, the FIREBASE_SERVICE_ACCOUNT is a part of the secret since it cannot be exposed. In the following steps, we’ll see how to configure the service account.
Configuration of Firebase Service Account in Github
To make Github push to Firebase, you need to configure the service account. But to extract the service account, follow these steps.
Navigate to Project Settings from the sidebar.
Click on the Service Accounts tab on the settings page
Click on the “Generate new private key” Button to generate a new one
Copy the contents of the downloaded file.
Navigate to your GitHub repository’s settings page. And open the secrets section from the sidebar
Click on the “New secret” button.
The name of the new secret should be FIREBASE_SERVICE_ACCOUNT
and the value should be the contents of the firebase service account JSON we downloaded in the previous steps
After saving, we’re all set to auto-deploy to firebase hosting for every push to your GitHub repository.
I’m super excited about this workflow since it will reduce a lot of effort required to compile locally every time and then push it to Firebase hosting. In my next article, I’ll cover how to use Firebase hosting’s preview channels that recently launched. Stay tuned!
Subscribe to our newsletter
Get the latest updates from our team delivered directly to your inbox.
Related Posts
10 Gems in Ruby that you will love
Let's go back to basics with Ruby on Rails and see some of the Gems that we use everyday at skcript. #StartWithSkcript
#100DaysOfCommits
Our CTO, Swaathi, talks about our commitment to the #100DaysOfCommit challenge. Join us.
18 Python packages you should be using right now
Let us look at some python packages that will get you started on your machine learning path #StartWithSkcript