Skip to content

Latest commit

 

History

History
73 lines (53 loc) · 2.83 KB

README.md

File metadata and controls

73 lines (53 loc) · 2.83 KB

Build Status

Assistive Chess Robot Server

This is the server for the assistive chess robot created by Team -i^2 for the System Design Project 2019 at the University of Edinburgh.

Structure of repo

The repository is laid out in the following structure:

|
\ server - Contains all code for the flask app
| \
| | __init__.py - To make server into an importable module
| | server.py - Contains the entry point for the Flask app
| | ...
|
\ test - All tests
| \
| | __init__.py - Allows server module to be imported
| | test_main.py - A test file
| | ...
|
| .gitignore - Files that shouldn't be committed by Git
| .travis.yml - Configuration for the CI
| README.md - This readme file

Gettting Started

Pre-requisites

  • Heroku CLI
  • Python 3
  • virtualenv

Run the following to set up a virtual environment. This will make sure that you are running the correct version of Python and that your libraries won't clash with versions if working on multiple Python projects.

$ cd negativei2-server
$ virtualenv --python=python3 venv
$ . venv/bin/activate
(venv) $ pip install -r requirements.txt

To run the application or to test it, you need to define the following environment variables:

  • FIREBASE_SERVICE_ACCOUNT_JSON This contains the contents of the private key JSON that you download after setting up a service account. https://firebase.google.com/docs/admin/setup
  • GOOGLE_APPLICATION_CREDENTIALS This is the location of the file that we write out the contents of FIREBASE_SERVICE_ACCOUNT_JSON to, currently this should be set to firebase_account_cred.json.

The tests are all found in /tests and can be run with pytest. The tests expect that the environment variable CI=true is present.

Run the following to start the application.

$ heroku local
3:59:29 PM web.1 |  [2019-02-12 15:59:29 +0000] [26045] [INFO] Starting gunicorn 19.9.0
3:59:29 PM web.1 |  [2019-02-12 15:59:29 +0000] [26045] [INFO] Listening at: http://0.0.0.0:5000 (26045)
3:59:29 PM web.1 |  [2019-02-12 15:59:29 +0000] [26045] [INFO] Using worker: sync
3:59:29 PM web.1 |  [2019-02-12 15:59:29 +0000] [26048] [INFO] Booting worker with pid: 26048

You can then visit the server by going to http://localhost:5000 in your browser. Press Ctrl+C to stop the application.

Contributing

No commits are allowed directly to master. All PRs to master need to pass status checks and be reviewed by at least one other contributor. Ideally, all pull requests should come with tests for the code within.

Branch naming - The convention <username>/<descriptive word or phrase> should be used.

License

This code is licensed under the GPL v3.0. For the full license text, please refer to LICENSE.md.