2019-06-12 13:12:00 +02:00

1.6 KiB

Development, Testing and Contributing

  1. Make sure you have a running Docker daemon (Install for MacOS)
  2. Use a version of Go that supports modules (e.g. Go 1.11+)
  3. Fork this repo and git clone somewhere to $GOPATH/src/github.com/golang-migrate/migrate
    • Ensure that Go modules are enabled (e.g. your repo path or the GO111MODULE environment variable are set correctly)
  4. Install golangci-lint
  5. Run the linter: golangci-lint run
  6. Confirm tests are working: make test-short
  7. Write awesome code ...
  8. make test to run all tests against all database versions
  9. Push code and open Pull Request

Some more helpful commands:

  • You can specify which database/ source tests to run: make test-short SOURCE='file go_bindata' DATABASE='postgres cassandra'
  • After make test, run make html-coverage which opens a shiny test coverage overview.
  • make build-cli builds the CLI in directory cli/build/.
  • make list-external-deps lists all external dependencies for each package
  • make docs && make open-docs opens godoc in your browser, make kill-docs kills the godoc server. Repeatedly call make docs to refresh the server.
  • Set the DOCKER_API_VERSION environment variable to the latest supported version if you get errors regarding the docker client API version being too new.