From 6e9d99d9565804f790f0e8f54d759a1a9c017663 Mon Sep 17 00:00:00 2001 From: Adam Ouellette Date: Wed, 27 Sep 2017 23:05:50 -0400 Subject: [PATCH] Create .travis.yml --- .travis.yml | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 .travis.yml diff --git a/.travis.yml b/.travis.yml new file mode 100644 index 0000000..c72552c --- /dev/null +++ b/.travis.yml @@ -0,0 +1,38 @@ +language: go + +go: + - 1.8 + - 1.9 + - tip + +# Skip the install step. Don't `go get` dependencies. Only build with the +# code in vendor/ +install: true + +matrix: + # It's ok if our code fails on unstable development versions of Go. + allow_failures: + - go: tip + # Don't wait for tip tests to finish. Mark the test run green if the + # tests pass on the stable versions of Go. + fast_finish: true + +# Don't email me the results of the test runs. +notifications: + email: true + +# Anything in before_script: that returns a nonzero exit code will +# flunk the build and immediately stop. It's sorta like having +# set -e enabled in bash. +before_script: + - GO_FILES=$(find . -iname '*.go' | grep -v /vendor/) # All the .go files, excluding vendor/ + - PKGS=$(go list ./... | grep -v /vendor/) # All the import paths, excluding vendor/ + - go get github.com/golang/lint/golint # Linter + +# script always run to completion (set +e). All of these code checks are must haves +# in a modern Go project. +script: + - test -z $(gofmt -s -l $GO_FILES) # Fail if a .go file hasn't been formatted with gofmt + - go test ./... -coverprofile=coverage.txt -covermode=atomic # Run all the tests with the race detector enabled + - go vet -v ./... # go vet is the official Go static analyzer + - golint -set_exit_status $PKGS # one last linter