Skip to content

Latest commit

 

History

History
50 lines (37 loc) · 2.95 KB

README.md

File metadata and controls

50 lines (37 loc) · 2.95 KB

🧮 JUMP Math

This repository is a digital math assessment tool made to be used by the JUMP Math team, an award-winning charitable organization dedicated to helping students globally develop an understanding and appreciation of math. As of 2021, the JUMP Math program reached 250,000 students worldwide.

Made with React, GraphQL & Node.js.

Getting Started 🎬

  1. Install Docker Desktop (MacOS | Windows (Home) | Windows (Pro, Enterprise, Education) | Linux). To test that it is running properly, check that these commands give you error-free output.
docker info
docker-compose --version
  1. Clone this repository and cd into the project folder
git clone https://github.com/uwblueprint/jump-math.git
cd jump-math
  1. Pull secrets from Vault: vault kv get -format=json kv/jump-math | python update_secret_files.py
  2. Run the application: docker-compose up --build

The backend runs at http://localhost:5000 and the frontend runs at http://localhost:3000.

References 📚

Workflow Management 🛠

  • Branching: To begin any feature work or bug fixes, branch off of staging. Prefix your branch name with the contributor name and name your branch in a way that is relevant and meaningful. For example, joyce/readme-update.
  • Commits: When working on your branch, commit early and often. Make your commit messages descriptive and meaningful. By default, the linter will run - you must fix all linting errors before merging.
  • Pull Requests: While working on a ticket, open a draft PR. Upon completing and testing your changes locally, click Ready for Review to publish your PR for review. Please tag @carissa-tang, @joyce-shi and any other team members who are working on related tickets as reviewers. Anyone else is also welcome to leave PR reviews! At least one reviewer must approve your PR for you to merge your branch into staging.

Helpful Commands ⛑

Running Tests

# running frontend tests
$ docker exec -it ts-frontend "yarn test"

# running backend tests
$ docker exec -it ts-backend "yarn test"

Linting Manually:

# linting & formatting warnings only
$ docker exec -it jump_math_ts_backend /bin/bash -c "yarn lint"

# linting with fix & formatting
$ docker exec -it jump_math_ts_backend /bin/bash -c "yarn fix"