Merge pull request #3903 from thaJeztah/2.8_bump_go_118
[release/2.8] bump up golang version (alternative)
This commit is contained in:
commit
d3fac541b1
20 changed files with 73 additions and 70 deletions
1
.dockerignore
Normal file
1
.dockerignore
Normal file
|
@ -0,0 +1 @@
|
||||||
|
bin/
|
1
.github/workflows/build.yml
vendored
1
.github/workflows/build.yml
vendored
|
@ -87,7 +87,6 @@ jobs:
|
||||||
draft: true
|
draft: true
|
||||||
files: |
|
files: |
|
||||||
bin/*.tar.gz
|
bin/*.tar.gz
|
||||||
bin/*.zip
|
|
||||||
bin/*.sha256
|
bin/*.sha256
|
||||||
env:
|
env:
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
|
6
.github/workflows/ci.yml
vendored
6
.github/workflows/ci.yml
vendored
|
@ -25,13 +25,13 @@ jobs:
|
||||||
- name: Set up Go
|
- name: Set up Go
|
||||||
uses: actions/setup-go@v2
|
uses: actions/setup-go@v2
|
||||||
with:
|
with:
|
||||||
go-version: 1.16.*
|
go-version: 1.18.8
|
||||||
|
|
||||||
- name: Dependencies
|
- name: Dependencies
|
||||||
run: |
|
run: |
|
||||||
sudo apt-get -q update
|
sudo apt-get -q update
|
||||||
sudo -E apt-get -yq --no-install-suggests --no-install-recommends install python2-minimal
|
sudo -E apt-get -yq --no-install-suggests --no-install-recommends install python2-minimal
|
||||||
cd /tmp && go get -u github.com/vbatts/git-validation
|
cd /tmp && go install github.com/vbatts/git-validation@latest
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
working-directory: ./src/github.com/docker/distribution
|
working-directory: ./src/github.com/docker/distribution
|
||||||
|
@ -39,7 +39,7 @@ jobs:
|
||||||
DCO_VERBOSITY=-q script/validate/dco
|
DCO_VERBOSITY=-q script/validate/dco
|
||||||
GO111MODULE=on script/setup/install-dev-tools
|
GO111MODULE=on script/setup/install-dev-tools
|
||||||
script/validate/vendor
|
script/validate/vendor
|
||||||
go build -i .
|
go build .
|
||||||
make check
|
make check
|
||||||
make build
|
make build
|
||||||
make binaries
|
make binaries
|
||||||
|
|
82
Dockerfile
82
Dockerfile
|
@ -1,49 +1,59 @@
|
||||||
# syntax=docker/dockerfile:1.3
|
# syntax=docker/dockerfile:1
|
||||||
|
|
||||||
ARG GO_VERSION=1.16.15
|
ARG GO_VERSION=1.18.8
|
||||||
ARG GORELEASER_XX_VERSION=1.2.5
|
ARG ALPINE_VERSION=3.16
|
||||||
|
ARG XX_VERSION=1.1.1
|
||||||
|
|
||||||
FROM --platform=$BUILDPLATFORM crazymax/goreleaser-xx:${GORELEASER_XX_VERSION} AS goreleaser-xx
|
FROM --platform=$BUILDPLATFORM tonistiigi/xx:${XX_VERSION} AS xx
|
||||||
FROM --platform=$BUILDPLATFORM golang:${GO_VERSION}-alpine AS base
|
FROM --platform=$BUILDPLATFORM golang:${GO_VERSION}-alpine${ALPINE_VERSION} AS base
|
||||||
COPY --from=goreleaser-xx / /
|
COPY --from=xx / /
|
||||||
RUN apk add --no-cache file git
|
RUN apk add --no-cache bash coreutils file git
|
||||||
WORKDIR /go/src/github.com/docker/distribution
|
|
||||||
|
|
||||||
FROM base AS build
|
|
||||||
ENV GO111MODULE=auto
|
ENV GO111MODULE=auto
|
||||||
ENV CGO_ENABLED=0
|
ENV CGO_ENABLED=0
|
||||||
# GIT_REF is used by goreleaser-xx to handle the proper git ref when available.
|
WORKDIR /go/src/github.com/docker/distribution
|
||||||
# It will fallback to the working tree info if empty and use "git tag --points-at"
|
|
||||||
# or "git describe" to define the version info.
|
|
||||||
ARG GIT_REF
|
|
||||||
ARG TARGETPLATFORM
|
|
||||||
ARG PKG="github.com/distribution/distribution"
|
|
||||||
ARG BUILDTAGS="include_oss include_gcs"
|
|
||||||
RUN --mount=type=bind,rw \
|
|
||||||
--mount=type=cache,target=/root/.cache/go-build \
|
|
||||||
--mount=target=/go/pkg/mod,type=cache \
|
|
||||||
goreleaser-xx --debug \
|
|
||||||
--name="registry" \
|
|
||||||
--dist="/out" \
|
|
||||||
--main="./cmd/registry" \
|
|
||||||
--flags="-v" \
|
|
||||||
--ldflags="-s -w -X '$PKG/version.Version={{.Version}}' -X '$PKG/version.Revision={{.Commit}}' -X '$PKG/version.Package=$PKG'" \
|
|
||||||
--tags="$BUILDTAGS" \
|
|
||||||
--files="LICENSE" \
|
|
||||||
--files="README.md"
|
|
||||||
|
|
||||||
FROM scratch AS artifact
|
FROM base AS version
|
||||||
COPY --from=build /out/*.tar.gz /
|
ARG PKG="github.com/docker/distribution"
|
||||||
COPY --from=build /out/*.zip /
|
RUN --mount=target=. \
|
||||||
COPY --from=build /out/*.sha256 /
|
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#v} -X ${PKG}/version.Revision=${REVISION} -X ${PKG}/version.Package=${PKG}" | tee /tmp/.ldflags; \
|
||||||
|
echo -n "${VERSION}" | tee /tmp/.version;
|
||||||
|
|
||||||
|
FROM base AS build
|
||||||
|
ARG TARGETPLATFORM
|
||||||
|
ARG LDFLAGS="-s -w"
|
||||||
|
ARG BUILDTAGS="include_oss include_gcs"
|
||||||
|
RUN --mount=type=bind,target=/go/src/github.com/docker/distribution,rw \
|
||||||
|
--mount=type=cache,target=/root/.cache/go-build \
|
||||||
|
--mount=target=/go/pkg/mod,type=cache \
|
||||||
|
--mount=type=bind,source=/tmp/.ldflags,target=/tmp/.ldflags,from=version \
|
||||||
|
set -x ; xx-go build -trimpath -ldflags "$(cat /tmp/.ldflags) ${LDFLAGS}" -o /usr/bin/registry ./cmd/registry \
|
||||||
|
&& xx-verify --static /usr/bin/registry
|
||||||
|
|
||||||
FROM scratch AS binary
|
FROM scratch AS binary
|
||||||
COPY --from=build /usr/local/bin/registry* /
|
COPY --from=build /usr/bin/registry /
|
||||||
|
|
||||||
FROM alpine:3.16
|
FROM base AS releaser
|
||||||
|
ARG TARGETOS
|
||||||
|
ARG TARGETARCH
|
||||||
|
ARG TARGETVARIANT
|
||||||
|
WORKDIR /work
|
||||||
|
RUN --mount=from=binary,target=/build \
|
||||||
|
--mount=type=bind,target=/src \
|
||||||
|
--mount=type=bind,source=/tmp/.version,target=/tmp/.version,from=version \
|
||||||
|
VERSION=$(cat /tmp/.version) \
|
||||||
|
&& mkdir -p /out \
|
||||||
|
&& cp /build/registry /src/README.md /src/LICENSE . \
|
||||||
|
&& tar -czvf "/out/registry_${VERSION#v}_${TARGETOS}_${TARGETARCH}${TARGETVARIANT}.tar.tgz" * \
|
||||||
|
&& sha256sum -z "/out/registry_${VERSION#v}_${TARGETOS}_${TARGETARCH}${TARGETVARIANT}.tar.tgz" | awk '{ print $1 }' > "/out/registry_${VERSION#v}_${TARGETOS}_${TARGETARCH}${TARGETVARIANT}.tar.tgz.sha256"
|
||||||
|
|
||||||
|
FROM scratch AS artifact
|
||||||
|
COPY --from=releaser /out /
|
||||||
|
|
||||||
|
FROM alpine:${ALPINE_VERSION}
|
||||||
RUN apk add --no-cache ca-certificates
|
RUN apk add --no-cache ca-certificates
|
||||||
COPY cmd/registry/config-dev.yml /etc/docker/registry/config.yml
|
COPY cmd/registry/config-dev.yml /etc/docker/registry/config.yml
|
||||||
COPY --from=build /usr/local/bin/registry /bin/registry
|
COPY --from=binary /registry /bin/registry
|
||||||
VOLUME ["/var/lib/registry"]
|
VOLUME ["/var/lib/registry"]
|
||||||
EXPOSE 5000
|
EXPOSE 5000
|
||||||
ENTRYPOINT ["registry"]
|
ENTRYPOINT ["registry"]
|
||||||
|
|
2
Makefile
2
Makefile
|
@ -50,7 +50,7 @@ version/version.go:
|
||||||
|
|
||||||
check: ## run all linters (TODO: enable "unused", "varcheck", "ineffassign", "unconvert", "staticheck", "goimports", "structcheck")
|
check: ## run all linters (TODO: enable "unused", "varcheck", "ineffassign", "unconvert", "staticheck", "goimports", "structcheck")
|
||||||
@echo "$(WHALE) $@"
|
@echo "$(WHALE) $@"
|
||||||
golangci-lint run
|
@GO111MODULE=off golangci-lint run
|
||||||
|
|
||||||
test: ## run tests, except integration test with test.short
|
test: ## run tests, except integration test with test.short
|
||||||
@echo "$(WHALE) $@"
|
@echo "$(WHALE) $@"
|
||||||
|
|
|
@ -246,11 +246,7 @@ func (ctx *muxVarsContext) Value(key interface{}) interface{} {
|
||||||
return ctx.vars
|
return ctx.vars
|
||||||
}
|
}
|
||||||
|
|
||||||
if strings.HasPrefix(keyStr, "vars.") {
|
if v, ok := ctx.vars[strings.TrimPrefix(keyStr, "vars.")]; ok {
|
||||||
keyStr = strings.TrimPrefix(keyStr, "vars.")
|
|
||||||
}
|
|
||||||
|
|
||||||
if v, ok := ctx.vars[keyStr]; ok {
|
|
||||||
return v
|
return v
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,15 +1,3 @@
|
||||||
// GITHUB_REF is the actual ref that triggers the workflow
|
|
||||||
// https://docs.github.com/en/actions/learn-github-actions/environment-variables#default-environment-variables
|
|
||||||
variable "GITHUB_REF" {
|
|
||||||
default = ""
|
|
||||||
}
|
|
||||||
|
|
||||||
target "_common" {
|
|
||||||
args = {
|
|
||||||
GIT_REF = GITHUB_REF
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
group "default" {
|
group "default" {
|
||||||
targets = ["image-local"]
|
targets = ["image-local"]
|
||||||
}
|
}
|
||||||
|
@ -20,13 +8,11 @@ target "docker-metadata-action" {
|
||||||
}
|
}
|
||||||
|
|
||||||
target "binary" {
|
target "binary" {
|
||||||
inherits = ["_common"]
|
|
||||||
target = "binary"
|
target = "binary"
|
||||||
output = ["./bin"]
|
output = ["./bin"]
|
||||||
}
|
}
|
||||||
|
|
||||||
target "artifact" {
|
target "artifact" {
|
||||||
inherits = ["_common"]
|
|
||||||
target = "artifact"
|
target = "artifact"
|
||||||
output = ["./bin"]
|
output = ["./bin"]
|
||||||
}
|
}
|
||||||
|
@ -43,8 +29,13 @@ target "artifact-all" {
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Special target: https://github.com/docker/metadata-action#bake-definition
|
||||||
|
target "docker-metadata-action" {
|
||||||
|
tags = ["registry:local"]
|
||||||
|
}
|
||||||
|
|
||||||
target "image" {
|
target "image" {
|
||||||
inherits = ["_common", "docker-metadata-action"]
|
inherits = ["docker-metadata-action"]
|
||||||
}
|
}
|
||||||
|
|
||||||
target "image-local" {
|
target "image-local" {
|
||||||
|
|
|
@ -17,4 +17,4 @@ RUN wget https://golang.org/dl/go$GOLANG_VERSION.linux-amd64.tar.gz --quiet && \
|
||||||
tar -C /usr/local -xzf go$GOLANG_VERSION.linux-amd64.tar.gz && \
|
tar -C /usr/local -xzf go$GOLANG_VERSION.linux-amd64.tar.gz && \
|
||||||
rm go${GOLANG_VERSION}.linux-amd64.tar.gz
|
rm go${GOLANG_VERSION}.linux-amd64.tar.gz
|
||||||
|
|
||||||
RUN go get github.com/axw/gocov/gocov github.com/mattn/goveralls github.com/golang/lint/golint
|
RUN go install github.com/axw/gocov/gocov@latest github.com/mattn/goveralls@latest github.com/golang/lint/golint@latest
|
||||||
|
|
|
@ -114,9 +114,7 @@ func (r *registry) Repositories(ctx context.Context, entries []string, last stri
|
||||||
return 0, err
|
return 0, err
|
||||||
}
|
}
|
||||||
|
|
||||||
for cnt := range ctlg.Repositories {
|
copy(entries, ctlg.Repositories)
|
||||||
entries[cnt] = ctlg.Repositories[cnt]
|
|
||||||
}
|
|
||||||
numFilled = len(ctlg.Repositories)
|
numFilled = len(ctlg.Repositories)
|
||||||
|
|
||||||
link := resp.Header.Get("Link")
|
link := resp.Header.Get("Link")
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
//go:build go1.4
|
||||||
// +build go1.4
|
// +build go1.4
|
||||||
|
|
||||||
package handlers
|
package handlers
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
//go:build !go1.4
|
||||||
// +build !go1.4
|
// +build !go1.4
|
||||||
|
|
||||||
package handlers
|
package handlers
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
//go:build noresumabledigest
|
||||||
// +build noresumabledigest
|
// +build noresumabledigest
|
||||||
|
|
||||||
package storage
|
package storage
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
//go:build !noresumabledigest
|
||||||
// +build !noresumabledigest
|
// +build !noresumabledigest
|
||||||
|
|
||||||
package storage
|
package storage
|
||||||
|
|
|
@ -10,6 +10,7 @@
|
||||||
// Note that the contents of incomplete uploads are not accessible even though
|
// Note that the contents of incomplete uploads are not accessible even though
|
||||||
// Stat returns their length
|
// Stat returns their length
|
||||||
//
|
//
|
||||||
|
//go:build include_gcs
|
||||||
// +build include_gcs
|
// +build include_gcs
|
||||||
|
|
||||||
package gcs
|
package gcs
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
//go:build include_gcs
|
||||||
// +build include_gcs
|
// +build include_gcs
|
||||||
|
|
||||||
package gcs
|
package gcs
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
// Because OSS is a key, value store the Stat call does not support last modification
|
// Because OSS is a key, value store the Stat call does not support last modification
|
||||||
// time for directories (directories are an abstraction for key, value stores)
|
// time for directories (directories are an abstraction for key, value stores)
|
||||||
//
|
//
|
||||||
|
//go:build include_oss
|
||||||
// +build include_oss
|
// +build include_oss
|
||||||
|
|
||||||
package oss
|
package oss
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
//go:build include_oss
|
||||||
// +build include_oss
|
// +build include_oss
|
||||||
|
|
||||||
package oss
|
package oss
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
GOLANGCI_LINT_VERSION="v1.27.0"
|
GOLANGCI_LINT_VERSION="v1.50.1"
|
||||||
|
|
||||||
#
|
#
|
||||||
# Install developer tools to $GOBIN (or $GOPATH/bin if unset)
|
# Install developer tools to $GOBIN (or $GOPATH/bin if unset)
|
||||||
|
@ -8,5 +8,5 @@ GOLANGCI_LINT_VERSION="v1.27.0"
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
|
|
||||||
cd /tmp
|
cd /tmp
|
||||||
go get -u github.com/LK4D4/vndr
|
go install github.com/LK4D4/vndr@latest
|
||||||
go get "github.com/golangci/golangci-lint/cmd/golangci-lint@${GOLANGCI_LINT_VERSION}"
|
go install "github.com/golangci/golangci-lint/cmd/golangci-lint@${GOLANGCI_LINT_VERSION}"
|
||||||
|
|
|
@ -4,7 +4,7 @@ set -eu -o pipefail
|
||||||
|
|
||||||
if ! command -v git-validation; then
|
if ! command -v git-validation; then
|
||||||
>&2 echo "ERROR: git-validation not found. Install with:"
|
>&2 echo "ERROR: git-validation not found. Install with:"
|
||||||
>&2 echo " go get -u github.com/vbatts/git-validation"
|
>&2 echo " go install github.com/vbatts/git-validation@latest"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
|
@ -17,7 +17,7 @@ var Package = "$(go list)"
|
||||||
// Version indicates which version of the binary is running. This is set to
|
// Version indicates which version of the binary is running. This is set to
|
||||||
// the latest release tag by hand, always suffixed by "+unknown". During
|
// the latest release tag by hand, always suffixed by "+unknown". During
|
||||||
// build, it will be replaced by the actual version. The value here will be
|
// build, it will be replaced by the actual version. The value here will be
|
||||||
// used if the registry is run after a go get based install.
|
// used if the registry is run after a go install based install.
|
||||||
var Version = "$(git describe --match 'v[0-9]*' --dirty='.m' --always)+unknown"
|
var Version = "$(git describe --match 'v[0-9]*' --dirty='.m' --always)+unknown"
|
||||||
|
|
||||||
// Revision is filled with the VCS (e.g. git) revision being used to build
|
// Revision is filled with the VCS (e.g. git) revision being used to build
|
||||||
|
|
Loading…
Reference in a new issue