Builds both scratch & Alpine Docker images

- Adds `Dockerfile_alpine`, which copies the complier from the scratch
   step into an Alpine image
 - Updates `docker_build.sh` to build the Alpine image
 - Updates `docker_deploy.sh` to tag and push the Alpine images
 - Updates `docker_deploy_manual.sh` to tag and push the Alpine images

The tags that are pushed follow:

 - Scratch
    - ethereum/solc:stable
    - ethereum/solc:0.5.1
    - ethereum/solc:nightly
    - ethereum/solc:nightly-0.5.1-bc7cb301e3d71756c8fbefe888aca53433302117
    - ethereum/solc:nightly-0.5.1-bc7cb301e3d71756c8fbefe888aca53433302117
 - Alpine
    - ethereum/solc:stable-alpine
    - ethereum/solc:0.5.1-alpine
    - ethereum/solc:nightly-alpine
    - ethereum/solc:nightly-alpine-0.5.1-bc7cb301e3d71756c8fbefe888aca53433302117
    - ethereum/solc:nightly-alpine-0.5.1-bc7cb301e3d71756c8fbefe888aca53433302117
This commit is contained in:
Justin Wilson 2018-11-27 13:45:59 -07:00
parent bc7cb301e3
commit 16d1bf3335
4 changed files with 42 additions and 18 deletions

View File

@ -0,0 +1,5 @@
FROM alpine
MAINTAINER chriseth <chris@ethereum.org>
COPY upload/solc-static-linux /usr/local/bin/solc
ENTRYPOINT ["/usr/local/bin/solc"]

View File

@ -2,7 +2,11 @@
set -e set -e
# Scratch image
docker build -t ethereum/solc:build -f scripts/Dockerfile . docker build -t ethereum/solc:build -f scripts/Dockerfile .
tmp_container=$(docker create ethereum/solc:build sh) tmp_container=$(docker create ethereum/solc:build sh)
mkdir -p upload mkdir -p upload
docker cp ${tmp_container}:/usr/bin/solc upload/solc-static-linux docker cp ${tmp_container}:/usr/bin/solc upload/solc-static-linux
# Alpine image
docker build -t ethereum/solc:build-alpine -f scripts/Dockerfile_alpine .

View File

@ -2,20 +2,28 @@
set -e set -e
image="ethereum/solc"
tag_and_push()
{
docker tag "$image:$1" "$image:$2"
docker push "$image:$2"
}
docker login -u="$DOCKER_USERNAME" -p="$DOCKER_PASSWORD"; docker login -u="$DOCKER_USERNAME" -p="$DOCKER_PASSWORD";
version=$($(dirname "$0")/get_version.sh) version=$($(dirname "$0")/get_version.sh)
if [ "$TRAVIS_BRANCH" = "develop" ] if [ "$TRAVIS_BRANCH" = "develop" ]
then then
docker tag ethereum/solc:build ethereum/solc:nightly; tag_and_push build nightly
docker tag ethereum/solc:build ethereum/solc:nightly-"$version"-"$TRAVIS_COMMIT" tag_and_push build nightly-"$version"-"$TRAVIS_COMMIT"
docker push ethereum/solc:nightly-"$version"-"$TRAVIS_COMMIT"; tag_and_push build-alpine nightly-alpine
docker push ethereum/solc:nightly; tag_and_push build-alpine nightly-alpine-"$version"-"$TRAVIS_COMMIT"
elif [ "$TRAVIS_TAG" = v"$version" ] elif [ "$TRAVIS_TAG" = v"$version" ]
then then
docker tag ethereum/solc:build ethereum/solc:stable; tag_and_push build stable
docker tag ethereum/solc:build ethereum/solc:"$version"; tag_and_push build "$version"
docker push ethereum/solc:stable; tag_and_push build-alpine stable-alpine
docker push ethereum/solc:"$version"; tag_and_push build-alpine "$version"-alpine
else else
echo "Not publishing docker image from branch $TRAVIS_BRANCH or tag $TRAVIS_TAG" echo "Not publishing docker image from branch $TRAVIS_BRANCH or tag $TRAVIS_TAG"
fi fi

View File

@ -7,6 +7,7 @@ then
echo "Usage: $0 <tag/branch>" echo "Usage: $0 <tag/branch>"
exit 1 exit 1
fi fi
image="ethereum/solc"
branch="$1" branch="$1"
#docker login #docker login
@ -27,21 +28,27 @@ else
date -u +"nightly.%Y.%-m.%-d" > prerelease.txt date -u +"nightly.%Y.%-m.%-d" > prerelease.txt
fi fi
tag_and_push()
{
docker tag "$image:$1" "$image:$2"
docker push "$image:$2"
}
rm -rf .git rm -rf .git
docker build -t ethereum/solc:build -f scripts/Dockerfile . docker build -t "$image":build -f scripts/Dockerfile .
tmp_container=$(docker create ethereum/solc:build sh) tmp_container=$(docker create "$image":build sh)
if [ "$branch" = "develop" ] if [ "$branch" = "develop" ]
then then
docker tag ethereum/solc:build ethereum/solc:nightly; tag_and_push build nightly
docker tag ethereum/solc:build ethereum/solc:nightly-"$version"-"$commithash" tag_and_push build nightly-"$version"-"$commithash"
docker push ethereum/solc:nightly-"$version"-"$commithash"; tag_and_push build-alpine nightly-alpine
docker push ethereum/solc:nightly; tag_and_push build-alpine nightly-alpine-"$version"-"$commithash"
elif [ "$branch" = v"$version" ] elif [ "$branch" = v"$version" ]
then then
docker tag ethereum/solc:build ethereum/solc:stable; tag_and_push build stable
docker tag ethereum/solc:build ethereum/solc:"$version"; tag_and_push build "$version"
docker push ethereum/solc:stable; tag_and_push build-alpine stable-alpine
docker push ethereum/solc:"$version"; tag_and_push build-alpine "$version"-alpine
else else
echo "Not publishing docker image from branch or tag $branch" echo "Not publishing docker image from branch or tag $branch"
fi fi