From 018194f4a832b406999762fdac3417dfbcb9b9cb Mon Sep 17 00:00:00 2001 From: Ivan Komissarov Date: Thu, 10 Sep 2020 18:16:33 +0200 Subject: Upgrade linux images to Ubuntu 20.04 Change-Id: I4dcfbe846f7847874908ed8ad84ac615a5a739c1 Reviewed-by: Christian Kandeler --- docker/bionic/Dockerfile | 107 -------------------------------- docker/bionic/entrypoint.sh | 96 ----------------------------- docker/bionic/test-android.Dockerfile | 112 ---------------------------------- 3 files changed, 315 deletions(-) delete mode 100644 docker/bionic/Dockerfile delete mode 100755 docker/bionic/entrypoint.sh delete mode 100644 docker/bionic/test-android.Dockerfile (limited to 'docker/bionic') diff --git a/docker/bionic/Dockerfile b/docker/bionic/Dockerfile deleted file mode 100644 index 9fee903dd..000000000 --- a/docker/bionic/Dockerfile +++ /dev/null @@ -1,107 +0,0 @@ -# -# Install Qt and Qbs for Linux -# -FROM ubuntu:bionic -LABEL Description="Ubuntu development environment for Qbs with Qt and various dependencies for testing Qbs modules and functionality" -ARG QT_VERSION -ARG QTCREATOR_VERSION - -# Allow colored output on command line. -ENV TERM=xterm-color - -# -# Make it possible to change UID/GID in the entrypoint script. The docker -# container usually runs as root user on Linux hosts. When the Docker container -# mounts a folder on the host and creates files there, those files would be -# owned by root instead of the current user. Thus we create a user here who's -# UID will be changed in the entrypoint script to match the UID of the current -# host user. -# -ARG USER_UID=1000 -ARG USER_NAME=devel -RUN apt-get update -qq && \ - apt-get install -qq -y \ - ca-certificates \ - gosu \ - sudo && \ - groupadd -g ${USER_UID} ${USER_NAME} && \ - useradd -s /bin/bash -u ${USER_UID} -g ${USER_NAME} -o -c "" -m ${USER_NAME} && \ - usermod -a -G sudo ${USER_NAME} && \ - echo "%devel ALL = (ALL) NOPASSWD: ALL" >> /etc/sudoers - -COPY docker/bionic/entrypoint.sh /sbin/entrypoint.sh -ENTRYPOINT ["/sbin/entrypoint.sh"] - -# Qbs build dependencies -RUN apt-get update -qq && \ - apt-get install -qq -y --no-install-recommends \ - bison \ - build-essential \ - ca-certificates \ - capnproto \ - ccache \ - clang-8 \ - clang-tidy-8 \ - cmake \ - curl \ - flex \ - git \ - help2man \ - icoutils \ - libcapnp-dev \ - libdbus-1-3 \ - libfreetype6 \ - libfontconfig1 \ - libgl1-mesa-dev \ - libgl1-mesa-glx \ - libprotobuf-dev \ - libgrpc++-dev \ - ninja-build \ - nsis \ - pkg-config \ - protobuf-compiler \ - protobuf-compiler-grpc \ - psmisc \ - python3-pip \ - python3-setuptools \ - p7zip-full \ - subversion \ - unzip \ - zip && \ - update-alternatives --install /usr/bin/clang clang /usr/bin/clang-8 100 && \ - update-alternatives --install /usr/bin/clang++ clang++ /usr/bin/clang++-8 100 && \ - update-alternatives --install /usr/bin/clang-check clang-check /usr/bin/clang-check-8 100 && \ - update-alternatives --install /usr/bin/python python /usr/bin/python3 100 && \ - update-alternatives --install /usr/bin/pip pip /usr/bin/pip3 100 && \ - pip install beautifulsoup4 lxml pyyaml - -ENV LLVM_INSTALL_DIR=/usr/lib/llvm-8 - - -# -# Install Qt and Qbs for Linux from qt.io -# -COPY scripts/install-qt.sh install-qt.sh - -RUN ./install-qt.sh --version ${QT_VERSION} qtbase qtdeclarative qtscript qttools qtx11extras qtscxml icu && \ - ./install-qt.sh --version ${QTCREATOR_VERSION} qtcreator && \ - echo "export PATH=/opt/Qt/${QT_VERSION}/gcc_64/bin:/opt/Qt/Tools/QtCreator/bin:\${PATH}" > /etc/profile.d/qt.sh - -ENV PATH=/opt/Qt/${QT_VERSION}/gcc_64/bin:/opt/Qt/Tools/QtCreator/bin:${PATH} - - -# Configure Qbs -USER $USER_NAME -RUN qbs-setup-toolchains /usr/bin/g++ gcc && \ - qbs-setup-toolchains /usr/bin/clang clang && \ - qbs-setup-qt /opt/Qt/${QT_VERSION}/gcc_64/bin/qmake qt-gcc_64 && \ - qbs config profiles.qt-gcc_64.baseProfile gcc && \ - qbs-setup-qt /opt/Qt/${QT_VERSION}/gcc_64/bin/qmake qt-clang_64 && \ - qbs config profiles.qt-clang_64.baseProfile clang && \ - qbs config defaultProfile qt-gcc_64 - -# Switch back to root user for the entrypoint script. -USER root - -# Work-around for QTBUG-79020 -RUN echo "export QT_NO_GLIB=1" >> /etc/profile.d/qt.sh diff --git a/docker/bionic/entrypoint.sh b/docker/bionic/entrypoint.sh deleted file mode 100755 index 40bc5acb9..000000000 --- a/docker/bionic/entrypoint.sh +++ /dev/null @@ -1,96 +0,0 @@ -#!/usr/bin/env bash -set -e - -############################################################################# -## -## Copyright (C) 2019 Richard Weickelt -## Contact: https://www.qt.io/licensing/ -## -## This file is part of Qbs. -## -## $QT_BEGIN_LICENSE:LGPL$ -## Commercial License Usage -## Licensees holding valid commercial Qt licenses may use this file in -## accordance with the commercial license agreement provided with the -## Software or, alternatively, in accordance with the terms contained in -## a written agreement between you and The Qt Company. For licensing terms -## and conditions see https://www.qt.io/terms-conditions. For further -## information use the contact form at https://www.qt.io/contact-us. -## -## GNU Lesser General Public License Usage -## Alternatively, this file may be used under the terms of the GNU Lesser -## General Public License version 3 as published by the Free Software -## Foundation and appearing in the file LICENSE.LGPL3 included in the -## packaging of this file. Please review the following information to -## ensure the GNU Lesser General Public License version 3 requirements -## will be met: https://www.gnu.org/licenses/lgpl-3.0.html. -## -## GNU General Public License Usage -## Alternatively, this file may be used under the terms of the GNU -## General Public License version 2.0 or (at your option) the GNU General -## Public license version 3 or any later version approved by the KDE Free -## Qt Foundation. The licenses are as published by the Free Software -## Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3 -## included in the packaging of this file. Please review the following -## information to ensure the GNU General Public License requirements will -## be met: https://www.gnu.org/licenses/gpl-2.0.html and -## https://www.gnu.org/licenses/gpl-3.0.html. -## -## $QT_END_LICENSE$ -## -############################################################################# - -# -# Entrypoint script when starting the container. The script checks the current -# working directory and changes the uid/gid of developer/users to match whatever -# is found in the working directory. This is useful to match the user and group -# of mounted volumes into the container - -# -# If not root, re-run script as root to fix ids -# -if [ "$(id -u)" != "0" ]; then - exec gosu root /sbin/entrypoint.sh "$@" -fi - -# -# Try to determine the uid of the working directory and adjust the current -# user's uid/gid accordingly. -# -USER_GID=${USER_GID:-$(stat -c "%g" .)} -USER_UID=${USER_UID:-$(stat -c "%u" .)} -USER_NAME=${USER_NAME:-devel} -USER_GROUP=${USER_GROUP:-devel} -EXEC="" -export HOME=/home/${USER_NAME} - -# -# This is a problem on Linux hosts when we mount a folder from the -# user file system and write artifacts into that. Thus, we downgrade -# the current user and make sure that the uid and gid matches the one -# of the mounted project folder. -# -# This work-around is not needed on Windows hosts as Windows doesn't -# have such a concept. -# -if [ "${USER_UID}" != "0" ]; then - if [ "$(id -u ${USER_NAME})" != "${USER_UID}" ]; then - usermod -o -u ${USER_UID} ${USER_NAME} - # After changing the user's uid, all files in user's home directory - # automatically get the new uid. - fi - current_gid=$(id -g ${USER_NAME}) - if [ "$(id -g ${USER_NAME})" != "${USER_GID}" ]; then - groupmod -o -g ${USER_GID} ${USER_GROUP} - # Set the new gid on all files in the home directory that still have the - # old gid. - find /home/${USER_NAME} -gid "${current_gid}" ! -type l -exec chgrp ${USER_GID} {} \; - fi -fi -EXEC="exec gosu ${USER_NAME}:${USER_GROUP}" - -if [ -z "$1" ]; then - ${EXEC} bash -l -else - ${EXEC} bash -l -c "$*" -fi diff --git a/docker/bionic/test-android.Dockerfile b/docker/bionic/test-android.Dockerfile deleted file mode 100644 index 64d22b8d1..000000000 --- a/docker/bionic/test-android.Dockerfile +++ /dev/null @@ -1,112 +0,0 @@ -# -# Android SDK/NDK + Qt for Android for testing Qbs -# -FROM ubuntu:bionic -LABEL Description="Ubuntu test environment for Qbs and Qt for Android" - -# Allow colored output on command line. -ENV TERM=xterm-color - -# -# Make it possible to change UID/GID in the entrypoint script. The docker -# container usually runs as root user on Linux hosts. When the Docker container -# mounts a folder on the host and creates files there, those files would be -# owned by root instead of the current user. Thus we create a user here who's -# UID will be changed in the entrypoint script to match the UID of the current -# host user. -# -ARG USER_UID=1000 -ARG USER_NAME=devel -RUN apt-get update -qq && \ - apt-get install -qq -y \ - ca-certificates \ - gosu \ - sudo && \ - groupadd -g ${USER_UID} ${USER_NAME} && \ - useradd -s /bin/bash -u ${USER_UID} -g ${USER_NAME} -o -c "" -m ${USER_NAME} && \ - usermod -a -G sudo ${USER_NAME} && \ - echo "%devel ALL = (ALL) NOPASSWD: ALL" >> /etc/sudoers - -COPY docker/bionic/entrypoint.sh /sbin/entrypoint.sh -ENTRYPOINT ["/sbin/entrypoint.sh"] - -# Qbs build dependencies -RUN apt-get update -qq && \ - apt-get install -qq -y --no-install-recommends \ - ca-certificates \ - curl \ - libasan4 \ - libglib2.0-0 \ - libgl1-mesa-glx \ - openjdk-8-jdk-headless \ - p7zip-full \ - unzip - -ENV JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64 -RUN echo "export JAVA_HOME=${JAVA_HOME}" > /etc/profile.d/android.sh && \ - echo "export PATH=${JAVA_HOME}/bin:\${PATH}" >> /etc/profile.d/android.sh - -ENV ANDROID_HOME="/home/${USER_NAME}/android" -ENV ANDROID_SDK_ROOT=${ANDROID_HOME} -ENV ANDROID_NDK_ROOT=${ANDROID_HOME}/ndk-bundle -ENV PATH="${JAVA_HOME}:${ANDROID_HOME}/platform-tools:${ANDROID_HOME}/tools/bin:$PATH" -RUN echo "export ANDROID_HOME=/home/${USER_NAME}/android" >> /etc/profile.d/android.sh && \ - echo "export ANDROID_SDK_ROOT=${ANDROID_SDK_ROOT}" >> /etc/profile.d/android.sh && \ - echo "export ANDROID_NDK_ROOT=${ANDROID_NDK_ROOT}" >> /etc/profile.d/android.sh && \ - echo "export PATH=${ANDROID_HOME}/platform-tools:${ANDROID_HOME}/tools/bin:\$PATH" >> /etc/profile.d/android.sh - -# -# We ned to run the following steps as the target user -# -USER ${USER_NAME} -RUN mkdir ${ANDROID_HOME} - -# Get Android SDK TOOLS -ARG SDK_TOOLS_VERSION="4333796" -RUN curl -s https://dl.google.com/android/repository/sdk-tools-linux-${SDK_TOOLS_VERSION}.zip > ${ANDROID_HOME}/sdk.zip && \ - unzip ${ANDROID_HOME}/sdk.zip -d ${ANDROID_HOME} && \ - rm -v ${ANDROID_HOME}/sdk.zip - -# Accept SDK license -ARG ANDROID_PLATFORM="android-29" -ARG BUILD_TOOLS="28.0.3" -RUN yes | sdkmanager --verbose --licenses && \ - sdkmanager --update && \ - sdkmanager "platforms;${ANDROID_PLATFORM}" "build-tools;${BUILD_TOOLS}" "platform-tools" "tools" "ndk-bundle" && \ - /usr/lib/jvm/java-8-openjdk-amd64/bin/keytool -genkey -keystore /home/${USER_NAME}/.android/debug.keystore -alias androiddebugkey -storepass android -keypass android -keyalg RSA -keysize 2048 -validity 10000 -dname 'CN=Android Debug,O=Android,C=US' - -# Install ndk samples in ${ANDROID_NDK_ROOT}/samples -RUN cd ${ANDROID_NDK_ROOT} && \ - curl -sLO https://github.com/android/ndk-samples/archive/master.zip && \ - unzip -q master.zip && \ - rm -v master.zip && \ - mv ndk-samples-master samples - -# Install android-BasicMediaDecoder in ${ANDROID_SDK_ROOT}/samples -RUN mkdir ${ANDROID_SDK_ROOT}/samples && \ - cd ${ANDROID_SDK_ROOT}/samples && \ - curl -sLO https://github.com/googlearchive/android-BasicMediaDecoder/archive/master.zip && \ - unzip -q master.zip && \ - rm -v master.zip && \ - mv android-BasicMediaDecoder-master android-BasicMediaDecoder - -# Download buildtool to generate aab packages in ${ANDROID_SDK_ROOT} -RUN cd ${ANDROID_SDK_ROOT} && \ - curl -sLO https://github.com/google/bundletool/releases/download/0.15.0/bundletool-all-0.15.0.jar - -USER root - -# -# Install Qt and Qbs for Linux from qt.io -# -ARG QT_VERSION -COPY scripts/install-qt.sh install-qt.sh -RUN if [ "${QT_VERSION}" \< "5.14" ]; then \ - QT_ABIS="android_armv7 android_arm64_v8a android_x86 android_x86_64"; \ - else \ - QT_ABIS="any"; \ - fi; \ - for abi in ${QT_ABIS}; do \ - ./install-qt.sh --version ${QT_VERSION} --target android --toolchain ${abi} qtbase qtdeclarative qttools qtimageformats; \ - done && \ - echo "export QT_VERSION=${QT_VERSION}" >> /etc/profile.d/qt.sh -- cgit v1.2.3