Skip to content
This repository was archived by the owner on Oct 2, 2024. It is now read-only.

Commit 08415e8

Browse files
committed
Introduce devcontainer
1 parent 60e77b6 commit 08415e8

File tree

5 files changed

+114
-11
lines changed

5 files changed

+114
-11
lines changed

.devcontainer/Dockerfile

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
# See here for image contents: https://github.com/microsoft/vscode-dev-containers/tree/v0.224.2/containers/python-3/.devcontainer/base.Dockerfile
2+
3+
# [Choice] Python version (use -bullseye variants on local arm64/Apple Silicon): 3, 3.10, 3.9, 3.8, 3.7, 3.6, 3-bullseye, 3.10-bullseye, 3.9-bullseye, 3.8-bullseye, 3.7-bullseye, 3.6-bullseye, 3-buster, 3.10-buster, 3.9-buster, 3.8-buster, 3.7-buster, 3.6-buster
4+
ARG VARIANT="3.10-bullseye"
5+
FROM mcr.microsoft.com/vscode/devcontainers/python:0-${VARIANT}
6+
7+
# [Choice] Node.js version: none, lts/*, 16, 14, 12, 10
8+
ARG NODE_VERSION="none"
9+
RUN if [ "${NODE_VERSION}" != "none" ]; then su vscode -c "umask 0002 && . /usr/local/share/nvm/nvm.sh && nvm install ${NODE_VERSION} 2>&1"; fi
10+
11+
# [Optional] If your pip requirements rarely change, uncomment this section to add them to the image.
12+
# COPY requirements.txt /tmp/pip-tmp/
13+
# RUN pip3 --disable-pip-version-check --no-cache-dir install -r /tmp/pip-tmp/requirements.txt \
14+
# && rm -rf /tmp/pip-tmp
15+
16+
# [Optional] Uncomment this section to install additional OS packages.
17+
# RUN apt-get update && export DEBIAN_FRONTEND=noninteractive \
18+
# && apt-get -y install --no-install-recommends <your-package-list-here>
19+
20+
# [Optional] Uncomment this line to install global node packages.
21+
# RUN su vscode -c "source /usr/local/share/nvm/nvm.sh && npm install -g <your-package-here>" 2>&1

.devcontainer/devcontainer.json

Lines changed: 62 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,62 @@
1+
// For format details, see https://aka.ms/devcontainer.json. For config options, see the README at:
2+
// https://github.com/microsoft/vscode-dev-containers/tree/v0.224.2/containers/python-3
3+
{
4+
"name": "Python 3",
5+
"build": {
6+
"dockerfile": "Dockerfile",
7+
"context": "..",
8+
"args": {
9+
// Update 'VARIANT' to pick a Python version: 3, 3.10, 3.9, 3.8, 3.7, 3.6
10+
// Append -bullseye or -buster to pin to an OS version.
11+
// Use -bullseye variants on local on arm64/Apple Silicon.
12+
"VARIANT": "3.10-bullseye",
13+
// Options
14+
"NODE_VERSION": "lts/*"
15+
}
16+
},
17+
18+
// Set *default* container specific settings.json values on container create.
19+
"settings": {
20+
"python.defaultInterpreterPath": "/usr/local/bin/python",
21+
"python.linting.enabled": true,
22+
"python.linting.pylintEnabled": true,
23+
"python.formatting.autopep8Path": "/usr/local/py-utils/bin/autopep8",
24+
"python.formatting.blackPath": "/usr/local/py-utils/bin/black",
25+
"python.formatting.yapfPath": "/usr/local/py-utils/bin/yapf",
26+
"python.linting.banditPath": "/usr/local/py-utils/bin/bandit",
27+
"python.linting.flake8Path": "/usr/local/py-utils/bin/flake8",
28+
"python.linting.mypyPath": "/usr/local/py-utils/bin/mypy",
29+
"python.linting.pycodestylePath": "/usr/local/py-utils/bin/pycodestyle",
30+
"python.linting.pydocstylePath": "/usr/local/py-utils/bin/pydocstyle",
31+
"python.linting.pylintPath": "/usr/local/py-utils/bin/pylint"
32+
},
33+
34+
// Add the IDs of extensions you want installed when the container is created.
35+
"extensions": [
36+
"ms-python.python",
37+
"ms-python.vscode-pylance"
38+
],
39+
40+
// Use 'forwardPorts' to make a list of ports inside the container available locally.
41+
// "forwardPorts": [],
42+
43+
// Use 'postCreateCommand' to run commands after the container is created.
44+
"postCreateCommand": "./scripts/install-hooks.sh",
45+
46+
// Comment out to connect as root instead. More info: https://aka.ms/vscode-remote/containers/non-root.
47+
"remoteUser": "vscode",
48+
"features": {
49+
"docker-from-docker": "latest",
50+
"git": "latest"
51+
},
52+
//"runArgs": ["--init"],
53+
//"overrideCommand": false,
54+
"remoteEnv": {
55+
"LOCAL_WORKSPACE_FOLDER": "${localWorkspaceFolder}",
56+
// Uncomment below if host is Windows/WSL (untested)
57+
// per https://docs.docker.com/compose/reference/envvars/
58+
// "COMPOSE_FORCE_WINDOWS_HOST": "true"
59+
},
60+
61+
62+
}

Dockerfile

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,5 +5,5 @@ FROM breneser/mssql-python-nodejs
55

66
WORKDIR /code
77
ADD requirements.txt /code/
8-
RUN pip install -r requirements.txt
8+
RUN pip install --upgrade pip && pip install -r requirements.txt
99
ADD . /code

README.md

Lines changed: 28 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -99,26 +99,46 @@ pre_save.connect(format_permissions_json, sender=TestModel)
9999
How to contribute
100100
-----------------
101101

102-
### Requirements
102+
### Getting started
103+
104+
#### With devcontainer and VSCode (recommended)
105+
106+
* Open repository folder in container
107+
108+
#### Build locally (old school)
109+
110+
##### Requirements
103111
* Docker
104112
* docker-compose
105113
You'll get all this lot installed nicely with (https://docs.docker.com/docker-for-mac/install).
106114

107-
108-
### Setup locally
109-
Add git hook
115+
##### Add git hook
110116
```
111117
./scripts/install-hooks.sh
112118
```
113-
Build the image
119+
120+
### Now you are set
121+
122+
#### Build the containers
114123
```
115124
docker-compose build
116125
```
117-
Run the containers
126+
#### Create super user
127+
```
128+
docker-compose run --rm web python manage.py createsuperuser
129+
```
130+
#### Exercise the application
131+
132+
##### Run the containers
133+
118134
```
119135
docker-compose up
120136
```
121-
Create super user:
137+
138+
##### Browse to http://localhost:8000/admin and make your changes with live reload
139+
140+
#### Run tests as required
141+
122142
```
123-
docker-compose run --rm web python manage.py createsuperuser
143+
docker-compose run --rm web python manage.py test
124144
```

docker-compose.yml

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -8,7 +8,7 @@ services:
88
ports:
99
- "5432:5432"
1010
volumes:
11-
- ./db:/var/lib/postgresql/data
11+
- ${LOCAL_WORKSPACE_FOLDER:-.}/db:/var/lib/postgresql/data
1212
web:
1313
environment:
1414
HAY_DEBUG: "True"
@@ -26,7 +26,7 @@ services:
2626
build: .
2727
command: bash -c "./scripts/wait-for-it.sh db:5432 -- python3 ./manage.py migrate && python3 manage.py load_test_data_fixtures && python3 ./manage.py runserver 0.0.0.0:8000"
2828
volumes:
29-
- .:/code
29+
- ${LOCAL_WORKSPACE_FOLDER:-.}:/code
3030
ports:
3131
- "8000:8000"
3232
depends_on:

0 commit comments

Comments
 (0)