You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
gears/services/gears_api
androiddrew 3d7e6f29c5 Blacking that code. 5 years ago
..
gears_api Blacking that code. 5 years ago
migrations Blacking that code. 5 years ago
scripts Inital commit 5 years ago
tests Blacking that code. 5 years ago
.coveragerc Inital commit 5 years ago
.gitignore Inital commit 5 years ago
Dockerfile Cleaning up README files and dependencies 5 years ago
LICENSE Inital commit 5 years ago
README.md Cleaning up README files and dependencies 5 years ago
alembic.ini Inital commit 5 years ago
dev_requirements.in Inital commit 5 years ago
dev_requirements.txt Cleaning up README files and dependencies 5 years ago
manage.py Blacking that code. 5 years ago
requirements.in Inital commit 5 years ago
requirements.txt Cleaning up README files and dependencies 5 years ago
setup.cfg Blacking that code. 5 years ago
setup.py Inital commit 5 years ago

README.md

gears_api

API for the gears application

Development

It is helpful to have a clean virtualenv:

python -m venv gears_api_env
source gears_sockets_env/bin/activate

To run the app you will need a postgres database. Create a development and a test database. Update the connection strings within the gears_api.settings.toml. At this time, if you choose to, you can remove the demo Todo code and replace it with your own Model. Otherwise create your first alembic migration using the alembic revision --autogenerate -m "your revision message" command. Finally, apply your first migration with alembic upgrade head.

Running the developement server

A manage.py script has been included with a collection of click cli functions to assist in development.

Note: the developement server command is not a production webserver. You will need to c

python manage.py runserver

Using the interactive interpreter

The manage.py script can be used to open an interactive interpreter with a configured molten application from your project.

python manage.py shell

Dependency management

Dependencies are managed via pip-tools.

Adding a dependency

To add a dependency, edit requirements.in (or dev_requirements.in for dev dependencies) and add your dependency then run pip-compile requirements.in.

Syncing dependencies

Run pip-sync requirements.txt dev_requirements.txt.

Migrations

Migrations are managed using alembic.

Generating new migrations

alembic revision --autogenerate -m 'message'

Running the migrations

alembic upgrade head  # to upgrade the local db
env ENVIRONMENT=test alembic upgrade head  # to upgrade the test db
env ENVIRONMENT=prod alembic upgrade head  # to upgrade prod

Testing

Run the tests by invoking py.test in the project root. Make sure you run any pending migrations beforehand.