updated androiddev in docker.bionic
This commit is contained in:
parent
154ecc410c
commit
b0b06db991
|
@ -1,90 +1,66 @@
|
|||
#!/bin/bash
|
||||
#!/bin/sh
|
||||
# This is a comment!
|
||||
echo Hello android # This is a comment, too!
|
||||
|
||||
ANDROID_HOME="/opt/android"
|
||||
get_python_version=$@
|
||||
get_python_version=3
|
||||
echo "#################################################################################"
|
||||
echo $get_python_version
|
||||
echo "#################################################################################"
|
||||
|
||||
#INSTALL ANDROID PACKAGES
|
||||
function install_android_pkg ()
|
||||
{
|
||||
if [[ "$get_python_version" -eq " 2 " ]];
|
||||
then
|
||||
BUILDOZER_VERSION=0.39
|
||||
CYTHON_VERSION=0.28.6
|
||||
elif [[ "$get_python_version" -eq " 3 " ]];
|
||||
then
|
||||
BUILDOZER_VERSION=1.0
|
||||
CYTHON_VERSION=0.29.15
|
||||
else
|
||||
exit
|
||||
fi
|
||||
pip3 install buildozer==$BUILDOZER_VERSION
|
||||
pip3 install --upgrade cython==$CYTHON_VERSION
|
||||
}
|
||||
|
||||
# SYSTEM DEPENDENCIES
|
||||
function system_dependencies ()
|
||||
system_dependencies ()
|
||||
{
|
||||
if [[ "$get_python_version" -eq " 2 " ]];
|
||||
then
|
||||
apt -y update -qq
|
||||
apt -y install -qq --no-install-recommends python virtualenv python-pip python-setuptools python-wheel git wget unzip lbzip2 patch sudo software-properties-common
|
||||
echo "installing system dependencies......................."
|
||||
echo $(python -V)
|
||||
echo $get_python_version
|
||||
|
||||
elif [[ "$get_python_version" -eq " 3 " ]];
|
||||
then
|
||||
apt -y update -qq
|
||||
apt -y install --no-install-recommends python3-pip pip3 python3 virtualenv python3-setuptools python3-wheel git wget unzip sudo patch bzip2 lzma
|
||||
else
|
||||
exit
|
||||
fi
|
||||
apt -y autoremove
|
||||
|
||||
}
|
||||
|
||||
# build dependencies
|
||||
# https://buildozer.readthedocs.io/en/latest/installation.html#android-on-ubuntu-16-04-64bit
|
||||
function build_dependencies ()
|
||||
build_dependencies ()
|
||||
{
|
||||
echo "installing build dependencies..............."
|
||||
dpkg --add-architecture i386
|
||||
apt -y update -qq
|
||||
if [[ "$get_python_version" -eq " 2 " ]];
|
||||
then
|
||||
apt -y install -qq --no-install-recommends build-essential ccache git python python-dev libncurses5:i386 libstdc++6:i386 libgtk2.0-0:i386 libpangox-1.0-0:i386 libpangoxft-1.0-0:i386 libidn11:i386 zip zlib1g-dev zlib1g:i386
|
||||
elif [[ "$get_python_version" -eq " 3 " ]];
|
||||
then
|
||||
apt -y install -qq --no-install-recommends build-essential ccache git python3 python3-dev libncurses5:i386 libstdc++6:i386 libgtk2.0-0:i386 libpangox-1.0-0:i386 libpangoxft-1.0-0:i386 libidn11:i386 zip zlib1g-dev zlib1g:i386
|
||||
else
|
||||
exit
|
||||
fi
|
||||
apt -y autoremove
|
||||
apt -y clean
|
||||
}
|
||||
|
||||
# RECIPES DEPENDENCIES
|
||||
function specific_recipes_dependencies ()
|
||||
specific_recipes_dependencies ()
|
||||
{
|
||||
echo "installing dependent recipes................."
|
||||
dpkg --add-architecture i386
|
||||
apt -y update -qq
|
||||
apt -y install -qq --no-install-recommends libffi-dev autoconf automake cmake gettext libltdl-dev libtool pkg-config
|
||||
apt -y autoremove
|
||||
apt -y clean
|
||||
}
|
||||
|
||||
# INSTALL NDK
|
||||
function install_ndk()
|
||||
install_android_pkg ()
|
||||
{
|
||||
if [[ "$get_python_version" -eq " 2 " ]];
|
||||
then
|
||||
ANDROID_NDK_VERSION="17c"
|
||||
elif [[ "$get_python_version" -eq " 3 " ]];
|
||||
then
|
||||
ANDROID_NDK_VERSION=21
|
||||
else
|
||||
# echo "-----"
|
||||
exit
|
||||
fi
|
||||
echo "installing android packages................"
|
||||
BUILDOZER_VERSION=1.2.0
|
||||
CYTHON_VERSION=0.29.15
|
||||
pip3 install buildozer==$BUILDOZER_VERSION
|
||||
pip3 install --upgrade cython==$CYTHON_VERSION
|
||||
}
|
||||
|
||||
install_ndk()
|
||||
{
|
||||
echo "installing ndk............................."
|
||||
ANDROID_NDK_VERSION=23b
|
||||
ANDROID_NDK_HOME="${ANDROID_HOME}/android-ndk"
|
||||
ANDROID_NDK_HOME_V="${ANDROID_NDK_HOME}-r${ANDROID_NDK_VERSION}"
|
||||
# get the latest version from https://developer.android.com/ndk/downloads/index.html
|
||||
ANDROID_NDK_ARCHIVE="android-ndk-r${ANDROID_NDK_VERSION}-linux-x86_64.zip"
|
||||
ANDROID_NDK_ARCHIVE="android-ndk-r${ANDROID_NDK_VERSION}-linux.zip"
|
||||
ANDROID_NDK_DL_URL="https://dl.google.com/android/repository/${ANDROID_NDK_ARCHIVE}"
|
||||
echo $ANDROID_NDK_DL_URL
|
||||
echo "Downloading ndk.........................................................................."
|
||||
wget -nc ${ANDROID_NDK_DL_URL}
|
||||
mkdir --parents "${ANDROID_NDK_HOME_V}"
|
||||
|
@ -93,74 +69,8 @@ function install_ndk()
|
|||
rm -rf "${ANDROID_NDK_ARCHIVE}"
|
||||
}
|
||||
|
||||
# INSTALL SDK
|
||||
function install_sdk()
|
||||
{
|
||||
if [[ "$get_python_version" -eq " 2 " ]];
|
||||
then
|
||||
ANDROID_SDK_BUILD_TOOLS_VERSION="28.0.3"
|
||||
elif [[ "$get_python_version" -eq " 3 " ]];
|
||||
then
|
||||
ANDROID_SDK_BUILD_TOOLS_VERSION="29.0.2"
|
||||
else
|
||||
exit
|
||||
fi
|
||||
ANDROID_SDK_HOME="${ANDROID_HOME}/android-sdk"
|
||||
# get the latest version from https://developer.android.com/studio/index.html
|
||||
ANDROID_SDK_TOOLS_VERSION="4333796"
|
||||
ANDROID_SDK_TOOLS_ARCHIVE="sdk-tools-linux-${ANDROID_SDK_TOOLS_VERSION}.zip"
|
||||
ANDROID_SDK_TOOLS_DL_URL="https://dl.google.com/android/repository/${ANDROID_SDK_TOOLS_ARCHIVE}"
|
||||
echo "Downloading sdk.........................................................................."
|
||||
wget -nc ${ANDROID_SDK_TOOLS_DL_URL}
|
||||
mkdir --parents "${ANDROID_SDK_HOME}"
|
||||
unzip -q "${ANDROID_SDK_TOOLS_ARCHIVE}" -d "${ANDROID_SDK_HOME}"
|
||||
rm -rf "${ANDROID_SDK_TOOLS_ARCHIVE}"
|
||||
# update Android SDK, install Android API, Build Tools...
|
||||
mkdir --parents "${ANDROID_SDK_HOME}/.android/"
|
||||
echo '### Sources for Android SDK Manager' > "${ANDROID_SDK_HOME}/.android/repositories.cfg"
|
||||
# accept Android licenses (JDK necessary!)
|
||||
apt -y update -qq
|
||||
apt -y install -qq --no-install-recommends openjdk-8-jdk
|
||||
apt -y autoremove
|
||||
yes | "${ANDROID_SDK_HOME}/tools/bin/sdkmanager" "build-tools;${ANDROID_SDK_BUILD_TOOLS_VERSION}" > /dev/null
|
||||
# download platforms, API, build tools
|
||||
"${ANDROID_SDK_HOME}/tools/bin/sdkmanager" "platforms;android-24" > /dev/null
|
||||
"${ANDROID_SDK_HOME}/tools/bin/sdkmanager" "platforms;android-28" > /dev/null
|
||||
"${ANDROID_SDK_HOME}/tools/bin/sdkmanager" "build-tools;${ANDROID_SDK_BUILD_TOOLS_VERSION}" > /dev/null
|
||||
"${ANDROID_SDK_HOME}/tools/bin/sdkmanager" "extras;android;m2repository" > /dev/null
|
||||
find /opt/android/android-sdk -type f -perm /0111 -print0|xargs -0 chmod a+x
|
||||
chown -R buildbot.buildbot /opt/android/android-sdk
|
||||
chmod +x "${ANDROID_SDK_HOME}/tools/bin/avdmanager"
|
||||
}
|
||||
|
||||
# INSTALL APACHE-ANT
|
||||
function install_ant()
|
||||
{
|
||||
if [[ "$get_python_version" -eq " 2 " ]];
|
||||
then
|
||||
APACHE_ANT_VERSION="1.9.4"
|
||||
elif [[ "$get_python_version" -eq " 3 " ]];
|
||||
then
|
||||
APACHE_ANT_VERSION="1.10.7"
|
||||
else
|
||||
exit
|
||||
fi
|
||||
|
||||
APACHE_ANT_ARCHIVE="apache-ant-${APACHE_ANT_VERSION}-bin.tar.gz"
|
||||
APACHE_ANT_DL_URL="http://archive.apache.org/dist/ant/binaries/${APACHE_ANT_ARCHIVE}"
|
||||
APACHE_ANT_HOME="${ANDROID_HOME}/apache-ant"
|
||||
APACHE_ANT_HOME_V="${APACHE_ANT_HOME}-${APACHE_ANT_VERSION}"
|
||||
echo "Downloading ant.........................................................................."
|
||||
wget -nc ${APACHE_ANT_DL_URL}
|
||||
tar -xf "${APACHE_ANT_ARCHIVE}" -C "${ANDROID_HOME}"
|
||||
ln -sfn "${APACHE_ANT_HOME_V}" "${APACHE_ANT_HOME}"
|
||||
rm -rf "${APACHE_ANT_ARCHIVE}"
|
||||
}
|
||||
|
||||
system_dependencies
|
||||
build_dependencies
|
||||
specific_recipes_dependencies
|
||||
install_android_pkg
|
||||
install_ndk
|
||||
install_sdk
|
||||
install_ant
|
|
@ -18,14 +18,15 @@ RUN add-apt-repository ppa:deadsnakes/ppa
|
|||
|
||||
RUN apt-get -y install sudo
|
||||
|
||||
|
||||
RUN apt-get install -yq --no-install-suggests --no-install-recommends \
|
||||
# travis xenial bionic
|
||||
python-setuptools libssl-dev libpq-dev python-prctl python-dev \
|
||||
python-setuptools libssl-dev libpq-dev python-prctl \
|
||||
python-dev python-virtualenv python-pip virtualenv \
|
||||
# dpkg
|
||||
python-minimal python-setuptools python-all python openssl libssl-dev \
|
||||
dh-apparmor debhelper dh-python python-msgpack python-qt4 python-stdeb \
|
||||
python-all-dev python-crypto python-psutil \
|
||||
libfuse2 libglib2.0-bin python-minimal python-all python openssl libssl-dev \
|
||||
dh-apparmor debhelper dh-python python-msgpack python-qt4 git python-stdeb \
|
||||
python-all-dev python-crypto python-psutil python-pycryptopp \
|
||||
fakeroot python-pytest \
|
||||
# Code quality
|
||||
pylint python-pycodestyle python3-pycodestyle pycodestyle python-flake8 \
|
||||
|
@ -48,40 +49,52 @@ RUN rm -rf /var/lib/apt/lists/*
|
|||
|
||||
#####################################################################################################
|
||||
|
||||
FROM base AS travis
|
||||
# FROM base AS travis
|
||||
|
||||
# travis2bash
|
||||
RUN wget -O /usr/local/bin/travis2bash.sh https://git.bitmessage.org/Bitmessage/buildbot-scripts/raw/branch/master/travis2bash.sh
|
||||
RUN chmod +x /usr/local/bin/travis2bash.sh
|
||||
# # travis2bash
|
||||
# RUN wget -O /usr/local/bin/travis2bash.sh https://git.bitmessage.org/Bitmessage/buildbot-scripts/raw/branch/master/travis2bash.sh
|
||||
# RUN chmod +x /usr/local/bin/travis2bash.sh
|
||||
|
||||
RUN useradd -m -U builder
|
||||
RUN echo 'builder ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers
|
||||
# RUN useradd -m -U builder
|
||||
# RUN echo 'builder ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers
|
||||
|
||||
# copy sources
|
||||
COPY . /home/builder/src
|
||||
RUN chown -R builder.builder /home/builder/src
|
||||
# # copy sources
|
||||
# COPY . /home/builder/src
|
||||
# RUN chown -R builder.builder /home/builder/src
|
||||
|
||||
USER builder
|
||||
# USER builder
|
||||
|
||||
WORKDIR /home/builder/src
|
||||
# WORKDIR /home/builder/src
|
||||
|
||||
ENTRYPOINT /usr/local/bin/travis2bash.sh
|
||||
# ENTRYPOINT /usr/local/bin/travis2bash.sh
|
||||
|
||||
#####################################################################################################
|
||||
|
||||
FROM base AS buildbot
|
||||
# FROM base AS buildbot
|
||||
|
||||
# travis2bash
|
||||
RUN wget -O /usr/local/bin/travis2bash.sh https://git.bitmessage.org/Bitmessage/buildbot-scripts/raw/branch/master/travis2bash.sh
|
||||
RUN chmod +x /usr/local/bin/travis2bash.sh
|
||||
# # travis2bash
|
||||
# RUN wget -O /usr/local/bin/travis2bash.sh https://git.bitmessage.org/Bitmessage/buildbot-scripts/raw/branch/master/travis2bash.sh
|
||||
# RUN chmod +x /usr/local/bin/travis2bash.sh
|
||||
|
||||
# copy entrypoint
|
||||
COPY packages/docker/buildbot-entrypoint.sh entrypoint.sh
|
||||
RUN chmod +x entrypoint.sh
|
||||
# # copy entrypoint
|
||||
# COPY packages/docker/buildbot-entrypoint.sh entrypoint.sh
|
||||
# RUN chmod +x entrypoint.sh
|
||||
|
||||
RUN useradd -m -U buildbot
|
||||
RUN echo 'buildbot ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers
|
||||
# RUN useradd -m -U buildbot
|
||||
# RUN echo 'buildbot ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers
|
||||
|
||||
USER buildbot
|
||||
# USER buildbot
|
||||
|
||||
ENTRYPOINT /entrypoint.sh "$BUILDMASTER" "$WORKERNAME" "$WORKERPASS"
|
||||
# ENTRYPOINT /entrypoint.sh $BUILDMASTER $WORKERNAME" "$WORKERPASS"
|
||||
|
||||
#####################################################################################################
|
||||
|
||||
FROM base AS appandroid
|
||||
|
||||
COPY . /home/builder/src
|
||||
|
||||
WORKDIR /home/builder/src
|
||||
|
||||
RUN chmod +x buildscripts/androiddev.sh
|
||||
|
||||
RUN buildscripts/androiddev.sh
|
||||
|
|
Reference in New Issue
Block a user