THIS PROJECT WAS ARCHIVED ON OCTOBER 9, 2020. ITS CONTENTS HAVE INCORPORATED INTO THE MONOREPO: BOXWISE/BOXTRIBUTE
This is a simple flask app to be used together with the react-client for the revamp of Boxtribute
-
Create an
.env
-file from the fileexample.env
and add values forAUTH0_DOMAIN
andAUTH0_AUDIENCE
. Please use the same ones as for the corresponding react-client. -
To run the application, we assume you have Docker installed. You can then run:
docker-compose up
Boxwise is an application for organisations who run distribution/warehouses in multiple bases. Therefore the development database seed holds at least two organisations and three bases:
- Organisation
BoxAid
working onLesvos
and - Organisation
BoxCare
working onSamos
and inThessaloniki
.
Each organisation has at least 3 user groups with different access levels in the app:
Head of Operations
(Admin access)Coordinator
Volunteer
For each of these three user groups of each of the two organisations we created an login credential for development purposes:
dev_headofops@boxaid.org
dev_coordinator@boxaid.org
dev_volunteer@boxaid.org
dev_headofops@boxcare.org
dev_coordinator@boxcare.org
dev_volunteer@boxcare.org
The password of all of these users is password
.
If you want to connect to the MySQL server from your host machine, you can do this using
docker exec -it <name of the db-docker container, e.g. boxwise-flask_mysql_1> mysql -u root -p
The mysql server in your docker container is also reachable on port 32000
of your localhost
mysql --host=127.0.0.1 --port=32000 -u root -p
The password for the root-user for the db dropapp_dev
is dropapp_root
.
Most of us use workbench to access the MySQL database. To establish a connection you need to enter your localhost
-address, e.g. 127.0.0.1
, for 'Hostname' and 32000
for 'Port'.
At the moment it is easiest if remove your db-docker container with
docker rm <name of the db-docker container, e.g. boxwise-flask_mysql_1>
and restart it afterwards.This is only a short-term solution for now.
This project is developed in Python >= 3.6. For setting up the development environment for the first time, create a Python virtual environment, e.g. by
python3 -m venv .venv
source .venv/bin/activate
pip install -e . -r requirements-dev.txt
pre-commit install --overwrite
Now you're all set up using Python code quality tools! pre-commit
automatically checks the staged patch before committing. If it rejects a patch, add the corrections and try to commit again.
Whenever you start a new shell to run tests, style-checks, or work on some code in general, activate the Python virtual environment
source .venv/bin/activate
Have a look at direnv if you're interested in ways to automate this procedure.
Run the test suite on your machine by executing
pytest
Two types of tests can be setup. Model tests and endpoint tests.
New test files should begin with the word test so the they are discovered when running pytest. for example:
test_<test_file_name>.py
and similarly the test functions should have the format
def test_<test_name>():
For endpoint testing, the test functions usually take two fixtures.
def test_<test_name>(client, database):
to allow for databases to be preconfigured with data and requests to be made to the app.
Fixtures are configured in the conftest.py
files which execute automatically before a test.
Run a full style-check by
pre-commit run --all-files
By default the flask app runs in development
mode which has hot-reloading and debugging enabled.
For debugging an exception in an endpoint, direct your webbrowser to that endpoint. The built-in flask debugger is shown. You can attach a console by clicking the icons on the right of the traceback lines. For more information, refer to the documentation.
Many of our developers are using VSCode which has a very easy-to-use debugger built-in. A launch configuration for the debugger is added to the repo.
To use the debugger:
- install the extensions to access Docker container and to debug python.
- Start the docker containers.
- Attach to the running Docker container for the
web
service. By this step a new VSCode window will open to work from inside theboxwise-flask_web
Docker container. - A new VSCode window pops up which is run from within the docker container
boxwise-flask_web
Docker container. - Open the
/codedir
in the new VSCode which popped up. Thecodedir
folder is the equivalent of the repo folder in the Docker container.
The following step are only required the first time or after you deleted a Docker container: 6. Install the python extension inside the Docker container.
Final steps: 7. Launch the debug configuration called 'Python: Run Flask in docker container to debug'.
You can now set break-points in your code.
If you want to debug a certain endpoint, set a break-point in the endpoint and call this enpoint at the port 5001, e.g.
localhost:5001/api/public
If you want to break on any other code lines (not endpoints), then you can only catch them during the server start-up.
To log to the console from inside the docker container, create an instance of app using:
from flask import Flask
app = Flask(__name__)
and log with:
app.logger.warn(<whatever you want to log>)
We are setting up GraphQL as a data layer for this application. To check out the playground, run this project with the above docker-compose instructions, and go to localhost:5000/graphql. In order to not expose personal data over an unsecured API, we require you to authenticate in order to access the graphQL endpoint. The easiest way to do this currently is:
- start up the frontend (go into the boxwise-react directory and run
yarn && yarn start
), log in with the demo user (user@user.co, ask Hans for the password), and the access token will be printed in the console when you inspect the page (or you can pull it out of the cookies, whatever you want). - paste this long string (it will start with "ey" and then a bunch more stuff) into the bottom left section of the playground labled
HTTP Headers
as the Authorization header.- it will be in the form:
{"Authorization": "Bearer ey.....}
- it will be in the form:
- every so often the validity of your access token will time out, so you will need to re-authenticate via the frontend and then paste a new token into the playground.
A sample query you can try is:
query {
allBases {
name
}
}
We are use CircleCI for automated testing of PRs and deployment to Google Cloud. To develop the CircleCI scripts you can run a CircleCI client locally. Please check out the documentation.
The most important commands are
circleci config validate
circleci local execute --job JOB_NAME
- You can only trigger a job locally if it is part of a CircleCI workflow.
- Each
run
-step in the config of CircleCI should be treated as its own terminal. If you have for example activated an virtual environment in arun
-step, this environment is not activated in the nextrun
-step.
We are using Docker containers to make it easy for everyone to spin up an development environment which is the same everywhere. In docker-compose.yaml
two docker containers are specified - one for the mysql database called mysql
and one for the flask backend called web
.
In the docker-compose file we define a separate docker network called backend
to which both containers are joined. Each container can now look up the hostname web
or mysql
and get back the appropriate container’s IP address.
To access the mysql database from the web
container there are now two ways:
- For example, you reach the mysql db at
MYSQL_HOST=mysql
andMYSQL_PORT=3306
or - by specifying the IP-address of the Gateway for
MYSQL_HOST
andMYSQL_PORT=32000
.
To figure out the gateway of the docker network backend
run
docker network inspect -f '{{range .IPAM.Config}}{{.Gateway}}{{end}}' boxwise-flask_backend
You can choose one of the two and specify the credentials in the .env
-file.
See the LICENSE for license rights and limitations (Apache 2.0).