From a74027cb41112451342630a0a672a49b5f59d1d3 Mon Sep 17 00:00:00 2001 From: Tonis Tiigi Date: Wed, 10 Oct 2018 17:09:35 -0700 Subject: [PATCH 1/5] hack: add release script Signed-off-by: Tonis Tiigi --- .travis.yml | 18 +++++++- hack/dockerfiles/test.Dockerfile | 2 +- hack/dockerfiles/test.buildkit.Dockerfile | 2 +- hack/release | 52 +++++++++++++++++++++++ 4 files changed, 71 insertions(+), 3 deletions(-) create mode 100755 hack/release diff --git a/.travis.yml b/.travis.yml index 5a50c1e6f6e2..e67cf6278034 100644 --- a/.travis.yml +++ b/.travis.yml @@ -12,4 +12,20 @@ env: - PREFER_BUILDCTL="1" script: - - make binaries validate-all && ./hack/cross \ No newline at end of file + - make binaries validate-all && ./hack/cross + +before_deploy: + - echo "$DOCKER_PASSWORD" | docker login -u "$DOCKER_USERNAME" --password-stdin + +deploy: + - provider: script + script: ./hack/release master tonistiigi/buildkit push + on: + repo: moby/buildkit + branch: master + - provider: script + script: ./hack/release $TRAVIS_TAG tonistiigi/buildkit push + on: + repo: moby/buildkit + tags: true + condition: $TRAVIS_TAG =~ ^v[0-9] \ No newline at end of file diff --git a/hack/dockerfiles/test.Dockerfile b/hack/dockerfiles/test.Dockerfile index 472406fb5b34..10e71560783e 100644 --- a/hack/dockerfiles/test.Dockerfile +++ b/hack/dockerfiles/test.Dockerfile @@ -5,7 +5,7 @@ ARG CONTAINERD10_VERSION=v1.0.3 # available targets: buildkitd, buildkitd.oci_only, buildkitd.containerd_only ARG BUILDKIT_TARGET=buildkitd ARG REGISTRY_VERSION=2.6 -ARG ROOTLESSKIT_VERSION=d843aadf00d72082fd7a31572ef018d1e792535f +ARG ROOTLESSKIT_VERSION=4f7ae4607d626f0a22fb495056d55b17cce8c01b # The `buildkitd` stage and the `buildctl` stage are placed here # so that they can be built quickly with legacy DAG-unaware `docker build --target=...` diff --git a/hack/dockerfiles/test.buildkit.Dockerfile b/hack/dockerfiles/test.buildkit.Dockerfile index 9329f895a900..99c1b7e66607 100644 --- a/hack/dockerfiles/test.buildkit.Dockerfile +++ b/hack/dockerfiles/test.buildkit.Dockerfile @@ -7,7 +7,7 @@ ARG CONTAINERD10_VERSION=v1.0.3 # available targets: buildkitd, buildkitd.oci_only, buildkitd.containerd_only ARG BUILDKIT_TARGET=buildkitd ARG REGISTRY_VERSION=2.6 -ARG ROOTLESSKIT_VERSION=d843aadf00d72082fd7a31572ef018d1e792535f +ARG ROOTLESSKIT_VERSION=4f7ae4607d626f0a22fb495056d55b17cce8c01b ARG ROOTLESS_BASE_MODE=external # git stage is used for checking out remote repository sources diff --git a/hack/release b/hack/release new file mode 100755 index 000000000000..dea42c713d27 --- /dev/null +++ b/hack/release @@ -0,0 +1,52 @@ +#!/usr/bin/env bash + +TAG=$1 +REPO=$2 +PUSH=$3 + +set -eu -o pipefail + +: ${PLATFORMS=linux/amd64} +: ${CONTINUOUS_INTEGRATION=} + +progressFlag="" +if [ "$CONTINUOUS_INTEGRATION" == "true" ]; then progressFlag="--progress=plain"; fi + + +usage() { + echo "usage: ./hack/test [push]" + exit 1 +} + +if [ -z "$TAG" ] || [ -z "$REPO" ]; then + usage +fi + +pushFlag="" +if [ "$PUSH" = "push" ]; then + pushFlag="--exporter-opt push=true" +fi + +tagLatest="" +tagLatestRootless="" +if [[ "$(git describe --tags --match "v[0-9]*")" == "$TAG" ]]; then + tagLatest=",$REPO:latest" + tagLatestRootless=",$REPO:rootless" +fi + +set -x + +buildctl build $progressFlag --frontend=dockerfile.v0 \ + --local context=. --local dockerfile=. \ + --frontend-opt filename=./hack/dockerfiles/test.buildkit.Dockerfile \ + --frontend-opt platform=$PLATFORMS \ + --exporter image \ + --exporter-opt name=$REPO:$TAG$tagLatest $pushFlag + +buildctl build $progressFlag --frontend=dockerfile.v0 \ + --local context=. --local dockerfile=. \ + --frontend-opt target=rootless \ + --frontend-opt filename=./hack/dockerfiles/test.buildkit.Dockerfile \ + --frontend-opt platform=$PLATFORMS \ + --exporter image \ + --exporter-opt name=$REPO:$TAG-rootless$tagLatestRootless $pushFlag \ No newline at end of file From 106834d7088b695362074238a3bb030ea70089c4 Mon Sep 17 00:00:00 2001 From: Tonis Tiigi Date: Wed, 10 Oct 2018 22:39:18 -0700 Subject: [PATCH 2/5] hack: add git to rootless stage Signed-off-by: Tonis Tiigi --- hack/dockerfiles/test.buildkit.Dockerfile | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/hack/dockerfiles/test.buildkit.Dockerfile b/hack/dockerfiles/test.buildkit.Dockerfile index 99c1b7e66607..c18e549ac915 100644 --- a/hack/dockerfiles/test.buildkit.Dockerfile +++ b/hack/dockerfiles/test.buildkit.Dockerfile @@ -70,7 +70,7 @@ WORKDIR /go/src/github.com/moby/buildkit # scan the version/revision info FROM buildkit-base AS buildkit-version -RUN --mount=target=.git,src=.git \ +RUN --mount=target=. \ PKG=github.com/moby/buildkit VERSION=$(git describe --match 'v[0-9]*' --dirty='.m' --always) REVISION=$(git rev-parse HEAD)$(if ! git diff --no-ext-diff --quiet --exit-code; then echo .m; fi); \ echo "-X ${PKG}/version.Version=${VERSION} -X ${PKG}/version.Revision=${REVISION} -X ${PKG}/version.Package=${PKG}" | tee /tmp/.ldflags; \ echo -n "${VERSION}" | tee /tmp/.version; @@ -204,14 +204,14 @@ COPY --from=binaries / /usr/bin/ COPY . . FROM alpine AS rootless-base-internal -RUN apk add --no-cache shadow shadow-uidmap \ +RUN apk add --no-cache git shadow shadow-uidmap \ && useradd --create-home --home-dir /home/user --uid 1000 user \ && mkdir -p /run/user/1000 /home/user/.local/tmp /home/user/.local/share/buildkit \ && chown -R user /run/user/1000 /home/user \ && rm /bin/su && ln -s /bin/busybox /bin/su # tonistiigi/buildkit:rootless-base is a pre-built multi-arch version of rootless-base-internal https://github.com/moby/buildkit/pull/666#pullrequestreview-161872350 -FROM tonistiigi/buildkit:rootless-base@sha256:a4999bc477416206973f93046ccfd9d82019f25bbc6400213bb2d27253e13c59 AS rootless-base-external +FROM tonistiigi/buildkit:rootless-base@sha256:6d9c50e2d006c2a8745e9d7f2bc075e4469191eccada41936ec0c6070361d45a AS rootless-base-external FROM rootless-base-$ROOTLESS_BASE_MODE AS rootless-base # Rootless mode. From fb5324c609465f9b0713cbce5f8a36eb119be144 Mon Sep 17 00:00:00 2001 From: Tonis Tiigi Date: Wed, 10 Oct 2018 23:46:34 -0700 Subject: [PATCH 3/5] hack: add tarball release Signed-off-by: Tonis Tiigi --- .gitignore | 1 + .travis.yml | 15 +++++++++-- hack/dockerfiles/test.buildkit.Dockerfile | 2 +- hack/release | 2 +- hack/release-tar | 33 +++++++++++++++++++++++ 5 files changed, 49 insertions(+), 4 deletions(-) create mode 100755 hack/release-tar diff --git a/.gitignore b/.gitignore index a4ad067c4d76..204e2cec1d89 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1,3 @@ bin .tmp +release-out \ No newline at end of file diff --git a/.travis.yml b/.travis.yml index e67cf6278034..ac3b07f9fef3 100644 --- a/.travis.yml +++ b/.travis.yml @@ -5,6 +5,7 @@ install: - docker run --name buildkit --rm -d --privileged -p 1234:1234 tonistiigi/buildkit --addr tcp://0.0.0.0:1234 - sudo docker cp buildkit:/usr/bin/buildctl /usr/bin/ - export BUILDKIT_HOST=tcp://0.0.0.0:1234 + - git fetch --tags --unshallow env: global: @@ -24,8 +25,18 @@ deploy: repo: moby/buildkit branch: master - provider: script - script: ./hack/release $TRAVIS_TAG tonistiigi/buildkit push + script: ./hack/release $TRAVIS_TAG tonistiigi/buildkit push && PLATFORMS="${PLATFORMS},darwin/amd64,windows/amd64" ./hack/release-tar $TRAVIS_TAG release-out on: repo: moby/buildkit tags: true - condition: $TRAVIS_TAG =~ ^v[0-9] \ No newline at end of file + condition: $TRAVIS_TAG =~ ^v[0-9] + - provider: releases + api_key: + secure: "hA0L2F6O1MLEJEbUDzxokpO6F6QrAIkltmVG3g0tTAoVj1xtCOXSmH3cAnVbFYyOz9q8pa/85tbpyEEIHVlqvWk2a5/QS16QaBW6XxH+FiZ3oQ44JbtpsjpmBFxdhfeFs8Ca6Nj29AOtDx21HHWsZKlBZFvC4Ubc05AM1rgZpJyZVDvYsjZIunc8/CPCbvAAp6RLnLHxAYXF+TQ7mAZP2SewsW/61nPjPIp2P4d93CduA9kUSxtC/1ewmU2T9Ak2X1Nw2ecPTonGjO51xNa6Ebo1hsbsRt5Krd1IR5rSkgXqLrhQO+19J3sUrQr2p8su6hCTKXR5TQz9L5C9VG8T3yOLbA7/FKBndWgBCm7EB7SezhFkm91e3Phkd/Hi5PF4ZKUSKyOYORHpoeg7ggBXaQF5r0OolqvNjxe7EhE+zlUIqnk5eprVrXT8H1QDF0Jg7pfdqVV9AIZO6i+e+1wOVDaP6K6tiWGdkRFH0wahcucZ/8xVoa8JVNZKke2mMCuLGsNWcN4DeLhkxa6giw3tkqbnY+eTYcW/PyVFMAVsZ8rOjQu4u4mm82FYBI7UywWQJTReD1LO2ibxHk74nwtyauX7KsCPFh2CA27DKlsQ1/xkjaCpE6vduzKzPj2DSHp6tKjxn2edPWRI+/4JxLD6KUFX1f1KqD0pKy/qVsZhEPI=" + file: release-out/**/* + skip_cleanup: true + file_glob: true + on: + repo: moby/buildkit + tags: true + condition: $TRAVIS_TAG =~ ^v[0-9] \ No newline at end of file diff --git a/hack/dockerfiles/test.buildkit.Dockerfile b/hack/dockerfiles/test.buildkit.Dockerfile index c18e549ac915..9a21a4710342 100644 --- a/hack/dockerfiles/test.buildkit.Dockerfile +++ b/hack/dockerfiles/test.buildkit.Dockerfile @@ -71,7 +71,7 @@ WORKDIR /go/src/github.com/moby/buildkit # scan the version/revision info FROM buildkit-base AS buildkit-version RUN --mount=target=. \ - PKG=github.com/moby/buildkit VERSION=$(git describe --match 'v[0-9]*' --dirty='.m' --always) REVISION=$(git rev-parse HEAD)$(if ! git diff --no-ext-diff --quiet --exit-code; then echo .m; fi); \ + PKG=github.com/moby/buildkit VERSION=$(git describe --match 'v[0-9]*' --dirty='.m' --always --tags) REVISION=$(git rev-parse HEAD)$(if ! git diff --no-ext-diff --quiet --exit-code; then echo .m; fi); \ echo "-X ${PKG}/version.Version=${VERSION} -X ${PKG}/version.Revision=${REVISION} -X ${PKG}/version.Package=${PKG}" | tee /tmp/.ldflags; \ echo -n "${VERSION}" | tee /tmp/.version; diff --git a/hack/release b/hack/release index dea42c713d27..726b81b4e7ba 100755 --- a/hack/release +++ b/hack/release @@ -14,7 +14,7 @@ if [ "$CONTINUOUS_INTEGRATION" == "true" ]; then progressFlag="--progress=plain" usage() { - echo "usage: ./hack/test [push]" + echo "usage: ./hack/release [push]" exit 1 } diff --git a/hack/release-tar b/hack/release-tar new file mode 100755 index 000000000000..e93ea8032e5b --- /dev/null +++ b/hack/release-tar @@ -0,0 +1,33 @@ +#!/usr/bin/env bash + +TAG=$1 +OUT=$2 + +set -eu -o pipefail + +: ${PLATFORMS=linux/amd64} +: ${CONTINUOUS_INTEGRATION=} + +progressFlag="" +if [ "$CONTINUOUS_INTEGRATION" == "true" ]; then progressFlag="--progress=plain"; fi + + +usage() { + echo "usage: ./hack/release-tar " + exit 1 +} + +if [ -z "$TAG" ] || [ -z "$OUT" ]; then + usage +fi + + +set -x + +buildctl build $progressFlag --frontend=dockerfile.v0 \ + --local context=. --local dockerfile=. \ + --frontend-opt filename=./hack/dockerfiles/test.buildkit.Dockerfile \ + --frontend-opt target=release \ + --frontend-opt platform=$PLATFORMS \ + --exporter local \ + --exporter-opt output=$OUT From 9da7b501956a359d435569405c43f09f8eb4ce26 Mon Sep 17 00:00:00 2001 From: Tonis Tiigi Date: Thu, 11 Oct 2018 13:46:16 -0700 Subject: [PATCH 4/5] cmd: fix app version reporting Signed-off-by: Tonis Tiigi --- cmd/buildctl/main.go | 1 + cmd/buildkitd/main.go | 1 + 2 files changed, 2 insertions(+) diff --git a/cmd/buildctl/main.go b/cmd/buildctl/main.go index 358ea619a8f2..5f1a6d93d370 100644 --- a/cmd/buildctl/main.go +++ b/cmd/buildctl/main.go @@ -28,6 +28,7 @@ func main() { app := cli.NewApp() app.Name = "buildctl" app.Usage = "build utility" + app.Version = version.Version defaultAddress := os.Getenv("BUILDKIT_HOST") if defaultAddress == "" { diff --git a/cmd/buildkitd/main.go b/cmd/buildkitd/main.go index 2f74ad94f9e2..d714a2a554d3 100644 --- a/cmd/buildkitd/main.go +++ b/cmd/buildkitd/main.go @@ -85,6 +85,7 @@ func main() { app := cli.NewApp() app.Name = "buildkitd" app.Usage = "build daemon" + app.Version = version.Version defaultConf, md := defaultConf() From 72ea6e2cff129ac15cb75acd4845fa67ceb79451 Mon Sep 17 00:00:00 2001 From: Tonis Tiigi Date: Thu, 11 Oct 2018 14:04:11 -0700 Subject: [PATCH 5/5] travis: update repo names to config Signed-off-by: Tonis Tiigi --- .travis.yml | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/.travis.yml b/.travis.yml index ac3b07f9fef3..6b1e6431dc8f 100644 --- a/.travis.yml +++ b/.travis.yml @@ -2,10 +2,9 @@ dist: trusty sudo: required install: - - docker run --name buildkit --rm -d --privileged -p 1234:1234 tonistiigi/buildkit --addr tcp://0.0.0.0:1234 + - docker run --name buildkit --rm -d --privileged -p 1234:1234 $REPO_SLUG_ORIGIN --addr tcp://0.0.0.0:1234 - sudo docker cp buildkit:/usr/bin/buildctl /usr/bin/ - export BUILDKIT_HOST=tcp://0.0.0.0:1234 - - git fetch --tags --unshallow env: global: @@ -20,12 +19,12 @@ before_deploy: deploy: - provider: script - script: ./hack/release master tonistiigi/buildkit push + script: ./hack/release master $REPO_SLUG_TARGET push on: repo: moby/buildkit branch: master - provider: script - script: ./hack/release $TRAVIS_TAG tonistiigi/buildkit push && PLATFORMS="${PLATFORMS},darwin/amd64,windows/amd64" ./hack/release-tar $TRAVIS_TAG release-out + script: ./hack/release $TRAVIS_TAG $REPO_SLUG_TARGET push && PLATFORMS="${PLATFORMS},darwin/amd64,windows/amd64" ./hack/release-tar $TRAVIS_TAG release-out on: repo: moby/buildkit tags: true