Skip to content

React/Flask app on Heroku starter repo for UT Austin Software Engineering Fall 2022.

Notifications You must be signed in to change notification settings

evmaki/ee461-react-flask-heroku

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

React/Flask Starter App on Heroku

This is a barebones repo used to demonstrate the setup and deployment of a React/Flask app hosted on Heroku for EE461L, Software Engineering & Design.

app.py

This contains the Flask backend. The / route serves up the built React app that is placed in /ui/build/ each time you build the React frontend. You can run the backend by running the following on your command line in the top-level directory:

flask run

/ui

This contains the React frontend. Run npm install after cloning this repo to install the node_modules.

Each time you make changes to it, you need to manually build it by running the following on the command line in the /ui directory:

npm run build

requirements.txt

This is a list of Python libraries used by your Flask backend. Heroku uses it to install all of the dependencies used by your Flask app.

Suggested Workflow

Follow this suggested workflow as you make changes to increase your chances of success:

  1. Fork this repo, then clone it using git clone https://github.com/yourgithubusername/ee461-react-flask-heroku.git
  2. Open two terminals: one for working on React and another for Flask. We'll call these "React terminal" and "Flask terminal".
  3. Install React dependencies. In your React terminal, cd ui then npm install.
  4. Build the React app. Run npm run build in your React terminal, in the ui directory.
  5. Start the Flask app. Run flask run in your Flask terminal, in the same directory as app.py.
  6. Go to localhost:5000 in your browser. The starter React app page should show up.
  7. When you make changes to your React app, repeat step 4.
  8. When you make changes to your Flask app, repeat step 5.
  9. When you are ready to deploy:
    • Create a new app on Heroku
    • Connect Heroku to your GitHub account (if you haven't already)
    • Search for this repository under your new Heroku app > Deploy > Connect to GitHub (bottom of the page) and connect to it
    • At the bottom of the Deploy page under Manual deploy, select the main branch and click Deploy Branch
    • If/when deployment fails, view the build log to learn why

FAQ

Q: Why isn't it working when I try to deploy to Heroku?

A: If you try to deploy this repository with no changes it should work. The first place to look is the build logs that are generated when you try to deploy.

  • If your error appears under "Installing requirements with pip" in the build logs, you are probably missing a Python dependency in requirements.txt. Make sure any additional libraries you are using for your Flask app are included in requirements.txt.
  • If your error happens AFTER deployment when you try to access the app in the browser, then you might have a bug in your Flask app that is causing it to crash. Access your app on the Heroku web panel, go to "More" on the top-ish right-hand side, and go to "View logs". These logs are equivalent to the terminal output you see when running a Python program on your computer. There is useful information there that will help you debug your app.

Q: I'm using PowerShell on Windows and I get "Error: Could not locate Flask application. You did not provide the FLASK_APP environment variable." when trying to run the Flask app.

A: First, make sure you are running flask run in the right directory (the top-level directory of this repo, where app.py is). If you still get the error, try setting your FLASK_APP environment variable in PowerShell by running the following: $env:FLASK_APP="app"

About

React/Flask app on Heroku starter repo for UT Austin Software Engineering Fall 2022.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages