2b849e0263
Since we can't use the TasksMax value in the docker.service file by default, we can uncomment it at buildtime. See docker/docker/pull/21491 for some background. Signed-off-by: Christy Perez <christy@linux.vnet.ibm.com>
108 lines
4.9 KiB
Bash
108 lines
4.9 KiB
Bash
#!/bin/bash
|
|
set -e
|
|
|
|
# subshell so that we can export PATH and TZ without breaking other things
|
|
(
|
|
export TZ=UTC # make sure our "date" variables are UTC-based
|
|
bundle .integration-daemon-start
|
|
bundle .detect-daemon-osarch
|
|
|
|
# TODO consider using frozen images for the dockercore/builder-deb tags
|
|
|
|
tilde='~' # ouch Bash 4.2 vs 4.3, you keel me
|
|
debVersion="${VERSION//-/$tilde}" # using \~ or '~' here works in 4.3, but not 4.2; just ~ causes $HOME to be inserted, hence the $tilde
|
|
# if we have a "-dev" suffix or have change in Git, let's make this package version more complex so it works better
|
|
if [[ "$VERSION" == *-dev ]] || [ -n "$(git status --porcelain)" ]; then
|
|
gitUnix="$(git log -1 --pretty='%at')"
|
|
gitDate="$(date --date "@$gitUnix" +'%Y%m%d.%H%M%S')"
|
|
gitCommit="$(git log -1 --pretty='%h')"
|
|
gitVersion="git${gitDate}.0.${gitCommit}"
|
|
# gitVersion is now something like 'git20150128.112847.0.17e840a'
|
|
debVersion="$debVersion~$gitVersion"
|
|
|
|
# $ dpkg --compare-versions 1.5.0 gt 1.5.0~rc1 && echo true || echo false
|
|
# true
|
|
# $ dpkg --compare-versions 1.5.0~rc1 gt 1.5.0~git20150128.112847.17e840a && echo true || echo false
|
|
# true
|
|
# $ dpkg --compare-versions 1.5.0~git20150128.112847.17e840a gt 1.5.0~dev~git20150128.112847.17e840a && echo true || echo false
|
|
# true
|
|
|
|
# ie, 1.5.0 > 1.5.0~rc1 > 1.5.0~git20150128.112847.17e840a > 1.5.0~dev~git20150128.112847.17e840a
|
|
fi
|
|
|
|
debSource="$(awk -F ': ' '$1 == "Source" { print $2; exit }' hack/make/.build-deb/control)"
|
|
debMaintainer="$(awk -F ': ' '$1 == "Maintainer" { print $2; exit }' hack/make/.build-deb/control)"
|
|
debDate="$(date --rfc-2822)"
|
|
|
|
# if go-md2man is available, pre-generate the man pages
|
|
./man/md2man-all.sh -q || true
|
|
# TODO decide if it's worth getting go-md2man in _each_ builder environment to avoid this
|
|
|
|
builderDir="contrib/builder/deb/${PACKAGE_ARCH}"
|
|
pkgs=( $(find "${builderDir}/"*/ -type d) )
|
|
if [ ! -z "$DOCKER_BUILD_PKGS" ]; then
|
|
pkgs=( $(echo ${DOCKER_BUILD_PKGS[@]/#/$builderDir\/}) )
|
|
fi
|
|
for dir in "${pkgs[@]}"; do
|
|
[ -d "$dir" ] || { echo >&2 "skipping nonexistent $dir"; continue; }
|
|
version="$(basename "$dir")"
|
|
suite="${version##*-}"
|
|
|
|
image="dockercore/builder-deb:$version"
|
|
if ! docker inspect "$image" &> /dev/null; then
|
|
( set -x && docker build ${DOCKER_BUILD_ARGS} -t "$image" "$dir" )
|
|
fi
|
|
|
|
mkdir -p "$DEST/$version"
|
|
cat > "$DEST/$version/Dockerfile.build" <<-EOF
|
|
FROM $image
|
|
WORKDIR /usr/src/docker
|
|
COPY . /usr/src/docker
|
|
RUN mkdir -p /go/src/github.com/docker && mkdir -p /go/src/github.com/opencontainers \
|
|
&& ln -snf /usr/src/docker /go/src/github.com/docker/docker
|
|
EOF
|
|
|
|
# get the RUNC and CONTAINERD commit from the root Dockerfile, this keeps the commits in sync
|
|
awk '$1 == "ENV" && $2 == "RUNC_COMMIT" { print; exit }' Dockerfile >> "$DEST/$version/Dockerfile.build"
|
|
awk '$1 == "ENV" && $2 == "CONTAINERD_COMMIT" { print; exit }' Dockerfile >> "$DEST/$version/Dockerfile.build"
|
|
|
|
# add runc and containerd compile and install
|
|
cat >> "$DEST/$version/Dockerfile.build" <<-EOF
|
|
# Install runc
|
|
RUN git clone https://github.com/opencontainers/runc.git "/go/src/github.com/opencontainers/runc" \
|
|
&& cd "/go/src/github.com/opencontainers/runc" \
|
|
&& git checkout -q "\$RUNC_COMMIT"
|
|
RUN set -x && export GOPATH="/go" && cd "/go/src/github.com/opencontainers/runc" \
|
|
&& make BUILDTAGS="\$RUNC_BUILDTAGS" && make install
|
|
# Install containerd
|
|
RUN git clone https://github.com/docker/containerd.git "/go/src/github.com/docker/containerd" \
|
|
&& cd "/go/src/github.com/docker/containerd" \
|
|
&& git checkout -q "\$CONTAINERD_COMMIT"
|
|
RUN set -x && export GOPATH="/go" && cd "/go/src/github.com/docker/containerd" && make && make install
|
|
EOF
|
|
if [ "$DOCKER_EXPERIMENTAL" ]; then
|
|
echo 'ENV DOCKER_EXPERIMENTAL 1' >> "$DEST/$version/Dockerfile.build"
|
|
fi
|
|
cat >> "$DEST/$version/Dockerfile.build" <<-EOF
|
|
RUN cp -aL hack/make/.build-deb debian
|
|
RUN { echo '$debSource (${debVersion}-0~${suite}) $suite; urgency=low'; echo; echo ' * Version: $VERSION'; echo; echo " -- $debMaintainer $debDate"; } > debian/changelog && cat >&2 debian/changelog
|
|
EOF
|
|
# Remove the following case-based substitution when none of these are supported, and the TasksMax value is uncommented in docker.service
|
|
case "$version" in
|
|
debian-jessie|debian-wheezy|ubuntu-precise|ubuntu-trusty|ubuntu-wily)
|
|
;;
|
|
*)
|
|
echo "RUN sed -i -- 's/#TasksMax=infinity/TasksMax=infinity/' contrib/init/systemd/docker.service" >> "$DEST/$version/Dockerfile.build"
|
|
;;
|
|
esac
|
|
cat >> "$DEST/$version/Dockerfile.build" <<-EOF
|
|
RUN dpkg-buildpackage -uc -us
|
|
EOF
|
|
tempImage="docker-temp/build-deb:$version"
|
|
( set -x && docker build -t "$tempImage" -f "$DEST/$version/Dockerfile.build" . )
|
|
docker run --rm "$tempImage" bash -c 'cd .. && tar -c *_*' | tar -xvC "$DEST/$version"
|
|
docker rmi "$tempImage"
|
|
done
|
|
|
|
bundle .integration-daemon-stop
|
|
) 2>&1 | tee -a "$DEST/test.log"
|