1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-01-06 03:13:48 +02:00
Deliver Go binaries as fast and easily as possible https://goreleaser.com/
Go to file
Carlos Alexandro Becker 20800a3019 Merge pull request #78 from jorinvo/optionals
Optional config
2017-01-14 18:36:14 -02:00
clients github client factory 2017-01-14 14:50:50 -02:00
config even more improvements 2017-01-14 15:08:10 -02:00
context even more improvements 2017-01-14 15:08:10 -02:00
pipeline Fixing some linter errors 2017-01-14 19:41:32 +01:00
sha256sum fixed tests and linters 2017-01-11 14:08:29 -02:00
.editorconfig added replacements support 2017-01-11 19:24:17 -02:00
.gitignore wip ctx 2017-01-14 12:34:22 -02:00
.travis.yml removed debug line 2017-01-02 14:33:26 -02:00
CODE_OF_CONDUCT.md added code of conduct 2017-01-02 13:36:39 -02:00
CONTRIBUTING.md Update go version prerequisite 2017-01-02 18:16:15 +01:00
glide.lock improved main.go 2016-12-31 13:57:39 -02:00
glide.yaml improved main.go 2016-12-31 13:57:39 -02:00
goreleaser.yml homebrew-formulae -> homebrew-tap 2017-01-11 20:51:33 -02:00
LICENSE.md readme, license and shit 2016-12-28 22:55:23 -02:00
main.go Config file optional 2017-01-14 19:29:57 +01:00
Makefile tabs vs spaces 2017-01-11 14:55:16 -02:00
README.md Improved some phrasing in the README 2017-01-14 19:58:51 +01:00

GoReleaser

goreleaser

GoReleaser builds Go binaries for several platforms, creates a Github release and then pushes a Homebrew formulae to a repository. All that wrapped in your favorite CI.

This project adheres to the Contributor Covenant code of conduct. By participating, you are expected to uphold this code. Please report unacceptable behavior to root@carlosbecker.com.

Build Status Go Report Card Powered By: GoReleaser

How it works?

The idea started with a simple shell script, but it quickly became more complex and I also wanted to publish binaries via Homebrew.

So, the all-new goreleaser was born.

Usage

  • You need to export a GITHUB_TOKEN environment variable with the repo scope selected. You can create one here.

  • GoReleaser uses the latest Git tag of your repository, so you need to create a tag first.

  • Now you can run releaser at the root of your repository:

curl -s https://raw.githubusercontent.com/goreleaser/get/master/latest | bash

This will build main.go as binary, for Darwin and Linux (amd64 and i386), archive the binary and common files as .tar.gz, and finally, publish a new Github release in the repository with archives uploaded.

For further customization create a goreleaser.yml file in the root of your repository.

Homebrew

Add a brew section to push a formulae to a Homebrew tab repository:

brew:
  repo: user/homebrew-tap
  folder: optional/subfolder/inside/the/repo
  caveats: "Optional caveats to add to the formulae"

See the Homebrew docs for creating your own tap.

Build customization

Just add a build section

build:
  main: ./cmd/main.go
  ldflags: -s -w
  oses:
    - darwin
    - freebsd
  arches:
    - amd64
  • oses and arches should be in GOOS/GOARCH-compatible format.
  • -s -w is the default value for ldflags.

Archive customization

You can customize the name and format of the archive adding an archive section:

archive:
  name_template: "{{.BinaryName}}_{{.Version}}_{{.Os}}_{{.Arch}}"
  format: zip
  replacements:
    amd64: 64-bit
    386: 32-bit
    darwin: macOS
    linux: Tux
  • Default name_template is {{.BinaryName}}_{{.Os}}_{{.Arch}}
  • Valid formats are tar.gz and zip, default is tar.gz
  • By default, replacements replace GOOS with uname -s values and GOARCH with uname -m values. They keys should always be in the GOOS and GOARCH form.

Add more files

You might also want to change the files that are packaged by adding a files section:

files:
  - LICENSE.txt
  - README.md
  - CHANGELOG.md

By default GoReleaser adds the binary itself, LICENCE*, LICENSE*, README* and CHANGELOG*.

ldflags (main.version)

GoReleaser always sets a main.version ldflag. You can use it in your main.go file:

package main

var version = "master"

func main() {
  println(version)
}

And this version will always be the name of the current tag.

Other customizations

  • By default it's assumed that the repository to release to is the same as the Git remote origin. If this is not the case for your project, you can specify a repo:
repo: owner/custom-repo
  • By default the binary name is the name of the project directory. You can specify a different binary_name:
binary_name: my-binary

Wire it with Travis CI

You may want to wire this to auto-deploy your new tags on Travis, for example:

after_success:
  test -n "$TRAVIS_TAG" && curl -s https://raw.githubusercontent.com/goreleaser/get/master/latest | bash

What the end result looks like

The release on Github looks pretty much like this:

image

And the Homebrew formulae would look like:

class Release < Formula
  desc "Deliver Go binaries as fast and easily as possible"
  homepage "https://github.com/goreleaser/releaser"
  url "https://github.com/goreleaser/releaser/releases/download/v0.2.8/release_Darwin_x86_64.tar.gz"
  version "v0.2.8"
  sha256 "9ee30fc358fae8d248a2d7538957089885da321dca3f09e3296fe2058e7fff74"

  def install
    bin.install "release"
  end
end

How to contribute

Please refer to our contributing guidelines.

Badges

Feel free to use it in your own projects:

[![Powered By: GoReleaser](https://img.shields.io/badge/powered%20by-goreleaser-green.svg?style=flat-square)](https://github.com/goreleaser)