diff --git a/.drone.yml b/.drone.yml deleted file mode 100644 index ef030c3f8..000000000 --- a/.drone.yml +++ /dev/null @@ -1,276 +0,0 @@ ---- -kind: pipeline -name: amd64 - -platform: - os: linux - arch: amd64 - -steps: -- name: build - image: rancher/dapper:v0.4.2 - commands: - - dapper ci - #- dapper e2e-test - volumes: - - name: docker - path: /var/run/docker.sock - -- name: github_binary_release - image: plugins/github-release - settings: - api_key: - from_secret: github_token - prerelease: true - checksum: - - sha256 - checksum_file: CHECKSUMsum-amd64.txt - checksum_flatten: true - files: - - "dist/artifacts/*" - when: - instance: - - drone-publish.rancher.io - event: - - tag - -- name: docker-publish - image: plugins/docker - settings: - dockerfile: package/Dockerfile - password: - from_secret: docker_password - repo: "rancher/local-path-provisioner" - tag: "${DRONE_BRANCH}-head-amd64" - username: - from_secret: docker_username - when: - instance: - - drone-publish.rancher.io - event: - - push - -- name: docker-tagged-publish - image: plugins/docker - settings: - dockerfile: package/Dockerfile - password: - from_secret: docker_password - repo: "rancher/local-path-provisioner" - tag: "${DRONE_TAG}-amd64" - username: - from_secret: docker_username - when: - instance: - - drone-publish.rancher.io - event: - - tag - -volumes: -- name: docker - host: - path: /var/run/docker.sock - ---- -kind: pipeline -name: arm64 - -platform: - os: linux - arch: arm64 - -steps: -- name: build - image: rancher/dapper:v0.4.2 - commands: - - dapper ci -# - dapper e2e-test - volumes: - - name: docker - path: /var/run/docker.sock - -- name: github_binary_release - image: plugins/github-release - settings: - api_key: - from_secret: github_token - prerelease: true - checksum: - - sha256 - checksum_file: CHECKSUMsum-arm64.txt - checksum_flatten: true - files: - - "dist/artifacts/*" - when: - instance: - - drone-publish.rancher.io - event: - - tag - -- name: docker-publish - image: plugins/docker - settings: - dockerfile: package/Dockerfile - password: - from_secret: docker_password - repo: "rancher/local-path-provisioner" - tag: "${DRONE_BRANCH}-head-arm64" - username: - from_secret: docker_username - when: - instance: - - drone-publish.rancher.io - event: - - push - -- name: docker-tagged-publish - image: plugins/docker - settings: - dockerfile: package/Dockerfile - password: - from_secret: docker_password - repo: "rancher/local-path-provisioner" - tag: "${DRONE_TAG}-arm64" - username: - from_secret: docker_username - when: - instance: - - drone-publish.rancher.io - event: - - tag - -volumes: -- name: docker - host: - path: /var/run/docker.sock - ---- -kind: pipeline -name: arm - -platform: - os: linux - arch: arm - -# ad-hoc fix: -# disable the use of upstream images /~https://github.com/rancherlabs/eio/issues/1493 -clone: - disable: true - -steps: -- name: clone - image: drone/git:linux-arm -- name: build - image: rancher/dapper:v0.4.2 - commands: - - dapper ci - volumes: - - name: docker - path: /var/run/docker.sock - -- name: github_binary_release - image: plugins/github-release:linux-arm - settings: - api_key: - from_secret: github_token - prerelease: true - checksum: - - sha256 - checksum_file: CHECKSUMsum-arm.txt - checksum_flatten: true - files: - - "dist/artifacts/*" - when: - instance: - - drone-publish.rancher.io - event: - - tag - -- name: docker-publish - image: plugins/docker:linux-arm - settings: - dockerfile: package/Dockerfile - password: - from_secret: docker_password - repo: "rancher/local-path-provisioner" - tag: "${DRONE_BRANCH}-head-arm" - username: - from_secret: docker_username - when: - instance: - - drone-publish.rancher.io - event: - - push - -- name: docker-tagged-publish - image: plugins/docker:linux-arm - settings: - dockerfile: package/Dockerfile - password: - from_secret: docker_password - repo: "rancher/local-path-provisioner" - tag: "${DRONE_TAG}-arm" - username: - from_secret: docker_username - when: - instance: - - drone-publish.rancher.io - event: - - tag - -volumes: -- name: docker - host: - path: /var/run/docker.sock - ---- -kind: pipeline -name: manifest - -platform: - os: linux - arch: amd64 - -steps: -- name: manifest - image: plugins/manifest:1.0.2 - settings: - username: - from_secret: docker_username - password: - from_secret: docker_password - platforms: - - linux/amd64 - - linux/arm64 - - linux/arm - target: "rancher/local-path-provisioner:${DRONE_BRANCH}-head" - template: "rancher/local-path-provisioner:${DRONE_BRANCH}-head-ARCH" - when: - instance: - - drone-publish.rancher.io - event: - - push - -- name: manifest-tag - image: plugins/manifest:1.0.2 - settings: - username: - from_secret: docker_username - password: - from_secret: docker_password - platforms: - - linux/amd64 - - linux/arm64 - - linux/arm - target: "rancher/local-path-provisioner:${DRONE_TAG}" - template: "rancher/local-path-provisioner:${DRONE_TAG}-ARCH" - when: - instance: - - drone-publish.rancher.io - event: - - tag - -depends_on: -- amd64 -- arm64 -- arm diff --git a/.github/stale.yaml b/.github/stale.yaml deleted file mode 100644 index b3589df53..000000000 --- a/.github/stale.yaml +++ /dev/null @@ -1,63 +0,0 @@ -# Configuration for probot-stale - /~https://github.com/probot/stale - -# Number of days of inactivity before an Issue or Pull Request becomes stale -daysUntilStale: 60 - -# Number of days of inactivity before an Issue or Pull Request with the stale label is closed. -# Set to false to disable. If disabled, issues still need to be closed manually, but will remain marked as stale. -daysUntilClose: 7 - -# Only issues or pull requests with all of these labels are check if stale. Defaults to `[]` (disabled) -onlyLabels: [] - -# Issues or Pull Requests with these labels will never be considered stale. Set to `[]` to disable -exemptLabels: - - bug - - doc - - enhancement - - good first issue - - help wanted - - question - -# Set to true to ignore issues in a project (defaults to false) -exemptProjects: true - -# Set to true to ignore issues in a milestone (defaults to false) -exemptMilestones: true - -# Set to true to ignore issues with an assignee (defaults to false) -exemptAssignees: true - -# Label to use when marking as stale -staleLabel: wontfix - -# Comment to post when marking as stale. Set to `false` to disable -markComment: > - This issue has been automatically marked as stale because it has not had - recent activity. It will be closed if no further activity occurs. Thank you - for your contributions. -# Comment to post when removing the stale label. -# unmarkComment: > -# Your comment here. - -# Comment to post when closing a stale Issue or Pull Request. -# closeComment: > -# Your comment here. - -# Limit the number of actions per hour, from 1-30. Default is 30 -limitPerRun: 30 - -# Limit to only `issues` or `pulls` -# only: issues - -# Optionally, specify configuration settings that are specific to just 'issues' or 'pulls': -# pulls: -# daysUntilStale: 30 -# markComment: > -# This pull request has been automatically marked as stale because it has not had -# recent activity. It will be closed if no further activity occurs. Thank you -# for your contributions. - -# issues: -# exemptLabels: -# - confirmed \ No newline at end of file diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml new file mode 100644 index 000000000..59a92d9ee --- /dev/null +++ b/.github/workflows/build.yml @@ -0,0 +1,104 @@ +name: build +on: + push: + branches: + - master + - v* + tags: + - v* + pull_request: +jobs: + build: + name: Build Binaries + runs-on: ubuntu-latest + permissions: + contents: read + id-token: write + steps: + - name: Checkout Codes + uses: actions/checkout@v4 + + # Build binaries + - name: Run CI + run: make ci + + # Run e2e test + - name: Run e2e Test + run: make e2e-test + + # Upload binaries + - name: Upload Binaries + uses: actions/upload-artifact@v4 + with: + name: binaries_artifact + path: ./bin/* + + build_push_image: + name: Build and Push Images + runs-on: ubuntu-latest + permissions: + contents: read + id-token: write + needs: build + if: ${{ startsWith(github.ref, 'refs/heads/') || startsWith(github.ref, 'refs/tags/') }} + steps: + - name: Checkout Codes + uses: actions/checkout@v4 + + - name: Download Binaries + uses: actions/download-artifact@v4 + with: + name: binaries_artifact + path: ./bin/ + + - name: Add Executable Permission + run: | + chmod +x ./bin/* + + - name: Copy bin Folder to package Folder + run: | + cp -r ./bin ./package/ + + # For multi-platform support + - name: Set up QEMU + uses: docker/setup-qemu-action@v3 + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + + - name: Read Secrets + uses: rancher-eio/read-vault-secrets@main + if: ${{ inputs.push == true }} + with: + secrets: | + secret/data/github/repo/${{ github.repository }}/dockerhub/rancher/credentials username | DOCKER_USERNAME ; + secret/data/github/repo/${{ github.repository }}/dockerhub/rancher/credentials password | DOCKER_PASSWORD + + - name: Login to Docker Hub + run: | + echo "branch=${GITHUB_HEAD_REF:-${GITHUB_REF#refs/heads/}}" >> "$GITHUB_ENV" + - name: Login to Docker Hub + uses: docker/login-action@v3 + with: + username: ${{ env.DOCKER_USERNAME }} + password: ${{ env.DOCKER_PASSWORD }} + + # rancher/local-path-provisioner image + - name: docker-publish + if: ${{ startsWith(github.ref, 'refs/heads/') }} + uses: docker/build-push-action@v5 + with: + context: ./ + push: true + platforms: linux/amd64,linux/arm64, linux/arm + tags: rancher/local-path-provisioner:${{ env.branch }}-head + file: package/Dockerfile + + - name: docker-publish-with-tag + if: ${{ startsWith(github.ref, 'refs/tags/') }} + uses: docker/build-push-action@v5 + with: + context: ./ + push: true + platforms: linux/amd64,linux/arm64, linux/arm + tags: rancher/local-path-provisioner:${{ github.ref_name }} + file: package/Dockerfile diff --git a/.github/workflows/stale.yaml b/.github/workflows/stale.yaml new file mode 100644 index 000000000..aa1f4f27c --- /dev/null +++ b/.github/workflows/stale.yaml @@ -0,0 +1,28 @@ +name: 'Close stale issues and PRs' + +on: + workflow_call: + workflow_dispatch: + schedule: + - cron: '30 1 * * *' + +jobs: + stale: + runs-on: ubuntu-latest + steps: + - uses: actions/stale@v4 + with: + stale-issue-message: 'This issue is stale because it has been open 30 days with no activity. Remove stale label or comment or this will be closed in 5 days.' + stale-pr-message: 'This PR is stale because it has been open 45 days with no activity. Remove stale label or comment or this will be closed in 10 days.' + close-issue-message: 'This issue was closed because it has been stalled for 5 days with no activity.' + close-pr-message: 'This PR was closed because it has been stalled for 10 days with no activity.' + days-before-stale: 60 + days-before-pr-stale: 45 + days-before-close: 5 + days-before-pr-close: 10 + stale-issue-label: 'stale' + stale-pr-label: 'stale' + exempt-all-assignees: true + exempt-issue-labels: 'bug,doc,enhancement,good first issue,help wanted,question' + exempt-draft-pr: true + exempt-all-milestones: true diff --git a/Dockerfile.dapper b/Dockerfile.dapper index 90d0ec2b3..497b2cd17 100644 --- a/Dockerfile.dapper +++ b/Dockerfile.dapper @@ -14,6 +14,13 @@ RUN if [ "${ARCH}" == "amd64" ]; then \ curl -sL "/~https://github.com/kubernetes-sigs/kustomize/releases/download/kustomize%2Fv4.2.0/kustomize_v4.2.0_linux_${ARCH}.tar.gz" | tar -zxv -C /usr/local/bin; \ fi +RUN curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $(go env GOPATH)/bin v1.55.2 + +# The docker version in dapper is too old to have buildx. Install it manually. +RUN wget /~https://github.com/docker/buildx/releases/download/v0.13.1/buildx-v0.13.1.linux-${ARCH} && \ + chmod +x buildx-v0.13.1.linux-${ARCH} && \ + mv buildx-v0.13.1.linux-${ARCH} /usr/local/bin/buildx + ENV DAPPER_ENV REPO TAG DRONE_TAG ENV DAPPER_SOURCE /go/src/github.com/rancher/local-path-provisioner/ ENV DAPPER_OUTPUT ./bin ./dist diff --git a/main.go b/main.go index cddd4097c..3f0c9a49c 100644 --- a/main.go +++ b/main.go @@ -51,12 +51,12 @@ var ( EnvConfigMountPath = "CONFIG_MOUNT_PATH" ) -func cmdNotFound(c *cli.Context, command string) { +func cmdNotFound(_ *cli.Context, command string) { panic(fmt.Errorf("Unrecognized command: %s", command)) } -func onUsageError(c *cli.Context, err error, isSubcommand bool) error { - panic(fmt.Errorf("Usage error, please check your command")) +func onUsageError(_ *cli.Context, err error, _ bool) error { + panic(errors.Wrap(err, "Usage error, please check your command")) } func RegisterShutdownChannel(cancelFn context.CancelFunc) { diff --git a/package/Dockerfile b/package/Dockerfile index 4a3a66c05..a25f36fb7 100644 --- a/package/Dockerfile +++ b/package/Dockerfile @@ -1,7 +1,18 @@ +# syntax=docker/dockerfile:1.7.0 + FROM alpine +ARG TARGETPLATFORM +RUN if [ "$TARGETPLATFORM" != "linux/amd64" ] && [ "$TARGETPLATFORM" != "linux/arm64" ] && [ "$TARGETPLATFORM" != "linux/arm/v7" ]; then \ + echo "Error: Unsupported TARGETPLATFORM: $TARGETPLATFORM" && \ + exit 1; \ + fi + +ENV ARCH ${TARGETPLATFORM#linux/} +ENV ARCH ${ARCH%/v7} + RUN apk update RUN apk upgrade --no-cache busybox zlib -COPY bin/local-path-provisioner /usr/bin/ +COPY bin/local-path-provisioner-${ARCH} /usr/bin/local-path-provisioner CMD ["local-path-provisioner"] diff --git a/provisioner.go b/provisioner.go index 1f86f0cb0..9f774cc59 100644 --- a/provisioner.go +++ b/provisioner.go @@ -300,7 +300,7 @@ type pvMetadata struct { func pathFromPattern(pattern string, opts pvController.ProvisionOptions) (string, error) { metadata := pvMetadata{ PVName: opts.PVName, - PVC: opts.PVC.ObjectMeta, + PVC: opts.PVC.ObjectMeta, } tpl, err := template.New("pathPattern").Parse(pattern) @@ -317,7 +317,7 @@ func pathFromPattern(pattern string, opts pvController.ProvisionOptions) (string return buf.String(), nil } -func (p *LocalPathProvisioner) Provision(ctx context.Context, opts pvController.ProvisionOptions) (*v1.PersistentVolume, pvController.ProvisioningState, error) { +func (p *LocalPathProvisioner) Provision(_ context.Context, opts pvController.ProvisionOptions) (*v1.PersistentVolume, pvController.ProvisioningState, error) { cfg, err := p.pickConfig(opts.StorageClass.Name) if err != nil { return nil, pvController.ProvisioningFinished, err @@ -462,7 +462,7 @@ func (p *LocalPathProvisioner) provisionFor(opts pvController.ProvisionOptions, }, pvController.ProvisioningFinished, nil } -func (p *LocalPathProvisioner) Delete(ctx context.Context, pv *v1.PersistentVolume) (err error) { +func (p *LocalPathProvisioner) Delete(_ context.Context, pv *v1.PersistentVolume) (err error) { cfg, err := p.pickConfig(pv.Spec.StorageClassName) if err != nil { return err diff --git a/scripts/build b/scripts/build index 5d5218fb0..a41c1c533 100755 --- a/scripts/build +++ b/scripts/build @@ -10,7 +10,9 @@ if [ "$(uname)" = "Linux" ]; then OTHER_LINKFLAGS="-extldflags -static -s -w" fi LINKFLAGS="-X main.VERSION=$VERSION" -CGO_ENABLED=0 go build -ldflags "$LINKFLAGS $OTHER_LINKFLAGS" -o bin/local-path-provisioner +CGO_ENABLED=0 GOARCH=amd64 go build -ldflags "$LINKFLAGS $OTHER_LINKFLAGS" -o bin/local-path-provisioner-amd64 +CGO_ENABLED=0 GOARCH=arm64 go build -ldflags "$LINKFLAGS $OTHER_LINKFLAGS" -o bin/local-path-provisioner-arm64 +CGO_ENABLED=0 GOARCH=arm go build -ldflags "$LINKFLAGS $OTHER_LINKFLAGS" -o bin/local-path-provisioner-arm if [ "$CROSS" = "true" ] && [ "$ARCH" = "amd64" ]; then GOOS=darwin go build -ldflags "$LINKFLAGS" -o bin/local-path-provisioner-darwin GOOS=windows go build -ldflags "$LINKFLAGS" -o bin/local-path-provisioner-windows diff --git a/scripts/package b/scripts/package index ea6f5f3f3..e006b2e1c 100755 --- a/scripts/package +++ b/scripts/package @@ -6,7 +6,7 @@ source $(dirname $0)/version cd $(dirname $0)/.. mkdir -p dist/artifacts -cp bin/local-path-provisioner dist/artifacts/local-path-provisioner${SUFFIX} +cp bin/local-path-provisioner* dist/artifacts/ IMAGE=${REPO}/local-path-provisioner:${TAG} DOCKERFILE=package/Dockerfile @@ -14,7 +14,7 @@ if [ -e ${DOCKERFILE}.${ARCH} ]; then DOCKERFILE=${DOCKERFILE}.${ARCH} fi -docker build -f ${DOCKERFILE} -t ${IMAGE} . +buildx build --load -t ${IMAGE} -f ${DOCKERFILE} . echo Built ${IMAGE} echo ${IMAGE} > ./bin/latest_image diff --git a/test/util.go b/test/util.go index bdc93607e..7aedec0b6 100644 --- a/test/util.go +++ b/test/util.go @@ -12,6 +12,7 @@ import ( ) func createCmd(t *testing.T, cmd, kustomizeDir string, envs []string, callback func(*exec.Cmd)) *exec.Cmd { + t.Logf("creating command: %s", cmd) c := exec.Command("bash", "-c", cmd) c.Env = append(os.Environ(), envs...) c.Dir = kustomizeDir