2020-05-10 16:57:11 -03:00
# Quick Start
2017-09-10 17:07:28 -03:00
2019-03-24 20:10:30 -03:00
In this example we will build, archive and release a sample Go project.
2017-10-01 18:57:52 +02:00
2017-09-10 17:07:28 -03:00
Create a GitHub repository and add a single main package:
```go
// main.go
package main
func main() {
println("Ba dum, tss!")
}
```
2021-07-10 17:11:37 +00:00
Run the [init ](/cmd/goreleaser_init/ ) command to create an example `.goreleaser.yml` file:
2017-09-10 17:07:28 -03:00
2020-08-14 18:13:02 -03:00
```sh
goreleaser init
2018-07-21 10:33:59 -03:00
```
2017-10-01 18:57:52 +02:00
2021-07-10 17:11:37 +00:00
Now, lets run a "local-only" release to see if it works using the [release ](/cmd/goreleaser_release/ ) command:
2019-02-06 17:14:38 +00:00
2020-08-14 18:13:02 -03:00
```sh
2021-07-10 17:11:37 +00:00
goreleaser release --snapshot --skip-publish --rm-dist
2019-02-06 17:14:38 +00:00
```
2021-07-10 17:11:37 +00:00
At this point, you can [customize ](/customization/ ) the generated `.goreleaser.yml` or leave it as-is, it's up to you.
It is best practice to check `.goreleaser.yml` into the source control.
2019-02-06 17:14:38 +00:00
2021-07-10 17:11:37 +00:00
You can verify your `.goreleaser.yml` is valid by running the [check ](/cmd/goreleaser_check/ ) command:
2017-09-10 17:07:28 -03:00
2021-07-10 17:11:37 +00:00
```sh
goreleaser check
```
2017-09-10 17:07:28 -03:00
2021-07-10 17:11:37 +00:00
You can also use GoReleaser to [build ](cmd/goreleaser_build/ ) the binary only for a given GOOS/GOARCH, which is useful for local development:
2017-09-10 17:07:28 -03:00
2020-08-14 18:13:02 -03:00
```sh
2021-07-10 17:11:37 +00:00
goreleaser build --single-target
2020-08-14 18:13:02 -03:00
```
2021-07-10 17:11:37 +00:00
In order to release to GitHub, 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 new github token [here ](https://github.com/settings/tokens/new ).
2020-08-14 18:13:02 -03:00
```sh
2021-07-10 17:11:37 +00:00
export GITHUB_TOKEN="YOUR_GH_TOKEN"
2017-09-10 17:07:28 -03:00
```
2021-07-10 17:11:37 +00:00
GoReleaser will use the latest [Git tag ](https://git-scm.com/book/en/v2/Git-Basics-Tagging ) of your repository.
Now, create a tag and push it to GitHub:
2017-09-10 17:07:28 -03:00
2020-08-14 18:13:02 -03:00
```sh
git tag -a v0.1.0 -m "First release"
git push origin v0.1.0
2017-09-10 17:07:28 -03:00
```
2020-05-10 16:57:11 -03:00
!!! info
2021-06-21 02:13:49 +00:00
Check if your tag adheres to [semantic versioning ](/limitations/semver/ ).
2017-09-10 17:07:28 -03:00
2021-07-10 17:11:37 +00:00
!!! info
If you don't want to create a tag yet, you can also run GoReleaser without publishing based on the latest commit by using the `--snapshot` flag:
2020-02-20 13:39:42 -05:00
2021-07-10 17:11:37 +00:00
```sh
goreleaser release --snapshot
```
2017-09-10 17:07:28 -03:00
Now you can run GoReleaser at the root of your repository:
2020-08-14 18:13:02 -03:00
```sh
2021-01-21 01:04:16 -03:00
goreleaser release
2017-09-10 17:07:28 -03:00
```
2021-07-10 17:11:37 +00:00
That's all it takes!
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 `builds` section. Check the [documentation ](/customization/build/ ) for more information.
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 ](/customization/archive/ ) for more information.
Finally, it will create a release on GitHub with all the artifacts.
2017-09-10 17:07:28 -03:00
2021-01-21 00:54:12 -03:00
Check your GitHub project's releases page!
< a href = "https://github.com/goreleaser/example/releases" >
< figure >
< img src = "https://img.carlosbecker.dev/goreleaser-github.png" / >
< figcaption > Example release on GitHub.< / figcaption >
< / figure >
2017-09-10 17:07:28 -03:00
< / a >
2018-10-17 00:41:40 -03:00
## Dry run
If you want to test everything before doing a release "for real", you can
2020-05-15 15:19:20 +01:00
use the following techniques.
### Build-only Mode
Build command will build the project
2020-08-14 18:13:02 -03:00
```sh
goreleaser build
2020-05-15 15:19:20 +01:00
```
This can be useful as part of CI pipelines to verify the project builds
without errors for all build targets.
You can check the other options by running:
2020-08-14 18:13:02 -03:00
```sh
goreleaser build --help
2020-05-15 15:19:20 +01:00
```
### Release Flags
Use the `--skip-publish` flag to skip publishing:
2018-10-17 00:41:40 -03:00
2020-08-14 18:13:02 -03:00
```sh
goreleaser release --skip-publish
2018-10-17 00:41:40 -03:00
```
You can check the other options by running:
2020-08-14 18:13:02 -03:00
```sh
goreleaser --help
2018-10-17 00:41:40 -03:00
```
and
2020-08-14 18:13:02 -03:00
```sh
goreleaser release --help
2018-10-17 00:41:40 -03:00
```