|
| 1 | +FROM gitpod/workspace-base:latest |
| 2 | + |
| 3 | +RUN echo "CI version from base" |
| 4 | + |
| 5 | +### NodeJS ### |
| 6 | +USER gitpod |
| 7 | +ENV NODE_VERSION=16.13.0 |
| 8 | +ENV TRIGGER_REBUILD=1 |
| 9 | +RUN curl -fsSL https://raw.githubusercontent.com/nvm-sh/nvm/v0.38.0/install.sh | PROFILE=/dev/null bash \ |
| 10 | + && bash -c ". .nvm/nvm.sh \ |
| 11 | + && nvm install $NODE_VERSION \ |
| 12 | + && nvm alias default $NODE_VERSION \ |
| 13 | + && npm install -g typescript yarn node-gyp" \ |
| 14 | + && echo ". ~/.nvm/nvm.sh" >> /home/gitpod/.bashrc.d/50-node |
| 15 | +ENV PATH=$PATH:/home/gitpod/.nvm/versions/node/v${NODE_VERSION}/bin |
| 16 | + |
| 17 | +### Python ### |
| 18 | +USER gitpod |
| 19 | +RUN sudo install-packages python3-pip |
| 20 | + |
| 21 | +ENV PATH=$HOME/.pyenv/bin:$HOME/.pyenv/shims:$PATH |
| 22 | +RUN curl -fsSL https://github.com/pyenv/pyenv-installer/raw/master/bin/pyenv-installer | bash \ |
| 23 | + && { echo; \ |
| 24 | + echo 'eval "$(pyenv init -)"'; \ |
| 25 | + echo 'eval "$(pyenv virtualenv-init -)"'; } >> /home/gitpod/.bashrc.d/60-python \ |
| 26 | + && pyenv update \ |
| 27 | + && pyenv install 3.8.11 \ |
| 28 | + && pyenv global 3.8.11 \ |
| 29 | + && python3 -m pip install --no-cache-dir --upgrade pip \ |
| 30 | + && python3 -m pip install --no-cache-dir --upgrade \ |
| 31 | + setuptools wheel virtualenv pipenv pylint rope flake8 \ |
| 32 | + mypy autopep8 pep8 pylama pydocstyle bandit notebook \ |
| 33 | + twine \ |
| 34 | + && sudo rm -rf /tmp/*USER gitpod |
| 35 | +ENV PYTHONUSERBASE=/workspace/.pip-modules \ |
| 36 | + PIP_USER=yes |
| 37 | +ENV PATH=$PYTHONUSERBASE/bin:$PATH |
| 38 | + |
| 39 | + |
| 40 | +# Setup Heroku CLI |
| 41 | +RUN curl https://cli-assets.heroku.com/install.sh | sh |
| 42 | + |
| 43 | +# Setup PostgreSQL |
| 44 | + |
| 45 | +RUN sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main" | tee /etc/apt/sources.list.d/pgdg.list' && \ |
| 46 | + sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv B97B0AFCAA1A47F044F244A07FCC7D46ACCC4CF8 && \ |
| 47 | + sudo apt-get update -y && \ |
| 48 | + sudo apt-get install -y postgresql-12 |
| 49 | + |
| 50 | +ENV PGDATA="/workspace/.pgsql/data" |
| 51 | + |
| 52 | +RUN mkdir -p ~/.pg_ctl/bin ~/.pg_ctl/sockets \ |
| 53 | + && echo '#!/bin/bash\n[ ! -d $PGDATA ] && mkdir -p $PGDATA && initdb --auth=trust -D $PGDATA\npg_ctl -D $PGDATA -l ~/.pg_ctl/log -o "-k ~/.pg_ctl/sockets" start\n' > ~/.pg_ctl/bin/pg_start \ |
| 54 | + && echo '#!/bin/bash\npg_ctl -D $PGDATA -l ~/.pg_ctl/log -o "-k ~/.pg_ctl/sockets" stop\n' > ~/.pg_ctl/bin/pg_stop \ |
| 55 | + && chmod +x ~/.pg_ctl/bin/* |
| 56 | + |
| 57 | +# ENV DATABASE_URL="postgresql://gitpod@localhost" |
| 58 | +ENV PGHOSTADDR="127.0.0.1" |
| 59 | +ENV PGDATABASE="postgres" |
| 60 | + |
| 61 | +ENV PATH="/usr/lib/postgresql/12/bin:/home/gitpod/.nvm/versions/node/v${NODE_VERSION}/bin:$HOME/.pg_ctl/bin:$PATH" |
| 62 | + |
| 63 | +# Create our own config files |
| 64 | + |
| 65 | +# Add aliases |
| 66 | + |
| 67 | +RUN echo 'alias heroku_config=". $GITPOD_REPO_ROOT/.vscode/heroku_config.sh"' >> ~/.bashrc && \ |
| 68 | + echo 'alias python=python3' >> ~/.bashrc && \ |
| 69 | + echo 'alias pip=pip3' >> ~/.bashrc && \ |
| 70 | + echo 'alias font_fix="python3 $GITPOD_REPO_ROOT/.vscode/font_fix.py"' >> ~/.bashrc |
| 71 | + |
| 72 | +# Local environment variables |
| 73 | + |
| 74 | +ENV PORT="8080" |
| 75 | +ENV IP="0.0.0.0" |
0 commit comments