Skip to content

A django boilerplate based on common good practices (such as two scopes of django)

Notifications You must be signed in to change notification settings

martinjobb/Frojd-Django-Boilerplate

 
 

Repository files navigation

Fröjd Django Boilerplate

This is a Django boilerplate that covers best practices and a docker configuration.

Requirements

Installation

With Docker (Recommended)

  1. Setup container .env files

    cd docker/config
    cp db.example.env db.env
    cp web.example.env web.env
    
  2. Retrive your machine ip: docker-machine ip default

  3. Include this ip on your hosts-file

    <your-machine-ip>  <project_domain>.dev
    
  4. Start project

    $(docker-machine env default)
    
    docker-compose up
    
  5. Visit your site on: http://<project_domain>.dev:<project_web_port>

Without Docker (Not recommended)

  1. Make you have all individual components installed:

    • PostgreSQL
    • Python 2.7
    • Pip
    • Virtualenv
  2. Install a virtualenv in your new project folder (virtualenv venv)

  3. Activate the virtualenv: source venv/bin/activate (or on windows: ./venv/Scripts/activate)

  4. Install the requirements from the environment you want (usually local version) with: pip install -r src/requirements/local.txt

  5. Create a database in postgres and remember the database name and user/password

  6. Copy the example.env and rename to .env and change the settings to your projects specific settings (including database etc)

  7. Go into src cd src

  8. Run the migrations to get auth system and the example pages app python manage.py migrate

  9. Create a superuser for your admin: python manage.py createsuperuser

  10. Start the development server: python manage.py runserver

  11. Run python manage.py collectstatic

  12. Visit your site on: http://localhost:8000

Example app

To activate the example app, uncomment it in base.py and it's included urls in urls.py in the core app.

Versioning

This boilerplate uses semantic versioning and follow django's MAJOR and MINOR version numbers, PATCH has no connection to django version, but is something we use to indicate updates.

Bump version in:

  • src/core/settings/base.py (APP_VERSION=0.0.1)
  • frontend/package.json
  • src/Dockerfile

...or just use the bump-version git hook

Style Guide

We follow the django coding style, which is based on PEP8.

Merge conflicts

The project has .gitattributes, but you need to make sure a driver is set up for this, type this is the terminal:

git config --global merge.ours.driver true

Git hooks

Bump version

These hooks will automatically bump the application version when using git flow release ...

chmod +x $PWD/git-hooks/bump-version.sh
ln -nfs $PWD/git-hooks/bump-version.sh .git/hooks/post-flow-release-start
ln -nfs $PWD/git-hooks/bump-version.sh .git/hooks/post-flow-hotfix-start

Run tests pre push

This hook will run the test suite before every push.

chmod +x $PWD/git-hooks/pre-push.sh
ln -nfs $PWD/git-hooks/pre-push.sh .git/hooks/pre-push

Run pep8 validation on commit

chmod +x $PWD/git-hooks/pep8-pre-commit.sh
ln -nfs $PWD/git-hooks/pep8-pre-commit.sh .git/hooks/pre-commit

Note: This requires the pep8 package (pip install pep8)

FAQ

How do I run the app locally with a production setup?

This app includes a docker-compose config that uses uwsgi and nginx. Just run this command.

docker-compose -f docker-compose.yml -f docker-compose-nginx.yml up

How do I sync data from stage/prod?

You can rebuild your application with the latest data dump by running the following

./docker/stage_to_local.sh

Note: This requires that have ssh-key based access to the stage or prod server

How do I install Docker on MacOS?

  1. Install docker (use the Docker Toolbox). Please use the virtualbox version.

    • Minimum requirements are docker 1.11, docker-compose 1.7
  2. Setup machine (if not already present)

    docker-machine create --driver virtualbox default
    docker-machine start default
    

How can I run pdb on the python container?

Start the container with service-ports exposed instead of docker-compose up. This will create a container called <project_prefix>_web_run_1

docker-compose run --rm --service-ports web

How do I run custom manage.py commands?

To run manage.py commands in docker is pretty straightforward, instead of targetting you local machine you just target your web container.

  • Example: Create migrations
docker-compose exec run web python manage.py makemigrations
  • Example: Run migrations
docker-compose exec run web python manage.py migrate

We also have a manage.sh script to make running management commands easier.

scripts/manage.sh makemigrations

How do I add new python dependecies?

First update your requirements/base.txt, then rebuild your container:

docker-compose stop
docker-compose build
docker-compose up

Contributing

Want to contribute? Awesome. Just send a pull request.

License

Fröjd Django Boilerplate is released under the MIT License.

About

A django boilerplate based on common good practices (such as two scopes of django)

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 66.0%
  • Shell 15.0%
  • HTML 10.3%
  • Nginx 7.7%
  • Makefile 1.0%