mirror of
https://github.com/goreleaser/goreleaser.git
synced 2025-01-26 04:22:05 +02:00
docs: improve docs
This commit is contained in:
parent
7c41d888f5
commit
367c6c0d1d
@ -36,7 +36,7 @@ deploy:
|
||||
verbose: true
|
||||
fqdn: goreleaser.com
|
||||
on:
|
||||
tags: true
|
||||
master: true
|
||||
- provider: script
|
||||
skip_cleanup: true
|
||||
script: ./goreleaser
|
||||
|
@ -24,13 +24,13 @@ $ git clone git@github.com:goreleaser/goreleaser.git
|
||||
|
||||
Install the build and lint dependencies:
|
||||
|
||||
```console
|
||||
```sh
|
||||
$ make setup
|
||||
```
|
||||
|
||||
A good way of making sure everything is all right is running the test suite:
|
||||
|
||||
```console
|
||||
```sh
|
||||
$ make test
|
||||
```
|
||||
|
||||
@ -38,13 +38,13 @@ $ make test
|
||||
|
||||
You can create a branch for your changes and try to build from the source as you go:
|
||||
|
||||
```console
|
||||
```sh
|
||||
$ make build
|
||||
```
|
||||
|
||||
When you are satisfied with the changes, we suggest you run:
|
||||
|
||||
```console
|
||||
```sh
|
||||
$ make ci
|
||||
```
|
||||
|
||||
|
@ -8,4 +8,5 @@ pygmentsCodeFences = true
|
||||
pygmentsStyle = "dracula"
|
||||
|
||||
[params]
|
||||
logo = "https://avatars2.githubusercontent.com/u/24697112?v=3&s=140"
|
||||
logo = "https://github.com/goreleaser.png"
|
||||
ghdocsrepo = "https://github.com/goreleaser/goreleaser/edit/master/www"
|
||||
|
@ -52,8 +52,8 @@ Supported variables:
|
||||
- Arch
|
||||
- Arm
|
||||
|
||||
_Attention_: Variables _Os_, _Arch_ and _Arm_ are only supported in upload
|
||||
mode `binary`.
|
||||
> **Attention**: Variables _Os_, _Arch_ and _Arm_ are only supported in upload
|
||||
> mode `binary`.
|
||||
|
||||
### Username
|
||||
|
||||
|
@ -108,7 +108,7 @@ builds:
|
||||
|
||||
Then you can run:
|
||||
|
||||
```console
|
||||
```sh
|
||||
GOVERSION=$(go version) goreleaser
|
||||
```
|
||||
|
||||
|
@ -159,26 +159,26 @@ changelog containing just the messages from the commits since the prior tag.
|
||||
|
||||
```yml
|
||||
steps:
|
||||
~ # Setup the workspace so we have a viable place to point GOPATH at.
|
||||
~ - name: gcr.io/cloud-builders/go
|
||||
~ env: ['PROJECT_ROOT=github.com/YourGithubUser/YourGithubRepo']
|
||||
~_ args: ['env']
|
||||
# Setup the workspace so we have a viable place to point GOPATH at.
|
||||
- name: gcr.io/cloud-builders/go
|
||||
env: ['PROJECT_ROOT=github.com/YourGithubUser/YourGithubRepo']
|
||||
args: ['env']
|
||||
|
||||
~ # Create github release.
|
||||
~ - name: goreleaser/goreleaser
|
||||
~ entrypoint: /bin/sh
|
||||
~ dir: gopath/src/github.com
|
||||
~ env: ['GOPATH=/workspace/gopath']
|
||||
~ args: ['-c', 'cd YourGithubUser/YourGithubRepo && git tag $TAG_NAME && /goreleaser' ]
|
||||
~_ secretEnv: ['GITHUB_TOKEN']
|
||||
# Create github release.
|
||||
- name: goreleaser/goreleaser
|
||||
entrypoint: /bin/sh
|
||||
dir: gopath/src/github.com
|
||||
env: ['GOPATH=/workspace/gopath']
|
||||
args: ['-c', 'cd YourGithubUser/YourGithubRepo && git tag $TAG_NAME && /goreleaser' ]
|
||||
secretEnv: ['GITHUB_TOKEN']
|
||||
|
||||
secrets:
|
||||
~ - kmsKeyName: projects/YourProjectId/locations/global/keyRings/YourKeyRing/cryptoKeys/YourKey
|
||||
~ secretEnv:
|
||||
~ GITHUB_TOKEN: |
|
||||
~ ICAgICAgICBDaVFBZUhVdUVoRUtBdmZJSGxVWnJDZ0hOU2NtMG1ES0k4WjF3L04zT3pEazhRbDZr
|
||||
~ QVVTVVFEM3dVYXU3cVJjK0g3T25UVW82YjJaCiAgICAgICAgREtBMWVNS0hOZzcyOUtmSGoyWk1x
|
||||
~_ ICAgICAgIEgwYndIaGUxR1E9PQo=
|
||||
- kmsKeyName: projects/YourProjectId/locations/global/keyRings/YourKeyRing/cryptoKeys/YourKey
|
||||
secretEnv:
|
||||
GITHUB_TOKEN: |
|
||||
ICAgICAgICBDaVFBZUhVdUVoRUtBdmZJSGxVWnJDZ0hOU2NtMG1ES0k4WjF3L04zT3pEazhRbDZr
|
||||
QVVTVVFEM3dVYXU3cVJjK0g3T25UVW82YjJaCiAgICAgICAgREtBMWVNS0hOZzcyOUtmSGoyWk1x
|
||||
ICAgICAgIEgwYndIaGUxR1E9PQo=
|
||||
|
||||
```
|
||||
|
||||
|
@ -2,7 +2,7 @@
|
||||
title: Environment Variables
|
||||
series: customization
|
||||
hideFromIndex: true
|
||||
weight: 30
|
||||
weight: 19
|
||||
---
|
||||
|
||||
Global environment variables to be passed down to all hooks and builds.
|
||||
|
@ -4,11 +4,14 @@ weight: 2
|
||||
menu: true
|
||||
---
|
||||
|
||||
You can install the pre-compiled binary, use Docker or compile from source.
|
||||
You can install the pre-compiled binary (in several different ways),
|
||||
use Docker or compile from source.
|
||||
|
||||
Here are the steps for each of them:
|
||||
|
||||
## Install the pre-compiled binary
|
||||
|
||||
**homebrew tap**:
|
||||
**homebrew tap** (only on macOS for now):
|
||||
|
||||
```sh
|
||||
$ brew install goreleaser/tap/goreleaser
|
||||
@ -45,8 +48,8 @@ copy to the desired location.
|
||||
|
||||
## Running with Docker
|
||||
|
||||
You can use Docker to do simple releases. Currently, the provided docker
|
||||
image does not provide support for snapcraft.
|
||||
You can also use it within a Docker container. To do that, you'll need to
|
||||
execute something more-or-less like the following:
|
||||
|
||||
```sh
|
||||
$ docker run --rm --privileged \
|
||||
@ -60,33 +63,21 @@ $ docker run --rm --privileged \
|
||||
goreleaser/goreleaser release
|
||||
```
|
||||
|
||||
> **ATTENTION**: Currently, the provided docker image does not support
|
||||
> the generation of snapcraft packages.
|
||||
|
||||
Note that the image will almost always have the last stable Go version.
|
||||
|
||||
The `DOCKER_REGISTRY` environment variables can be left empty when you are
|
||||
The `DOCKER_REGISTRY` environment variable can be left empty when you are
|
||||
releasing to the public docker registry.
|
||||
|
||||
If you need more things, you are encouraged to have your own image. You can
|
||||
always use GoReleaser's [own Dockerfile][dockerfile] as an example though.
|
||||
If you need more things, you are encouraged to keep your own image. You can
|
||||
always use GoReleaser's [own Dockerfile][dockerfile] as an example though
|
||||
and iterate from that.
|
||||
|
||||
[dockerfile]: https://github.com/goreleaser/goreleaser/blob/master/Dockerfile
|
||||
[releases]: https://github.com/goreleaser/goreleaser/releases
|
||||
|
||||
## Compiling from source
|
||||
|
||||
> **Note**: this method requires Go 1.11+.
|
||||
|
||||
```sh
|
||||
$ git clone git@github.com:goreleaser/goreleaser.git
|
||||
$ cd goreleaser
|
||||
$ make setup build
|
||||
```
|
||||
|
||||
After that, the `goreleaser` binary will be in the root folder:
|
||||
|
||||
```sh
|
||||
$ ./goreleaser --help
|
||||
```
|
||||
|
||||
For more information, check the [contributing guide][contrib].
|
||||
|
||||
[contrib]: /contributing
|
||||
Please follow the relevant steps on our [contributing guide](/contributing).
|
||||
|
@ -5,19 +5,12 @@ menu: true
|
||||
---
|
||||
|
||||
[GoReleaser](https://github.com/goreleaser/goreleaser) is a release automation
|
||||
tool for Go projects, the goal is to simplify the build, release and
|
||||
tool for Go projects. The goal is to simplify the build, release and
|
||||
publish steps while providing variant customization options for all steps.
|
||||
|
||||
GoReleaser is built for CI tools; you only need to
|
||||
[download and execute it](/ci) in your build script. Of course, you can
|
||||
also [install it locally](/install).
|
||||
|
||||
You can [customize](/customization) your release process by
|
||||
creating a `.goreleaser.yml` file.
|
||||
|
||||
The idea started with a
|
||||
[simple shell script](https://github.com/goreleaser/old-go-releaser),
|
||||
but it quickly became more complex and I also wanted to publish binaries via
|
||||
Homebrew taps, which would have made the script even more "hacky", so I let
|
||||
go of that and rewrote the whole thing in Go.
|
||||
[download and execute it](/ci) in your build script.
|
||||
Of course, you can also [install it locally](/install) if you wish.
|
||||
|
||||
You can also [customize](/customization) your release process through a
|
||||
`.goreleaser.yml` file.
|
||||
|
@ -4,7 +4,7 @@ weight: 10
|
||||
menu: true
|
||||
---
|
||||
|
||||
In this example we will build, archive and release a Go project.
|
||||
In this example we will build, archive and release a sample Go project.
|
||||
|
||||
Create a GitHub repository and add a single main package:
|
||||
|
||||
@ -19,47 +19,27 @@ func main() {
|
||||
|
||||
Run `goreleaser init` to create an example `.goreleaser.yaml` file:
|
||||
|
||||
```console
|
||||
```sh
|
||||
$ goreleaser init
|
||||
|
||||
• Generating .goreleaser.yml file
|
||||
• config created; please edit accordingly to your needs file=.goreleaser.yml
|
||||
```
|
||||
|
||||
The generated config file will look like this:
|
||||
You can [customize](/customization) the generated `.goreleaser.yml` or leave
|
||||
it as-is, it's up to you.
|
||||
|
||||
```yml
|
||||
# This is an example goreleaser.yaml file with some sane defaults.
|
||||
# Make sure to check the documentation at http://goreleaser.com
|
||||
builds:
|
||||
- env:
|
||||
- CGO_ENABLED=0
|
||||
archive:
|
||||
replacements:
|
||||
darwin: Darwin
|
||||
linux: Linux
|
||||
windows: Windows
|
||||
386: i386
|
||||
amd64: x86_64
|
||||
checksum:
|
||||
name_template: 'checksums.txt'
|
||||
snapshot:
|
||||
name_template: "{{ .Tag }}-next"
|
||||
changelog:
|
||||
sort: asc
|
||||
filters:
|
||||
exclude:
|
||||
- '^docs:'
|
||||
- '^test:'
|
||||
```
|
||||
You can test the configuration at any time by running GoReleaser with a few
|
||||
extra parameters to not require a version tag, skip publishing to GitHub,
|
||||
and remove any already-built files:
|
||||
|
||||
You can test this initial configuration by running GoReleaser with a few extra parameters to not require a version tag, skip publishing to GitHub, and remove any already-built files:
|
||||
|
||||
```
|
||||
```sh
|
||||
$ goreleaser --snapshot --skip-publish --rm-dist
|
||||
```
|
||||
|
||||
If you are not using vgo or Go modules, then you will need to comment out the before hooks in the generated config file. Or update them to match your setup accordingly.
|
||||
If you are not using vgo or Go modules, then you will need to comment out the
|
||||
before hooks in the generated config file or update them to match your setup
|
||||
accordingly.
|
||||
|
||||
GoReleaser will build the binaries for your app for Windows, Linux and macOS,
|
||||
both amd64 and i386 architectures. You can customize that by changing the
|
||||
@ -67,15 +47,15 @@ both amd64 and i386 architectures. You can customize that by changing the
|
||||
|
||||
After building the binaries, GoReleaser will create an archive for each OS/Arch
|
||||
pair into a separate file. You can customize several things by changing
|
||||
the `archive` section, including releasing only the binaries and not creating archives at all.
|
||||
Check the [documentation](/archive) for more information.
|
||||
the `archive` section, including releasing only the binaries and not creating
|
||||
archives at all. Check the [documentation](/archive) for more information.
|
||||
|
||||
You'll need to export a `GITHUB_TOKEN` environment variable, which should
|
||||
contain a valid GitHub token with the `repo` scope.
|
||||
It will be used to deploy releases to your GitHub repository.
|
||||
You can create a token [here](https://github.com/settings/tokens/new).
|
||||
|
||||
```console
|
||||
```sh
|
||||
$ export GITHUB_TOKEN=`YOUR_TOKEN`
|
||||
```
|
||||
|
||||
@ -83,7 +63,7 @@ GoReleaser will use the latest
|
||||
[Git tag](https://git-scm.com/book/en/v2/Git-Basics-Tagging) of your repository.
|
||||
Create a tag and push it to GitHub:
|
||||
|
||||
```console
|
||||
```sh
|
||||
$ git tag -a v0.1.0 -m "First release"
|
||||
$ git push origin v0.1.0
|
||||
```
|
||||
@ -95,7 +75,7 @@ based on the latest commit by using the `--snapshot` flag.
|
||||
|
||||
Now you can run GoReleaser at the root of your repository:
|
||||
|
||||
```console
|
||||
```sh
|
||||
$ goreleaser
|
||||
```
|
||||
|
||||
@ -112,18 +92,18 @@ The release should look like this:
|
||||
If you want to test everything before doing a release "for real", you can
|
||||
use the `--skip-publish` flag, which will only build and package things:
|
||||
|
||||
```console
|
||||
```sh
|
||||
$ goreleaser release --skip-publish
|
||||
```
|
||||
|
||||
You can check the other options by running:
|
||||
|
||||
```console
|
||||
```sh
|
||||
$ goreleaser --help
|
||||
```
|
||||
|
||||
and
|
||||
|
||||
```console
|
||||
```sh
|
||||
$ goreleaser release --help
|
||||
```
|
||||
|
@ -78,7 +78,7 @@ On Unix systems you can also generate the release notes in-line by using
|
||||
To list all commits since the last tag, but skip ones starting with `Merge` or
|
||||
`docs`, you could run this command:
|
||||
|
||||
```console
|
||||
```sh
|
||||
$ goreleaser --release-notes <(some_changelog_generator)
|
||||
```
|
||||
|
||||
@ -86,6 +86,6 @@ Some changelog generators you can use:
|
||||
|
||||
- [buchanae/github-release-notes](https://github.com/buchanae/github-release-notes)
|
||||
|
||||
**Important**: If you create the release before running GoReleaser, and the
|
||||
said release has some text in its body, GoReleaser will not override it with
|
||||
it's release notes.
|
||||
> **Important**: If you create the release before running GoReleaser, and the
|
||||
> said release has some text in its body, GoReleaser will not override it with
|
||||
> it's release notes.
|
||||
|
@ -14,6 +14,8 @@ object storages ([minio][] for example).
|
||||
Right now, the implementation is quite simple and probably won't cover all
|
||||
use cases. If you need one of such use cases, please open an issue/pull request.
|
||||
|
||||
Here is what you can customize:
|
||||
|
||||
## Customization
|
||||
|
||||
```yaml
|
||||
@ -54,21 +56,17 @@ You can read the [docs][auth] to find out more about it.
|
||||
|
||||
Currently it supports authentication with:
|
||||
|
||||
* A [EnvProvider][EnvProvider] which retrieves credentials from the environment variables of the
|
||||
running process. Environment credentials never expire.
|
||||
Environment variables used:
|
||||
|
||||
* Access Key ID: AWS_ACCESS_KEY_ID or AWS_ACCESS_KEY
|
||||
|
||||
* Secret Access Key: AWS_SECRET_ACCESS_KEY or AWS_SECRET_KEY
|
||||
|
||||
* A [SharedCredentialsProvider][SharedCredentialsProvider] which retrieves credentials from the current user's home
|
||||
directory, and keeps track if those credentials are expired.
|
||||
|
||||
Profile ini file example: $HOME/.aws/credentials
|
||||
|
||||
* A AssumeRoleTokenProvider with enabled SharedConfigState which uses MFA prompting for token code on stdin.
|
||||
Go to [session doc][session] for more details.
|
||||
- An [EnvProvider][EnvProvider] which retrieves credentials from the environment
|
||||
variables of the running process. Environment credentials never expire.
|
||||
Environment variables used:
|
||||
- Access Key ID: `AWS_ACCESS_KEY_ID` or `AWS_ACCESS_KEY`
|
||||
- Secret Access Key: `AWS_SECRET_ACCESS_KEY` or `AWS_SECRET_KEY`
|
||||
- A [SharedCredentialsProvider][SharedCredentialsProvider] which retrieves
|
||||
credentials from the current user's home directory, and keeps track if those
|
||||
credentials are expired. Profile ini file example: `$HOME/.aws/credentials`
|
||||
- A AssumeRoleTokenProvider with enabled SharedConfigState which uses MFA
|
||||
prompting for token code on stdin. Go to [session doc][session] for more
|
||||
details.
|
||||
|
||||
You can also set different profile names for each S3 config, so you may be able
|
||||
to push to buckets in different accounts, for example.
|
||||
|
@ -61,7 +61,7 @@ foo_template: 'foo_{{ .Env.GOVERSION }}'
|
||||
|
||||
And then you can run:
|
||||
|
||||
```console
|
||||
```sh
|
||||
GOVERSION_NR=$(go version | awk '{print $3;}') goreleaser
|
||||
```
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
---
|
||||
title: Tutorials
|
||||
title: Tutorials and posts
|
||||
menu: true
|
||||
weight: 998
|
||||
---
|
||||
@ -7,10 +7,11 @@ weight: 998
|
||||
Tutorials made by the community.
|
||||
|
||||
<!-- please, keep A-Z sorting -->
|
||||
- [Creating debs and rpms with Go](https://carlosbecker.com/posts/nfpm/)
|
||||
- [Fast and easy Go binaries delivery](https://carlosbecker.com/posts/goreleaser/)
|
||||
- [GoReleaser Docker Support](https://carlosbecker.com/posts/goreleaser-docker/)
|
||||
- [GoReleaser: build and push Snapcraft packages from TravisCI](https://carlosbecker.com/posts/goreleaser-snap-travis/)
|
||||
- [Shipping Rust Binaries with GoReleaser](https://medium.com/@jondot/shipping-rust-binaries-with-goreleaser-d5aa42a46be0)
|
||||
|
||||
Want to add your tutorial here? Please do! Edit [this file][tutorials] and open
|
||||
a Pull Request! Thanks!
|
||||
|
||||
[tutorials]: https://github.com/goreleaser/goreleaser/blob/master/www/content/tutorials.md
|
||||
Want to add your tutorial here? Please do! Click on the `improve this page`
|
||||
link bellow!
|
||||
|
Binary file not shown.
Before Width: | Height: | Size: 12 KiB After Width: | Height: | Size: 12 KiB |
@ -1 +1 @@
|
||||
Subproject commit 7a952e65f3dcdc1023f35a7faf83b7b70de4631a
|
||||
Subproject commit 14c2f44baa62efc725c2b874f218420909fb2792
|
Loading…
x
Reference in New Issue
Block a user