2020-03-20 17:38:44 +03:00
# Used as inspiration: https://github.com/mvdan/github-actions-golang
2020-08-01 23:23:22 +03:00
name : Tests
2020-03-20 17:38:44 +03:00
on :
push :
2020-05-06 03:50:30 +03:00
branches :
2020-03-23 23:26:53 +03:00
- master
2021-05-12 07:26:16 +03:00
- 2 .*
2020-03-20 17:38:44 +03:00
pull_request :
2020-05-06 03:50:30 +03:00
branches :
2020-03-23 23:26:53 +03:00
- master
2021-05-12 07:26:16 +03:00
- 2 .*
2020-03-20 17:38:44 +03:00
jobs :
test :
strategy :
# Default is true, cancels jobs for other platforms in the matrix if one fails
fail-fast : false
matrix :
2023-07-22 07:00:48 +03:00
os :
- ubuntu-latest
- macos-latest
- windows-latest
go :
- '1.20'
2023-08-09 19:34:28 +03:00
- '1.21'
2020-03-22 01:53:42 +03:00
2022-04-13 23:03:38 +03:00
include :
# Set the minimum Go patch version for the given Go minor
# Usable via ${{ matrix.GO_SEMVER }}
2023-02-06 19:29:20 +03:00
- go : '1.20'
2023-07-22 07:00:48 +03:00
GO_SEMVER : '~1.20.6'
2023-08-09 19:34:28 +03:00
- go : '1.21'
GO_SEMVER : '~1.21.0'
2022-04-13 23:03:38 +03:00
2020-03-22 01:53:42 +03:00
# Set some variables per OS, usable via ${{ matrix.VAR }}
# CADDY_BIN_PATH: the path to the compiled Caddy binary, for artifact publishing
# SUCCESS: the typical value for $? per OS (Windows/pwsh returns 'True')
- os : ubuntu-latest
CADDY_BIN_PATH : ./cmd/caddy/caddy
SUCCESS : 0
- os : macos-latest
CADDY_BIN_PATH : ./cmd/caddy/caddy
SUCCESS : 0
- os : windows-latest
CADDY_BIN_PATH : ./cmd/caddy/caddy.exe
SUCCESS : 'True'
2020-03-20 17:38:44 +03:00
runs-on : ${{ matrix.os }}
steps :
2023-04-15 04:38:33 +03:00
- name : Checkout code
2023-10-02 03:13:54 +03:00
uses : actions/checkout@v4
2023-04-15 04:38:33 +03:00
2020-03-20 17:38:44 +03:00
- name : Install Go
2024-01-02 10:13:31 +03:00
uses : actions/setup-go@v5
2020-03-20 17:38:44 +03:00
with :
2022-04-13 23:03:38 +03:00
go-version : ${{ matrix.GO_SEMVER }}
check-latest : true
2020-03-20 17:38:44 +03:00
# These tools would be useful if we later decide to reinvestigate
# publishing test/coverage reports to some tool for easier consumption
# - name: Install test and coverage analysis tools
# run: |
# go get github.com/axw/gocov/gocov
# go get github.com/AlekSi/gocov-xml
# go get -u github.com/jstemmer/go-junit-report
2022-12-28 20:05:42 +03:00
# echo "$(go env GOPATH)/bin" >> $GITHUB_PATH
2020-03-20 17:38:44 +03:00
- name : Print Go version and environment
2020-03-22 02:44:51 +03:00
id : vars
2023-08-25 19:06:44 +03:00
shell : bash
2020-03-20 17:38:44 +03:00
run : |
printf "Using go at: $(which go)\n"
printf "Go version: $(go version)\n"
printf "\n\nGo environment:\n\n"
go env
printf "\n\nSystem environment:\n\n"
env
2021-01-29 01:40:36 +03:00
printf "Git version: $(git version)\n\n"
2020-03-22 02:44:51 +03:00
# Calculate the short SHA1 hash of the git commit
2022-12-28 20:05:42 +03:00
echo "short_sha=$(git rev-parse --short HEAD)" >> $GITHUB_OUTPUT
2020-04-17 20:54:35 +03:00
2020-03-20 17:38:44 +03:00
- name : Get dependencies
run : |
go get -v -t -d ./...
# mkdir test-results
- name : Build Caddy
working-directory : ./cmd/caddy
env :
CGO_ENABLED : 0
run : |
2020-04-17 20:54:35 +03:00
go build -trimpath -ldflags="-w -s" -v
2020-03-20 17:38:44 +03:00
2020-03-22 01:53:42 +03:00
- name : Publish Build Artifact
2024-01-02 11:23:25 +03:00
uses : actions/upload-artifact@v4
2020-03-20 17:38:44 +03:00
with :
2020-08-21 05:40:26 +03:00
name : caddy_${{ runner.os }}_go${{ matrix.go }}_${{ steps.vars.outputs.short_sha }}
2020-03-22 01:53:42 +03:00
path : ${{ matrix.CADDY_BIN_PATH }}
2024-01-02 11:23:25 +03:00
compression-level : 0
2020-03-20 17:38:44 +03:00
# Commented bits below were useful to allow the job to continue
# even if the tests fail, so we can publish the report separately
# For info about set-output, see https://stackoverflow.com/questions/57850553/github-actions-check-steps-status
- name : Run tests
# id: step_test
# continue-on-error: true
run : |
# (go test -v -coverprofile=cover-profile.out -race ./... 2>&1) > test-results/test-result.out
2020-03-25 17:55:14 +03:00
go test -v -coverprofile="cover-profile.out" -short -race ./...
2022-12-28 20:05:42 +03:00
# echo "status=$?" >> $GITHUB_OUTPUT
2020-03-20 17:38:44 +03:00
# Relevant step if we reinvestigate publishing test/coverage reports
# - name: Prepare coverage reports
# run: |
# mkdir coverage
# gocov convert cover-profile.out > coverage/coverage.json
# # Because Windows doesn't work with input redirection like *nix, but output redirection works.
# (cat ./coverage/coverage.json | gocov-xml) > coverage/coverage.xml
# To return the correct result even though we set 'continue-on-error: true'
2020-03-22 01:53:42 +03:00
# - name: Coerce correct build result
# if: matrix.os != 'windows-latest' && steps.step_test.outputs.status != ${{ matrix.SUCCESS }}
2020-03-20 17:38:44 +03:00
# run: |
# echo "step_test ${{ steps.step_test.outputs.status }}\n"
# exit 1
2020-06-12 20:11:46 +03:00
s390x-test :
name : test (s390x on IBM Z)
runs-on : ubuntu-latest
2022-12-22 22:13:47 +03:00
if : github.event.pull_request.head.repo.full_name == github.repository && github.actor != 'dependabot[bot]'
2020-08-06 23:17:40 +03:00
continue-on-error: true # August 2020 : s390x VM is down due to weather and power issues
2020-06-12 20:11:46 +03:00
steps :
2023-04-15 04:38:33 +03:00
- name : Checkout code
2023-10-02 03:13:54 +03:00
uses : actions/checkout@v4
2020-06-12 20:11:46 +03:00
- name : Run Tests
run : |
mkdir -p ~/.ssh && echo -e "${SSH_KEY//_/\\n}" > ~/.ssh/id_ecdsa && chmod og-rwx ~/.ssh/id_ecdsa
# short sha is enough?
short_sha=$(git rev-parse --short HEAD)
# The environment is fresh, so there's no point in keeping accepting and adding the key.
2022-10-04 17:03:10 +03:00
rsync -arz -e "ssh -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null" --progress --delete --exclude '.git' . "$CI_USER"@ci-s390x.caddyserver.com:/var/tmp/"$short_sha"
ssh -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -t "$CI_USER"@ci-s390x.caddyserver.com "cd /var/tmp/$short_sha; go version; go env; printf "\n\n";CGO_ENABLED=0 go test -v ./..."
2020-06-12 20:11:46 +03:00
test_result=$?
# There's no need leaving the files around
2022-10-04 17:03:10 +03:00
ssh -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null "$CI_USER"@ci-s390x.caddyserver.com "rm -rf /var/tmp/'$short_sha'"
2020-06-12 20:11:46 +03:00
echo "Test exit code: $test_result"
exit $test_result
env :
SSH_KEY : ${{ secrets.S390X_SSH_KEY }}
2022-10-04 17:03:10 +03:00
CI_USER : ${{ secrets.CI_USER }}
2020-06-12 20:11:46 +03:00
2020-05-06 03:50:30 +03:00
goreleaser-check :
runs-on : ubuntu-latest
steps :
2023-04-15 04:38:33 +03:00
- name : Checkout code
2023-10-02 03:13:54 +03:00
uses : actions/checkout@v4
2021-08-25 20:30:24 +03:00
2023-10-02 03:34:43 +03:00
- uses : goreleaser/goreleaser-action@v5
2020-05-06 03:50:30 +03:00
with :
version : latest
args : check
env :
TAG : ${{ steps.vars.outputs.version_tag }}