1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-01-24 04:16:27 +02:00
goreleaser/docs/140-ci.md

66 lines
1.3 KiB
Markdown
Raw Normal View History

2017-09-10 17:07:28 -03:00
---
2017-12-20 11:32:21 +01:00
title: Continuous Integration
2017-09-10 17:07:28 -03:00
---
GoReleaser was built from the very first commit with the idea of
running it as part of the CI pipeline in mind.
Let's see how we can get it working on popular CI softwares.
## Travis
You may want to setup your project to auto-deploy your new tags on
2017-09-11 10:13:14 -03:00
[Travis](https://travis-ci.org), for example:
2017-09-10 17:07:28 -03:00
```yaml
# .travis.yml
language: go
addons:
apt:
packages:
2018-02-18 20:37:59 -03:00
# needed for the nfpm pipe:
- rpm
2018-02-18 20:37:59 -03:00
# needed for the snap pipe:
- snapcraft
env:
# needed for the snap pipe:
- PATH=/snap/bin:$PATH
install:
# needed for the snap pipe:
- sudo snap install snapcraft --classic
# needed for the docker pipe
services:
- docker
# calls goreleaser
deploy:
- provider: script
skip_cleanup: true
script: curl -sL http://git.io/goreleaser | bash
on:
tags: true
condition: $TRAVIS_OS_NAME = linux
2017-09-10 17:07:28 -03:00
```
Note the last line (`condition: $TRAVIS_OS_NAME = linux`): it is important
if you run a build matrix with multiple Go versions and/or multiple OSes. If
that's the case you will want to make sure GoReleaser is run just once.
# Circle
2017-09-10 17:07:28 -03:00
Here is how to do it with [CircleCI](https://circleci.com):
```yml
# circle.yml
deployment:
tag:
tag: /v[0-9]+(\.[0-9]+)*(-.*)*/
owner: user
commands:
- curl -sL https://git.io/goreleaser | bash
```