Skip to content

Latest commit

 

History

History
93 lines (69 loc) · 4.13 KB

README.md

File metadata and controls

93 lines (69 loc) · 4.13 KB

zosia16-site

Django 2.2 version of ZOSIA registration page.

CircleCI

Development

The preferred approach is to use docker for development. And don't worry, we try to keep it as easy as possible. Of course, if you're really not into containerisation, you can try running it without docker, but you may find it harder to debug OS related bugs. Besides, on production site we run this application in docker, so it's better to keep your development process similar to the production one.

Local development (without docker)

Moved here

Full in-docker local development

Required software:

To run docker container you obviously need to have Docker (Community Edition) installed.

Additionally, you should install docker-compose using APT on Debian-based systems:

sudo apt install docker-ce docker-compose

or using PIP:

pip install docker-compose

How can I run it?

To keep things simple we've written dev.sh script that will run everything for you. You simply have to type ./dev.sh one_click. No root permissions are needed. All commands used with the script are listed under ./dev.sh help.

I have run it - what is happening?

First, script needs to build the docker image. This process uses local cache, so it takes time at the first run only, because docker has to pull python image and build every layer. Then two containers have started: zosia_db_1 with Postgres database and zosia_web_1 with our web application.

We mount some local folders so as to let you develop application without rebuilding docker every time:

  • ./app/src as /code/src
  • ./app/js as /code/js
  • ./app/static as /code/static

Thanks to this, all changes you make in the code will be visible immediately inside the container. Remember that this works in both directions! Every change you'll make in the container will affect your local files (from the listed folders), because these are the same files, of course :P

We tried to avoid side effects in our dev.sh script, but sometimes it can't be achieved easily. Some commands may create files inside listed folders. This files will be owned by root, because they were created inside docker. You don't have to worry about them, we listed them in .gitignore file, so they should not appear in git status.

Files created in directory /code/static are output from the webpack build system (these are JS and CSS files). They will be created in your local filesystem and fortunately will be ignored by version control. Moreover, NodeJS module required by our application are installed. They will exist inside docker container only, so they won't be copied into your local filesystem. If you'd like your JS file to be rebuilt after editing them, run command ./dev.sh js_watch in new terminal.

Next, we run migrations on database and, finally, start the web server. In terminal you will see output/logs from django (e.g. queries to the database).

You can shut this server down anytime by clicking CTRL+C, but containers will be still alive. If you want to shut them down as well, you need to run ./dev.sh shutdown command. And if you want to start the web server again, just run ./dev.sh runserver.

Troubleshooting

Creating network "zosia_default" with the default driver
ERROR: could not find an available, non-overlapping IPv4 address pool among the defaults to assign to the network

This error can appear during docker-compose up command if you have VPN activated on your system. There has been no solution found yet. You have to disconnect from VPN, run docker-compose up and when containers are finally up you may enable your VPN again.


Creating network "zosia_default" with the default driver
ERROR: Failed to program FILTER chain: iptables failed: iptables --wait -I FORWARD -o br-123123123123 -j DOCKER: iptables v1.X.Y: Couldn't load target `DOCKER':No such file or directory

In case of that error just restar docker daemon service with that command: systemctl restart docker