/django-template

A template for creating a django project

Primary LanguagePython

{% if not project_name %}

Project template

You can create a new project out of this template by using a gist.

Requirements:

  • python3
  • bash
  • wget
  • docker and docker-compose in version 1.10.0+

Do the following, replace <project_name> with your desired project name:

wget -O - https://gist.githubusercontent.com/mjainta/2e57c4b04d1bb9c526dc0843b4353aa5/raw/fbf135ae7b0935581c101136f2fd802747b21cf8/start-django-project.sh | bash -s <project_name>

This will create a folder called project_name in the current directory.

{% endif %}# {{ project_name|title }}

Setup working environment

$ make

This will build all necessary docker images and start them up.

Executing tests

(myenv) $ make coverage

This will execute all unittests it finds in the {{ project_name }}.tests module. Also coverage is enabled which ends up in a file called .coverage in the root directory. Coverage also generates a html report in coverage_html_report and after prints a summary to stdout.

By configuration, we aim to get a minimum code coverage of 95% Remember to use coverage before committing so the build will not fail after pushing!

If you do not want coverage to be executed, use make test instead

(myenv) $ make test

Both commands also work with a subset of the tests:

(myenv) $ make coverage TESTMODULE={{ project_name }}.tests.models

Settings for the coverage tool can be found in the .coveragerc file.

Use the Linter

We use pylint for linting functionality.

First, install the pre-commit hook which will check your files with the linter before you commit.

Remember, since it creates a pre-commit hook you need to init the git repository first.

(myenv) $ make install_pre_commit

This will create the file .git/hooks/pre-commit with the desired hook for the linter.

You can also use pylint directly if you want to check every file (except a few which get ignored).

(myenv) $ make lint

Settings for the linter can be found in the .pylintrc file.

The pylint manual can be found here.

Using postgresql

Built-in the template will use a postgresql database, instead of the sqlite default.

If you want to use sqlite instead, delete the according lines from the files:

  • [base.py]({{ project_name }}/settings/base.py)
  • [base.py]({{ project_name }}/settings/test.py)
  • In base.txt remove the psycopg2 library.
  • In docker-compose.yml remove the postgres container and the link for it.

Connect to it via make psql.

Data is not preserved by default! Modify docker-compose.yml to use volumes if you need to.

Documentation on the postgresql image is found on hub.docker.com.

Starting an interactive python shell

make shell

Running custom commands in the python container

$ docker-compose run --rm py <your command>

Deployment

The requirements the loaded in the docker build process during make images.

Requirements are held in their files, respectively: test / development / staging / production

base should be included for every stage.

GitLab

You can use GitLab-CI for deployment, the .gitlab-ci.yml may help in setting up the build and deployment system.

Out of the box it has to stages:

  • build: Creates a new docker container and saves it into the gitlab Registry
  • test: Uses the created container for executing tests and linting