feat: Speeding up workflows (#643)
* fix: rework macOS test so it's faster * feat: add go module caching
This commit is contained in:
parent
f56b21f6c3
commit
3e768cd916
1 changed files with 57 additions and 5 deletions
62
.github/workflows/push.yml
vendored
62
.github/workflows/push.yml
vendored
|
@ -1,5 +1,5 @@
|
||||||
name: push
|
name: push
|
||||||
on: [push, pull_request]
|
on: [push, pull_request, workflow_dispatch]
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
lint:
|
lint:
|
||||||
|
@ -28,7 +28,14 @@ jobs:
|
||||||
- uses: actions/setup-go@v1
|
- uses: actions/setup-go@v1
|
||||||
with:
|
with:
|
||||||
go-version: 1.16
|
go-version: 1.16
|
||||||
- run: go test -cover -coverprofile=coverage.txt -covermode=atomic ./...
|
- uses: actions/cache@v2
|
||||||
|
if: ${{ !env.ACT }}
|
||||||
|
with:
|
||||||
|
path: ~/go/pkg/mod
|
||||||
|
key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
|
||||||
|
restore-keys: |
|
||||||
|
${{ runner.os }}-go-
|
||||||
|
- run: go test -v -cover -coverprofile=coverage.txt -covermode=atomic ./...
|
||||||
env:
|
env:
|
||||||
CGO_ENABLED: 0
|
CGO_ENABLED: 0
|
||||||
- name: Upload Codecov report
|
- name: Upload Codecov report
|
||||||
|
@ -41,14 +48,45 @@ jobs:
|
||||||
name: Test on MacOS
|
name: Test on MacOS
|
||||||
runs-on: macos-latest
|
runs-on: macos-latest
|
||||||
continue-on-error: true # Don't let macos test fail whole workflow
|
continue-on-error: true # Don't let macos test fail whole workflow
|
||||||
|
env:
|
||||||
|
ISO_PATH: ~/.docker/machine/cache/boot2docker.iso
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
- uses: actions/setup-go@v1
|
- uses: actions/setup-go@v1
|
||||||
with:
|
with:
|
||||||
go-version: 1.16
|
go-version: 1.16
|
||||||
- name: Install MacOS Docker
|
- uses: actions/cache@v2
|
||||||
uses: docker-practice/actions-setup-docker@master
|
if: ${{ !env.ACT }}
|
||||||
- run: go test -v -timeout 1h -cover ./...
|
with:
|
||||||
|
path: ~/go/pkg/mod
|
||||||
|
key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
|
||||||
|
restore-keys: |
|
||||||
|
${{ runner.os }}-go-
|
||||||
|
- uses: actions/cache@v2
|
||||||
|
with:
|
||||||
|
key: boot2docker
|
||||||
|
path: ${{ env.ISO_PATH }}
|
||||||
|
restore-keys: boot2docker
|
||||||
|
- name: Install Docker on macOS
|
||||||
|
run: |
|
||||||
|
printf " 🛠️ Downloading boot2docker.iso 🛠️ \n\n"
|
||||||
|
mkdir -p ~/.docker/machine/cache/
|
||||||
|
test -f ${{ env.ISO_PATH }} && printf " 🛠️ ${{ env.ISO_PATH }} successfully restored 🛠️ \n\n" || wget "https://github.com/boot2docker/boot2docker/releases/download/v19.03.12/boot2docker.iso" -O ${{ env.ISO_PATH }}
|
||||||
|
printf " 🛠️ Installing Docker from Homebrew 🛠️ \n\n"
|
||||||
|
brew install docker docker-machine
|
||||||
|
printf " 🛠️ Creating Docker VM 🛠️ \n\n"
|
||||||
|
docker-machine create --driver virtualbox --virtualbox-boot2docker-url ${{ env.ISO_PATH }} default
|
||||||
|
docker-machine env default
|
||||||
|
printf " 🛠️ Adding Docker VM info to environment 🛠️ \n\n"
|
||||||
|
eval "$(docker-machine env default)"
|
||||||
|
echo "DOCKER_TLS_VERIFY=$DOCKER_TLS_VERIFY" | tee -a $GITHUB_ENV
|
||||||
|
echo "DOCKER_HOST=$DOCKER_HOST" | tee -a $GITHUB_ENV
|
||||||
|
echo "DOCKER_CERT_PATH=$DOCKER_CERT_PATH" | tee -a $GITHUB_ENV
|
||||||
|
echo "DOCKER_MACHINE_NAME=$DOCKER_MACHINE_NAME" | tee -a $GITHUB_ENV
|
||||||
|
printf " 🛠️ Install Qemu for running containers with different architecture 🛠️ \n\n"
|
||||||
|
docker run --rm --privileged tonistiigi/binfmt --install all
|
||||||
|
printf " 🛠️ Finished installing Docker 🛠️ \n\n"
|
||||||
|
- run: go test -v -timeout 30m -cover ./...
|
||||||
env:
|
env:
|
||||||
CGO_ENABLED: 0
|
CGO_ENABLED: 0
|
||||||
|
|
||||||
|
@ -64,6 +102,13 @@ jobs:
|
||||||
- uses: actions/setup-go@v1
|
- uses: actions/setup-go@v1
|
||||||
with:
|
with:
|
||||||
go-version: 1.16
|
go-version: 1.16
|
||||||
|
- uses: actions/cache@v2
|
||||||
|
if: ${{ !env.ACT }}
|
||||||
|
with:
|
||||||
|
path: ~/go/pkg/mod
|
||||||
|
key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
|
||||||
|
restore-keys: |
|
||||||
|
${{ runner.os }}-go-
|
||||||
- name: GoReleaser
|
- name: GoReleaser
|
||||||
uses: goreleaser/goreleaser-action@v2
|
uses: goreleaser/goreleaser-action@v2
|
||||||
with:
|
with:
|
||||||
|
@ -99,6 +144,13 @@ jobs:
|
||||||
- uses: actions/setup-go@v1
|
- uses: actions/setup-go@v1
|
||||||
with:
|
with:
|
||||||
go-version: 1.16
|
go-version: 1.16
|
||||||
|
- uses: actions/cache@v2
|
||||||
|
if: ${{ !env.ACT }}
|
||||||
|
with:
|
||||||
|
path: ~/go/pkg/mod
|
||||||
|
key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
|
||||||
|
restore-keys: |
|
||||||
|
${{ runner.os }}-go-
|
||||||
- name: GoReleaser
|
- name: GoReleaser
|
||||||
uses: goreleaser/goreleaser-action@v1
|
uses: goreleaser/goreleaser-action@v1
|
||||||
with:
|
with:
|
||||||
|
|
Loading…
Reference in a new issue