115 lines
3.7 KiB
Docker
115 lines
3.7 KiB
Docker
# Dockerized nvm development environment
|
|
#
|
|
# This Dockerfile is for building nvm development environment only,
|
|
# not for any distribution/production usage.
|
|
#
|
|
# Please note that it'll use about 1.2 GB disk space and about 15 minutes to
|
|
# build this image, it depends on your hardware.
|
|
|
|
# Use Ubuntu Trusty Tahr as base image as we're using on Travis CI
|
|
# I also tested with Ubuntu 16.04, should be good with it!
|
|
FROM ubuntu:16.04
|
|
LABEL maintainer="Peter Dave Hello <hsu@peterdavehello.org>"
|
|
LABEL name="nvm-dev-env"
|
|
LABEL version="latest"
|
|
|
|
# Set the SHELL to bash with pipefail option
|
|
SHELL ["/bin/bash", "-o", "pipefail", "-c"]
|
|
|
|
# Prevent dialog during apt install
|
|
ENV DEBIAN_FRONTEND noninteractive
|
|
|
|
# ShellCheck version
|
|
ENV SHELLCHECK_VERSION=0.7.0
|
|
|
|
# Pick a Ubuntu apt mirror site for better speed
|
|
# ref: https://launchpad.net/ubuntu/+archivemirrors
|
|
ENV UBUNTU_APT_SITE ubuntu.cs.utah.edu
|
|
|
|
# Disable src package source
|
|
RUN sed -i 's/^deb-src\ /\#deb-src\ /g' /etc/apt/sources.list
|
|
|
|
# Replace origin apt package site with the mirror site
|
|
RUN sed -E -i "s/([a-z]+.)?archive.ubuntu.com/$UBUNTU_APT_SITE/g" /etc/apt/sources.list
|
|
RUN sed -i "s/security.ubuntu.com/$UBUNTU_APT_SITE/g" /etc/apt/sources.list
|
|
|
|
# Install apt packages
|
|
RUN apt update && \
|
|
apt upgrade -y -o Dpkg::Options::="--force-confdef" -o Dpkg::Options::="--force-confold" && \
|
|
apt install -y -o Dpkg::Options::="--force-confdef" -o Dpkg::Options::="--force-confold" \
|
|
coreutils \
|
|
util-linux \
|
|
bsdutils \
|
|
file \
|
|
openssl \
|
|
libssl-dev \
|
|
ca-certificates \
|
|
ssh \
|
|
wget \
|
|
patch \
|
|
sudo \
|
|
htop \
|
|
dstat \
|
|
vim \
|
|
tmux \
|
|
curl \
|
|
git \
|
|
jq \
|
|
realpath \
|
|
zsh \
|
|
ksh \
|
|
gcc-4.8 \
|
|
g++-4.8 \
|
|
xz-utils \
|
|
build-essential \
|
|
bash-completion && \
|
|
apt-get clean
|
|
|
|
# ShellCheck with Ubuntu 14.04 container workaround
|
|
RUN wget https://storage.googleapis.com/shellcheck/shellcheck-v$SHELLCHECK_VERSION.linux.x86_64.tar.xz -O- | \
|
|
tar xJvf - shellcheck-v$SHELLCHECK_VERSION/shellcheck && \
|
|
mv shellcheck-v$SHELLCHECK_VERSION/shellcheck /bin && \
|
|
rmdir shellcheck-v$SHELLCHECK_VERSION
|
|
RUN shellcheck -V
|
|
|
|
# Set locale
|
|
RUN locale-gen en_US.UTF-8
|
|
|
|
# Print tool versions
|
|
RUN bash --version | head -n 1
|
|
RUN zsh --version
|
|
RUN ksh --version || true
|
|
RUN dpkg -s dash | grep ^Version | awk '{print $2}'
|
|
RUN git --version
|
|
RUN curl --version
|
|
RUN wget --version
|
|
|
|
# Add user "nvm" as non-root user
|
|
RUN useradd -ms /bin/bash nvm
|
|
|
|
# Copy and set permission for nvm directory
|
|
COPY . /home/nvm/.nvm/
|
|
RUN chown nvm:nvm -R "home/nvm/.nvm"
|
|
|
|
# Set sudoer for "nvm"
|
|
RUN echo 'nvm ALL=(ALL) NOPASSWD: ALL' >> /etc/sudoers
|
|
|
|
# Switch to user "nvm" from now
|
|
USER nvm
|
|
|
|
# nvm
|
|
RUN echo 'export NVM_DIR="$HOME/.nvm"' >> "$HOME/.bashrc"
|
|
RUN echo '[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh" # This loads nvm' >> "$HOME/.bashrc"
|
|
RUN echo '[ -s "$NVM_DIR/bash_completion" ] && . "$NVM_DIR/bash_completion" # This loads nvm bash_completion' >> "$HOME/.bashrc"
|
|
|
|
# nodejs and tools
|
|
RUN bash -c 'source $HOME/.nvm/nvm.sh && \
|
|
nvm install node && \
|
|
npm install -g doctoc urchin eclint dockerfile_lint && \
|
|
npm install --prefix "$HOME/.nvm/"'
|
|
|
|
# Set WORKDIR to nvm directory
|
|
WORKDIR /home/nvm/.nvm
|
|
|
|
ENTRYPOINT ["/bin/bash"]
|