This is my solution to the technical challenge by Octopuslabs.
Running the project will spin up 4 docker containers:
- A Tornado web application
- A Celery worker that takes care of the asynchronous tasks that power this project
- A MySQL server to persist the application's data
- A Redis server to act as IPC vehicle between the web application and the Celery workers
The repo includes some throwaway settings and keys, to be able to hit the ground running.
Spin un up the containers with:
docker-compose up
- Docker >= 17.09.0
- Docker Compose >= 1.21.0
The project's configuration is set through environment variables.
For more information about each of the configurable paramaters, read their documentation in backend/config.py
- Avoid including production secrets in the repo
- Avoid including production secrets in the container build
- Environment variables should be a non-terrible way to inject sensitive information when launching the services
- Docker Secrets should be the preferred alternative, if the infrastructure permits, since it handles most of the security for us.. I've made the decision of using Docker Secrets in this version of the project
In order to hack on the project you'd:
- Clone the repo
git clone https://github.com/lalvarezguillen/octopus-challenge
- Setup a virtual environment
virtualenv .env
- Install dependencies
pip install -r requirements.dist.txt -r requirements.dev.txt
- Run the tests to make sure everything is working. A bash script has been included for convenience:
bash run_tests.sh
- Break things up
The project has been formatted with Black, and I've deferred every code styling decision to that library.
- Python >= 3.6
- NodeJS
- MySQL
- JS unittests
- Functional tests with Selenium