Add Dockerfile for RHEL 6 builds

This change enables building CLI for RHEL 6 in docker container.
This commit is contained in:
Jan Vorlicek 2017-09-26 10:02:53 -07:00
parent 2c2a9f0a6e
commit 277789bf16
2 changed files with 47 additions and 13 deletions

View file

@ -24,7 +24,7 @@ if [ -z "$HOME" ]; then
mkdir -p $HOME mkdir -p $HOME
fi fi
args=( "$@" ) args=
while [[ $# > 0 ]]; do while [[ $# > 0 ]]; do
lowerI="$(echo $1 | awk '{print tolower($0)}')" lowerI="$(echo $1 | awk '{print tolower($0)}')"
@ -32,23 +32,15 @@ while [[ $# > 0 ]]; do
--docker) --docker)
export BUILD_IN_DOCKER=1 export BUILD_IN_DOCKER=1
export DOCKER_IMAGENAME=$2 export DOCKER_IMAGENAME=$2
# remove docker args
args=( "${args[@]/$1}" )
args=( "${args[@]/$2}" )
shift shift
;; ;;
*) *)
args="$args $1"
;;
esac esac
shift shift
done done
# $args array may have empty elements in it.
# The easiest way to remove them is to cast to string and back to array.
# This will actually break quoted arguments, arguments like
# -test "hello world" will be broken into three arguments instead of two, as it should.
temp="${args[@]}"
args=($temp)
dockerbuild() dockerbuild()
{ {
BUILD_COMMAND=/opt/code/run-build.sh $DIR/scripts/dockerrun.sh --non-interactive "$@" BUILD_COMMAND=/opt/code/run-build.sh $DIR/scripts/dockerrun.sh --non-interactive "$@"
@ -56,7 +48,7 @@ dockerbuild()
# Check if we need to build in docker # Check if we need to build in docker
if [ ! -z "$BUILD_IN_DOCKER" ]; then if [ ! -z "$BUILD_IN_DOCKER" ]; then
dockerbuild "${args[@]}" dockerbuild $args
else else
$DIR/run-build.sh "${args[@]}" $DIR/run-build.sh $args
fi fi

View file

@ -0,0 +1,42 @@
#
# Copyright (c) .NET Foundation and contributors. All rights reserved.
# Licensed under the MIT license. See LICENSE file in the project root for full license information.
#
# Dockerfile that creates a container suitable to build dotnet-cli
FROM microsoft/dotnet-buildtools-prereqs:centos-6-783abde-20171304101322
# Install prerequisites for the git build below
RUN yum -q -y install sudo expat-devel perl-devel autoconf gcc gcc-c++ gettext-devel
# Compile and install a version of the git that supports the features that cli build needs
RUN \
wget https://www.kernel.org/pub/software/scm/git/git-2.9.5.tar.gz && \
tar -xf git-2.9.5.tar.gz && \
cd git-2.9.5 && \
make configure && \
./configure --prefix=/usr/local --without-tcltk && \
make -j $(nproc --all) all && \
make install && \
cd .. && \
rm -r git-2.9.5
# Setup User to match Host User, and give superuser permissions
ARG USER_ID=0
RUN useradd -m code_executor -u ${USER_ID} -g root
RUN echo 'code_executor ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers
# With the User Change, we need to change permssions on these directories
RUN chmod -R a+rwx /usr/local
RUN chmod -R a+rwx /home
RUN chmod -R 755 /usr/bin/sudo
# Set user to the one we just created
USER ${USER_ID}
# Set library path to make CURL and ICU libraries that are in /usr/local/lib visible
ENV LD_LIBRARY_PATH /usr/local/lib
# Set working directory
WORKDIR /opt/code