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

137 lines
3.4 KiB
Markdown
Raw Normal View History

# 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-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!")
}
```
Run the [init](/cmd/goreleaser_init/) command to create an example `.goreleaser.yml` file:
2017-09-10 17:07:28 -03:00
```sh
goreleaser init
2018-07-21 10:33:59 -03:00
```
Now, lets run a "local-only" release to see if it works using the [release](/cmd/goreleaser_release/) command:
```sh
goreleaser release --snapshot --rm-dist
```
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.
You can verify your `.goreleaser.yml` is valid by running the [check](/cmd/goreleaser_check/) command:
2017-09-10 17:07:28 -03:00
```sh
goreleaser check
```
2017-09-10 17:07:28 -03: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
```sh
goreleaser build --single-target
```
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).
```sh
export GITHUB_TOKEN="YOUR_GH_TOKEN"
2017-09-10 17:07:28 -03: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
```sh
git tag -a v0.1.0 -m "First release"
git push origin v0.1.0
2017-09-10 17:07:28 -03:00
```
!!! info
Check if your tag adheres to [semantic versioning](/limitations/semver/).
2017-09-10 17:07:28 -03: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:
```sh
goreleaser release --snapshot
```
2017-09-10 17:07:28 -03:00
Now you can run GoReleaser at the root of your repository:
```sh
goreleaser release
2017-09-10 17:07:28 -03: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
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
use the following techniques.
### Build-only Mode
Build command will build the project
```sh
goreleaser build
```
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:
```sh
goreleaser build --help
```
### Release Flags
Use the `--skip-publish` flag to skip publishing:
2018-10-17 00:41:40 -03:00
```sh
goreleaser release --skip-publish
2018-10-17 00:41:40 -03:00
```
You can check the other options by running:
```sh
goreleaser --help
2018-10-17 00:41:40 -03:00
```
and
```sh
goreleaser release --help
2018-10-17 00:41:40 -03:00
```