diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml new file mode 100644 index 00000000..54785644 --- /dev/null +++ b/.github/workflows/ci.yml @@ -0,0 +1,63 @@ +name: Docker publish + +# This workflow uses actions that are not certified by GitHub. +# They are provided by a third-party and are governed by +# separate terms of service, privacy policy, and support +# documentation. + +on: + + push: + branches: [ "main" ] + # Publish semver tags as releases. + tags: [ 'v*.*.*' ] + pull_request: + branches: [ "main" ] + + +defaults: + run: + shell: 'bash -Eeuo pipefail -x {0}' + +jobs: + generate-jobs: + name: customlimitrange-manager-build + runs-on: ubuntu-latest + strategy: + fail-fast: false + matrix: + include: + - + name: customlimitrange-manager + image: dongjiang1989/customlimitrange-manager:latest + file: ./hack/build/Dockerfile + platforms: linux/amd64,linux/arm64 + + steps: + - + name: Checkout + uses: actions/checkout@v3 + - + name: Set up QEMU + uses: docker/setup-qemu-action@v2 + - + name: Set up Docker Buildx + uses: docker/setup-buildx-action@v2 + - + name: Login to Registry + uses: docker/login-action@v2 + with: + username: ${{ secrets.DOCKERHUB_USERNAME }} + password: ${{ secrets.DOCKERHUB_TOKEN }} + - + name: Build and push + uses: docker/build-push-action@v3 + with: + file: ${{ matrix.file }} + platforms: ${{ matrix.platforms }} + push: true + tags: ${{ matrix.image }} + - name: Test ${{ matrix.name }} + run: | + docker pull ${{ matrix.image}}:${{ matrix.name }} + docker image inspect ${{ matrix.image}}:${{ matrix.name }}