From 1696a5aac1a0bf2b3b253036ff640519da3e506f Mon Sep 17 00:00:00 2001 From: Christoph Stenglein Date: Sat, 12 Nov 2022 08:28:21 +0100 Subject: [PATCH] dev: reduce docker layers & combine install commands --- Dockerfile | 101 ++++---------------------------------- scripts/docker_install.sh | 76 ++++++++++++++++++++++++++++ 2 files changed, 86 insertions(+), 91 deletions(-) create mode 100755 scripts/docker_install.sh diff --git a/Dockerfile b/Dockerfile index 37cd2d7ca..d5a096aad 100644 --- a/Dockerfile +++ b/Dockerfile @@ -17,83 +17,16 @@ FROM ubuntu:22.04 ENV DEBIAN_FRONTEND noninteractive -RUN apt-get update && apt-get upgrade -y && apt-get install -y wget nano rsync curl gnupg2 jq unzip bzip2 - -# for clang-*-15, see https://apt.llvm.org/ -RUN echo "deb http://apt.llvm.org/jammy/ llvm-toolchain-jammy-15 main" >> /etc/apt/sources.list && \ - echo "deb-src http://apt.llvm.org/jammy/ llvm-toolchain-jammy-15 main" >> /etc/apt/sources.list && \ - wget -O - https://apt.llvm.org/llvm-snapshot.gpg.key | apt-key add - - -# Install gcc8-arm-none-eabi -RUN mkdir ~/Downloads &&\ - cd ~/Downloads &&\ - wget -O gcc.tar.bz2 https://developer.arm.com/-/media/Files/downloads/gnu-rm/8-2018q4/gcc-arm-none-eabi-8-2018-q4-major-linux.tar.bz2?revision=d830f9dd-cd4f-406d-8672-cca9210dd220?product=GNU%20Arm%20Embedded%20Toolchain,64-bit,,Linux,8-2018-q4-major &&\ - echo "fb31fbdfe08406ece43eef5df623c0b2deb8b53e405e2c878300f7a1f303ee52 gcc.tar.bz2" | sha256sum -c &&\ - cd ~/Downloads &&\ - tar -xjvf gcc.tar.bz2 &&\ - rm -f gcc.tar.bz2 &&\ - cd ~/Downloads && rsync -a gcc-arm-none-eabi-8-2018-q4-major/ /usr/local/ - -# Tools for building -RUN apt-get update && apt-get install -y \ - build-essential \ - llvm-15 \ - gcc-10 \ - binutils \ - valgrind \ - cmake \ - git \ - autotools-dev \ - automake \ - autoconf \ - libtool \ - pkg-config \ - libcmocka-dev \ - libc6-i386 \ - lib32stdc++6 \ - lib32z1 \ - libusb-1.0-0-dev \ - libudev-dev \ - libhidapi-dev - -RUN apt-get update && apt-get install -y \ - doxygen \ - graphviz - -# Set gcc-10 as the default gcc -RUN update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-10 100 -RUN update-alternatives --install /usr/bin/gcov gcov /usr/bin/gcov-10 100 - -# Tools for CI -RUN apt-get update && apt-get install -y \ - python3 \ - python3-pip \ - clang-format-15 \ - clang-tidy-15 - -RUN python3 -m pip install --upgrade pip +ADD scripts/docker_install.sh /tmp/ +RUN chmod +x /tmp/docker_install.sh && /tmp/docker_install.sh # Python modules COPY py/bitbox02 /tmp/bitbox02 -RUN python3 -m pip install /tmp/bitbox02 -RUN rm -r /tmp/bitbox02 +RUN python3 -m pip install /tmp/bitbox02 && \ + rm -r /tmp/bitbox02 COPY py/requirements.txt /tmp -RUN python3 -m pip install --upgrade --requirement /tmp/requirements.txt -RUN rm /tmp/requirements.txt - -# Python modules for CI -RUN python3 -m pip install --upgrade \ - pylint==2.13.9 \ - pylint-protobuf==0.20.2 \ - black==22.3.0 \ - mypy==0.960 \ - mypy-protobuf==3.2.0 - -# Python modules for packaging -RUN python3 -m pip install --upgrade \ - setuptools==41.2.0 \ - wheel==0.33.6 \ - twine==1.15.0 +RUN python3 -m pip install --upgrade --requirement /tmp/requirements.txt && \ + rm /tmp/requirements.txt #Install protoc from release, because the version available on the repo is too old RUN mkdir -p /opt/protoc && \ @@ -101,19 +34,8 @@ RUN mkdir -p /opt/protoc && \ unzip /tmp/protoc-21.2-linux-x86_64.zip -d /opt/protoc ENV PATH /opt/protoc/bin:$PATH -# Make Python3 the default -RUN update-alternatives --install /usr/bin/python python /usr/bin/python3 1 - -# Developer tools -RUN apt-get update && apt-get install -y \ - bash-completion -# Install gcovr from PIP to get a newer version than in apt repositories -RUN python3 -m pip install gcovr - # Install Go, used for the tools in tools/go and for test/gounittest -ENV GOPATH /opt/go -ENV GOROOT /opt/go_dist/go -ENV PATH $GOROOT/bin:$GOPATH/bin:$PATH +ENV GOPATH=/opt/go GOROOT=/opt/go_dist/go PATH=$GOROOT/bin:$GOPATH/bin:$PATH RUN mkdir -p /opt/go_dist && \ curl https://dl.google.com/go/go1.19.3.linux-amd64.tar.gz | tar -xz -C /opt/go_dist @@ -122,15 +44,12 @@ RUN cd /opt && wget https://github.com/linux-test-project/lcov/releases/download ENV PATH /opt/lcov-1.14/bin:$PATH # Install rust compiler -ENV PATH /opt/cargo/bin:$PATH -ENV RUSTUP_HOME=/opt/rustup +ENV PATH=/opt/cargo/bin:$PATH RUSTUP_HOME=/opt/rustup COPY src/rust/rust-toolchain /tmp/rust-toolchain RUN curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | CARGO_HOME=/opt/cargo sh -s -- --default-toolchain $(cat /tmp/rust-toolchain | tr -d '\r\n\t') -y RUN rustup target add thumbv7em-none-eabi -RUN rustup component add rustfmt -RUN rustup component add clippy -RUN CARGO_HOME=/opt/cargo cargo install cbindgen --version 0.24.3 -RUN CARGO_HOME=/opt/cargo cargo install bindgen-cli --version 0.61.0 +RUN rustup component add rustfmt clippy +RUN CARGO_HOME=/opt/cargo cargo install cbindgen@0.24.3 bindgen-cli@0.61.0 COPY tools/prost-build prost-build RUN CARGO_HOME=/opt/cargo cargo install --path prost-build --locked diff --git a/scripts/docker_install.sh b/scripts/docker_install.sh new file mode 100755 index 000000000..3535b99c9 --- /dev/null +++ b/scripts/docker_install.sh @@ -0,0 +1,76 @@ +#!/bin/bash + +apt-get update +apt-get upgrade -y +apt-get install -y wget nano rsync curl gnupg2 jq unzip bzip2 + +# for clang-*-15, see https://apt.llvm.org/ +echo "deb http://apt.llvm.org/jammy/ llvm-toolchain-jammy-15 main" >> /etc/apt/sources.list +echo "deb-src http://apt.llvm.org/jammy/ llvm-toolchain-jammy-15 main" >> /etc/apt/sources.list +wget -O - https://apt.llvm.org/llvm-snapshot.gpg.key | apt-key add - + +# Install gcc8-arm-none-eabi +mkdir ~/Downloads +cd ~/Downloads +wget -O gcc.tar.bz2 https://developer.arm.com/-/media/Files/downloads/gnu-rm/8-2018q4/gcc-arm-none-eabi-8-2018-q4-major-linux.tar.bz2?revision=d830f9dd-cd4f-406d-8672-cca9210dd220?product=GNU%20Arm%20Embedded%20Toolchain,64-bit,,Linux,8-2018-q4-major +echo "fb31fbdfe08406ece43eef5df623c0b2deb8b53e405e2c878300f7a1f303ee52 gcc.tar.bz2" | sha256sum -c +cd ~/Downloads +tar -xjvf gcc.tar.bz2 +rm -f gcc.tar.bz2 +cd ~/Downloads && rsync -a gcc-arm-none-eabi-8-2018-q4-major/ /usr/local/ + +# Tools for building +apt-get update +apt-get install -y \ + build-essential \ + llvm-15 \ + gcc-10 \ + binutils \ + valgrind \ + cmake \ + git \ + autotools-dev \ + automake \ + autoconf \ + libtool \ + pkg-config \ + libcmocka-dev \ + libc6-i386 \ + lib32stdc++6 \ + lib32z1 \ + libusb-1.0-0-dev \ + libudev-dev \ + libhidapi-dev \ + doxygen \ + graphviz \ + python3 \ + python3-pip \ + clang-format-15 \ + clang-tidy-15 \ + bash-completion + + +# Set gcc-10 as the default gcc +update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-10 100 +update-alternatives --install /usr/bin/gcov gcov /usr/bin/gcov-10 100 + +# Make Python3 the default +update-alternatives --install /usr/bin/python python /usr/bin/python3 1 + +# install pip +python -m pip install --upgrade pip + +python -m pip install --upgrade \ + # Python modules for CI + pylint==2.13.9 \ + pylint-protobuf==0.20.2 \ + black==22.3.0 \ + mypy==0.960 \ + mypy-protobuf==3.2.0 \ + # Python modules for packaging + setuptools==41.2.0 \ + wheel==0.33.6 \ + twine==1.15.0 + +# Install gcovr from PIP to get a newer version than in apt repositories +python -m pip install gcovr \ No newline at end of file