name: build on: push: branches: - 'master' tags: - 'v*' pull_request: jobs: goreleaser: runs-on: ubuntu-latest env: DOCKER_CLI_EXPERIMENTAL: "enabled" steps: - name: Checkout uses: actions/checkout@v2.3.4 with: fetch-depth: 0 - name: Set up QEMU uses: docker/setup-qemu-action@v1 - name: Set up Docker Buildx uses: docker/setup-buildx-action@v1 - name: apt update run: sudo apt-get update - name: Set up Snapcraft run: | sudo apt-get -yq --no-install-suggests --no-install-recommends install snapcraft - name: Set up Go uses: actions/setup-go@v2 with: go-version: 1.15 - name: Cache Go modules uses: actions/cache@v2 with: path: ~/go/pkg/mod key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }} restore-keys: | ${{ runner.os }}-go- - name: Make Setup run: | make setup - name: Make CI run: | make ci - name: Upload coverage uses: codecov/codecov-action@v1.1.1 with: token: ${{ secrets.CODECOV_TOKEN }} file: ./coverage.txt - name: Check run: | ./goreleaser check - name: Docker Login if: success() && startsWith(github.ref, 'refs/tags/v') env: DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }} GITHUB_TOKEN: ${{ secrets.GH_PAT }} run: | echo "${DOCKER_PASSWORD}" | docker login --username "${DOCKER_USERNAME}" --password-stdin echo "${GITHUB_TOKEN}" | docker login ghcr.io --username $GITHUB_ACTOR --password-stdin - name: Snapcraft Login if: success() && startsWith(github.ref, 'refs/tags/v') env: SNAPCRAFT_LOGIN: ${{ secrets.SNAPCRAFT_LOGIN }} run: | snapcraft login --with <(echo "$SNAPCRAFT_LOGIN") - name: GoReleaser if: success() env: GITHUB_TOKEN: ${{ secrets.GH_PAT }} run: | if [[ $GITHUB_REF == refs/tags/v* ]]; then ./goreleaser elif [[ $GITHUB_REF == refs/heads/master ]]; then ./goreleaser --snapshot fi - name: Clear if: always() && startsWith(github.ref, 'refs/tags/v') run: | rm -f ${HOME}/.docker/config.json