summaryrefslogtreecommitdiff
path: root/tools/docker/Dockerfile
blob: 883d43ab839f93bcef6134b370b59e4497135c9f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
FROM ubuntu

ARG UID=1000

ENV PROJECT_HOME /home/patchwork/patchwork

ENV db_user root
ENV db_pass password

ENV DJANGO_SETTINGS_MODULE patchwork.settings.dev
ENV DEBIAN_FRONTEND noninteractive
ENV PYTHONUNBUFFERED 1

# System
# python3.4-minimal libpython3.4-stdlib libpython3.4-minimal \
# findutils is for python3.4... :/
COPY tools/docker/trusty.list /etc/apt/sources.list.d/trusty.list
RUN apt-get update -qq && \
    apt-get install -y --no-install-recommends --allow-downgrades \
    python-dev python-pip python-setuptools python-wheel \
    python3.5-dev python3-pip python3-setuptools python3-wheel \
    python3.4-dev findutils=4.4.2-7 \
    libmysqlclient-dev mysql-client curl unzip xvfb chromium-chromedriver \
    chromium-browser build-essential && \
    ln -s /usr/lib/chromium-browser/chromedriver /usr/bin/

# User
RUN useradd --uid=$UID --create-home patchwork

# Python requirements.
# If you update requirements, you should rebuild the container.
# entrypoint.sh will prompt you to do this.
# we install both Python 2 and Python 3 versions so you can use either
COPY requirements-*.txt /tmp/
RUN pip3 install virtualenv tox && \
    pip3 install -r /tmp/requirements-dev.txt
RUN pip2 install virtualenv tox && \
    pip2 install -r /tmp/requirements-dev.txt
# we deliberately leave the requirements files in tmp so we can
# ping the user in entrypoint.sh if the change them!

COPY tools/docker/bashrc /tmp/bashrc

# we put the code in ~/patchwork rather than ~ so that we
# can put in these bashrc snippets without dirtying the
# working directory
RUN cat /tmp/bashrc >> /home/patchwork/.bashrc

COPY tools/docker/entrypoint.sh /usr/local/bin/entrypoint.sh

ENTRYPOINT ["/usr/local/bin/entrypoint.sh"]
USER patchwork
WORKDIR /home/patchwork/patchwork