mirror of
https://github.com/goreleaser/goreleaser.git
synced 2025-01-26 04:22:05 +02:00
a209757ad2
with this patch, a config like: ```yaml archives: - format: tar.gz # this name template makes the OS and Arch compatible with the results of uname. name_template: >- {{ .ProjectName }}_ {{- title .Os }}_ {{- if eq .Arch "amd64" }}x86_64 {{- else if eq .Arch "386" }}i386 {{- else }}{{ .Arch }}{{ end }} {{- if .Arm }}v{{ .Arm }}{{ end }} rlcp: true files: - src: "build/**/*" dst: . nfpms: - package_name: foo contents: - src: "build/**/*" dst: usr/share/foo formats: - apk ``` will eval this: <img width="1384" alt="CleanShot 2022-12-21 at 22 21 00@2x" src="https://user-images.githubusercontent.com/245435/209034244-7c31b5f7-cfcd-4825-bb2f-7dd463c5286a.png"> as much as I would like to make this the default, it would be a breaking change, so we really can't do it. If `dst` is empty, it'll have the same behavior as before (no rlcp), and if `strip_parent` is set, it will also still have the same behavior. Finally, if the format is binary, `rlcp` is ignored too (as it doesn't make sense). So, this only changes if: - your format is not binary; and - you have files with `src` and `dst` set Then, goreleaser will warn you to set `rlcp: true`. ## todo - [x] docs - [x] more tests probably - [x] any ideas for a better name for the new config option? fixes #3655 Signed-off-by: Carlos A Becker <caarlos0@users.noreply.github.com>
969 lines
18 KiB
Markdown
969 lines
18 KiB
Markdown
# Deprecation notices
|
|
|
|
This page is used to list deprecation notices across GoReleaser.
|
|
|
|
Deprecated options will be removed after ~6 months from the time they were
|
|
deprecated.
|
|
|
|
You can check your use of deprecated configurations by running:
|
|
|
|
```sh
|
|
goreleaser check
|
|
```
|
|
|
|
## Active deprecation notices
|
|
|
|
<!--
|
|
|
|
Template for new deprecations:
|
|
|
|
### property
|
|
|
|
> since yyyy-mm-dd
|
|
|
|
Description.
|
|
|
|
=== "Before"
|
|
|
|
``` yaml
|
|
foo: bar
|
|
```
|
|
|
|
=== "After"
|
|
``` yaml
|
|
foo: bar
|
|
```
|
|
|
|
-->
|
|
|
|
|
|
### archives.rlcp
|
|
|
|
> since 2022-12-23 (v1.14.0)
|
|
|
|
This is not so much a deprecation property (yet), as it is a default behavior
|
|
change.
|
|
|
|
The usage of relative longest common path (`rlcp`) on the destination side of
|
|
archive files will be enabled by default by June 2023. Then, this option will be
|
|
deprecated, and you will have another 6 months (until December 2023) to remove
|
|
it.
|
|
|
|
For now, if you want to keep the old behavior, no action is required, but it
|
|
would be nice to have your opinion [here][rlcp-discuss].
|
|
|
|
[rlcp-discuss]: https://github.com/goreleaser/goreleaser/discussions/3659
|
|
|
|
If you want to make sure your releases will keep working properly, you can
|
|
enable this option and test it out with
|
|
`goreleaser release --snapshot --rm-dist`.
|
|
|
|
=== "After"
|
|
``` yaml
|
|
archives:
|
|
-
|
|
rlcp: true
|
|
```
|
|
|
|
### source.rlcp
|
|
|
|
> since 2022-12-23 (v1.14.0)
|
|
|
|
Same as [`archives.rlcp`](#archivesrlcp).
|
|
|
|
=== "After"
|
|
``` yaml
|
|
source:
|
|
rlcp: true
|
|
```
|
|
|
|
### archives.replacements
|
|
|
|
> since 2022-11-24 (v1.14.0)
|
|
|
|
The `replacements` will be removed soon from the archives section, as it was
|
|
never handled correctly when multiple archives were being used, and it also
|
|
causes confusion in other places.
|
|
|
|
You can still get the same features by abusing the `name_template` property.
|
|
|
|
=== "Before"
|
|
|
|
``` yaml
|
|
archives:
|
|
- id: foo
|
|
name_template: '{{ .ProjectName }}_{{ .Os }}_{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}'
|
|
replacements:
|
|
darwin: Darwin
|
|
linux: Linux
|
|
windows: Windows
|
|
386: i386
|
|
amd64: x86_64
|
|
```
|
|
|
|
=== "After"
|
|
``` yaml
|
|
archives:
|
|
- id: foo
|
|
name_template: >-
|
|
{{ .ProjectName }}_
|
|
{{- title .Os }}_
|
|
{{- if eq .Arch "amd64" }}x86_64
|
|
{{- else if eq .Arch "386" }}i386
|
|
{{- else }}{{ .Arch }}{{ end }}
|
|
```
|
|
|
|
Those two configurations will yield the same results.
|
|
|
|
|
|
### nfpms.replacements
|
|
|
|
> since 2022-11-24 (v1.14.0)
|
|
|
|
The `replacements` will be removed soon from the nFPMs section.
|
|
|
|
You can still get the same features by abusing the `file_name_template` property.
|
|
|
|
=== "Before"
|
|
|
|
``` yaml
|
|
nfpms:
|
|
- id: foo
|
|
file_name_template: '{{ .ProjectName }}_{{ .Os }}_{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}'
|
|
replacements:
|
|
darwin: Darwin
|
|
linux: Linux
|
|
windows: Windows
|
|
386: i386
|
|
amd64: x86_64
|
|
```
|
|
|
|
=== "After"
|
|
``` yaml
|
|
nfpms:
|
|
- id: foo
|
|
file_name_template: >-
|
|
{{ .ProjectName }}_
|
|
{{- title .Os }}_
|
|
{{- if eq .Arch "amd64" }}x86_64
|
|
{{- else if eq .Arch "386" }}i386
|
|
{{- else }}{{ .Arch }}{{ end }}
|
|
```
|
|
|
|
Those two configurations will yield the same results.
|
|
|
|
Generally speaking, is probably best to use `{{ .ConventionalFileName }}`
|
|
instead of custom templates.
|
|
|
|
### snapcrafts.replacements
|
|
|
|
> since 2022-11-24 (v1.14.0)
|
|
|
|
The `replacements` will be removed soon from the Snapcrafts section.
|
|
|
|
You can still get the same features by abusing the `name_template` property.
|
|
|
|
=== "Before"
|
|
|
|
``` yaml
|
|
snapcrafts:
|
|
- id: foo
|
|
name_template: '{{ .ProjectName }}_{{ .Os }}_{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}'
|
|
replacements:
|
|
darwin: Darwin
|
|
linux: Linux
|
|
windows: Windows
|
|
386: i386
|
|
amd64: x86_64
|
|
```
|
|
|
|
=== "After"
|
|
``` yaml
|
|
snapcrafts:
|
|
- id: foo
|
|
name_template: >-
|
|
{{ .ProjectName }}_
|
|
{{- title .Os }}_
|
|
{{- if eq .Arch "amd64" }}x86_64
|
|
{{- else if eq .Arch "386" }}i386
|
|
{{- else }}{{ .Arch }}{{ end }}
|
|
```
|
|
|
|
Those two configurations will yield the same results.
|
|
|
|
Generally speaking, is probably best to use `{{ .ConventionalFileName }}`
|
|
instead of custom templates.
|
|
|
|
|
|
|
|
### nfpms.maintainer
|
|
|
|
> since 2022-05-07 (v1.9.0)
|
|
|
|
nFPM will soon make mandatory setting the maintainer field.
|
|
|
|
=== "Before"
|
|
```yaml
|
|
nfpms:
|
|
- maintainer: ''
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
nfpms:
|
|
- maintainer: 'Name <email>'
|
|
```
|
|
|
|
### variables
|
|
|
|
> since 2022-01-20 (v1.4.0)
|
|
|
|
On [GoReleaser PRO](/pro/) custom variables should now be prefixed with `.Var`.
|
|
|
|
=== "Before"
|
|
|
|
``` yaml
|
|
variables:
|
|
foo: bar
|
|
some_template: 'lala-{{ .foo }}'
|
|
```
|
|
|
|
=== "After"
|
|
|
|
``` yaml
|
|
variables:
|
|
foo: bar
|
|
some_template: 'lala-{{ .Var.foo }}'
|
|
```
|
|
|
|
## Expired deprecation notices
|
|
|
|
The following options were deprecated in the past and were already removed.
|
|
|
|
### dockers.use: buildpacks
|
|
|
|
> since 2022-03-16 (v1.7.0), removed 2022-09-28 (v1.12.0)
|
|
|
|
This was removed due to some issues:
|
|
|
|
- The binary gets rebuild again during the buildpacks build;
|
|
- There is no ARM support.
|
|
|
|
### rigs
|
|
|
|
> since 2022-03-21 (v1.8.0), removed 2022-08-16 (v1.11.0)
|
|
|
|
GoFish was deprecated by their authors, therefore, we're removing its
|
|
support from GoReleaser too.
|
|
|
|
### nfpms.empty_folders
|
|
|
|
> since 2021-11-14 (v1.0.0), removed 2022-06-14 (v1.10.0)
|
|
|
|
nFPM empty folders is now deprecated in favor of a `dir` content type:
|
|
|
|
=== "Before"
|
|
|
|
``` yaml
|
|
nfpms:
|
|
- empty_folders:
|
|
- /foo/bar
|
|
```
|
|
|
|
=== "After"
|
|
``` yaml
|
|
nfpms:
|
|
- contents:
|
|
- dst: /foo/bar
|
|
type: dir
|
|
```
|
|
|
|
|
|
### builds for windows/arm64
|
|
|
|
> since 2021-08-16 (v0.175.0), removed 2022-06-12 (v1.10.0)
|
|
|
|
Since Go 1.17, `windows/arm64` is a valid target.
|
|
|
|
Prior to v0.175.0, GoReleaser would just ignore this target.
|
|
Since in Go 1.17 it is now a valid target, GoReleaser will build it if the Go version being used is 1.17 or later.
|
|
|
|
If you want to make sure it is ignored in the future, you need to add this to your build config:
|
|
|
|
```yaml
|
|
ignore:
|
|
- goos: windows
|
|
goarch: arm64
|
|
```
|
|
|
|
If you try to use new versions of GoReleaser with Go 1.16 or older, it will warn
|
|
about it until this deprecation warning expires, after that your build will
|
|
likely fail.
|
|
|
|
### godownloader
|
|
|
|
> since 2021-10-13 (all), removed 2022-05-18
|
|
|
|
GoDownloader, the installation script generator, wasn't updated for a long time
|
|
and is now officially deprecated.
|
|
The website and all install scripts will be taken out in 6 months.
|
|
You can still use any of the other install methods.
|
|
|
|
This also includes `install.goreleaser.com`.
|
|
|
|
Most common tools installed via that website were probably
|
|
[GoReleaser](/install/) itself and
|
|
[golangci-lint](https://golangci-lint.run/usage/install/).
|
|
|
|
Please follow to the check their documentation for alternative install methods.
|
|
|
|
### dockers.use_buildx
|
|
|
|
> since 2021-06-26 (v0.172.0), removed 2022-03-16 (v1.7.0)
|
|
|
|
`use_buildx` is deprecated in favor of the more generalist `use`, since now it also allow other options in the future:
|
|
|
|
Change this:
|
|
|
|
=== "Before"
|
|
```yaml
|
|
dockers:
|
|
-
|
|
use_buildx: true
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
dockers:
|
|
-
|
|
use: buildx
|
|
```
|
|
|
|
### builds for darwin/arm64
|
|
|
|
> since 2021-02-17 (v0.157.0), removed 2022-03-16 (v1.7.0)
|
|
|
|
Since Go 1.16, `darwin/arm64` is macOS on Apple Silicon instead of `iOS`.
|
|
|
|
Prior to v0.156.0, GoReleaser would just ignore this target.
|
|
Since in Go 1.16 and later it is a valid target, GoReleaser will now build it if the Go version being used is 1.16 or later.
|
|
|
|
If you want to make sure it is ignored in the future, you need to add this to your build config:
|
|
|
|
```yaml
|
|
ignore:
|
|
- goos: darwin
|
|
goarch: arm64
|
|
```
|
|
|
|
If you try to use new versions of GoReleaser with Go 1.15 or older, it will warn about it until this deprecation warning expires, after that your build will likely fail.
|
|
|
|
### Skipping SemVer Validations
|
|
|
|
> since 2021-02-28 (v0.158.0), removed 2021-09-22 (v0.180.0)
|
|
|
|
GoReleaser skips SemVer validations when run with `--skip-validation` or `--snapshot`.
|
|
This causes other problems later, such as [invalid Linux packages](https://github.com/goreleaser/goreleaser/issues/2081).
|
|
Because of that, once this deprecation expires, GoReleaser will hard fail on non-semver versions, as stated on our [limitations page](https://goreleaser.com/limitations/semver/).
|
|
|
|
### docker.builds
|
|
|
|
> since 2021-01-07 (v0.154.0), removed 2021-08-13 (v0.175.0)
|
|
|
|
`builds` is deprecated in favor of `ids`, since now it also allows to copy nfpm packages:
|
|
|
|
Change this:
|
|
|
|
=== "Before"
|
|
```yaml
|
|
dockers:
|
|
-
|
|
builds: ['a', 'b']
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
dockers:
|
|
-
|
|
ids: ['a', 'b']
|
|
```
|
|
|
|
### docker.binaries
|
|
|
|
> since 2021-01-07 (v0.154.0), removed 2021-08-13 (v0.175.0)
|
|
|
|
`binaries` is deprecated and now does nothing.
|
|
If you want to filter something out, use the `ids` property.
|
|
|
|
Change this:
|
|
|
|
=== "Before"
|
|
```yaml
|
|
dockers:
|
|
-
|
|
binaries: ['foo']
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
dockers:
|
|
-
|
|
ids: ['foo']
|
|
```
|
|
|
|
### nfpms.files
|
|
|
|
> since 2020-12-21 (v0.149.0), removed 2021-07-26 (v0.172.0)
|
|
|
|
`files` is deprecated in favor of `contents` (check [this page](https://goreleaser.com/customization/nfpm/) for more details):
|
|
|
|
Change this:
|
|
|
|
=== "Before"
|
|
```yaml
|
|
nfpms:
|
|
-
|
|
files:
|
|
foo: bar
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
nfpms:
|
|
-
|
|
contents:
|
|
- src: foo
|
|
dst: bar
|
|
```
|
|
|
|
### nfpms.config_files
|
|
|
|
> since 2020-12-21 (v0.149.0), removed 2021-07-26 (v0.172.0)
|
|
|
|
`config_files` is deprecated in favor of `contents` (check [this page](https://goreleaser.com/customization/nfpm/) for more details):
|
|
|
|
Change this:
|
|
|
|
=== "Before"
|
|
```yaml
|
|
nfpms:
|
|
-
|
|
config_files:
|
|
foo: bar
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
nfpms:
|
|
-
|
|
contents:
|
|
- src: foo
|
|
dst: bar
|
|
type: config
|
|
```
|
|
|
|
### nfpms.symlinks
|
|
|
|
> since 2020-12-21 (v0.149.0), removed 2021-07-26 (v0.172.0)
|
|
|
|
`symlinks` is deprecated in favor of `contents` (check [this page](https://goreleaser.com/customization/nfpm/) for more details):
|
|
|
|
Change this:
|
|
|
|
=== "Before"
|
|
```yaml
|
|
nfpms:
|
|
-
|
|
symlinks:
|
|
foo: bar
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
nfpms:
|
|
-
|
|
contents:
|
|
- src: foo
|
|
dst: bar
|
|
type: symlink
|
|
```
|
|
|
|
### nfpms.rpm.ghost_files
|
|
|
|
> since 2020-12-21 (v0.149.0), removed 2021-07-26 (v0.172.0)
|
|
|
|
`rpm.ghost_files` is deprecated in favor of `contents` (check [this page](https://goreleaser.com/customization/nfpm/) for more details):
|
|
|
|
Change this:
|
|
|
|
=== "Before"
|
|
```yaml
|
|
nfpms:
|
|
-
|
|
rpm:
|
|
ghost_files:
|
|
- foo
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
nfpms:
|
|
-
|
|
contents:
|
|
- dst: bar
|
|
type: ghost
|
|
packager: rpm # optional
|
|
```
|
|
|
|
### nfpms.rpm.config_noreplace_files
|
|
|
|
> since 2020-12-21 (v0.149.0), removed 2021-07-26 (v0.172.0)
|
|
|
|
`rpm.config_noreplace_files` is deprecated in favor of `contents` (check [this page](https://goreleaser.com/customization/nfpm/) for more details):
|
|
|
|
Change this:
|
|
|
|
=== "Before"
|
|
```yaml
|
|
nfpms:
|
|
-
|
|
rpm:
|
|
config_noreplace_files:
|
|
foo: bar
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
nfpms:
|
|
-
|
|
contents:
|
|
- src: foo
|
|
dst: bar
|
|
type: config|noreplace
|
|
packager: rpm # optional
|
|
```
|
|
|
|
|
|
### nfpms.deb.version_metadata
|
|
|
|
> since 2020-12-21 (v0.149.0), removed 2021-07-26 (v0.172.0)
|
|
|
|
`deb.version_metadata` is deprecated in favor of `version_metadata` (check [this page](https://goreleaser.com/customization/nfpm/) for more details):
|
|
|
|
Change this:
|
|
|
|
=== "Before"
|
|
```yaml
|
|
nfpms:
|
|
-
|
|
deb:
|
|
version_metadata: beta1
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
nfpms:
|
|
-
|
|
version_metadata: beta1
|
|
```
|
|
|
|
### brews.github
|
|
|
|
> since 2020-07-06 (v0.139.0), removed 2021-01-04 (v0.152.0)
|
|
|
|
GitHub section was deprecated in favour of `tap` which
|
|
reflects Homebrew's naming convention. GitHub will be picked
|
|
automatically when GitHub token is passed.
|
|
|
|
Change this:
|
|
|
|
=== "Before"
|
|
```yaml
|
|
brews:
|
|
-
|
|
github:
|
|
owner: goreleaser
|
|
name: homebrew-tap
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
brews:
|
|
-
|
|
tap:
|
|
owner: goreleaser
|
|
name: homebrew-tap
|
|
```
|
|
|
|
### brews.gitlab
|
|
|
|
> since 2020-07-06 (v0.139.0), removed 2021-01-04 (v0.152.0)
|
|
|
|
GitLab section was deprecated in favour of `tap` which
|
|
reflects Homebrew's naming convention. GitLab will be picked
|
|
automatically when GitLab token is passed.
|
|
|
|
Change this:
|
|
|
|
=== "Before"
|
|
```yaml
|
|
brews:
|
|
-
|
|
gitlab:
|
|
owner: goreleaser
|
|
name: homebrew-tap
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
brews:
|
|
-
|
|
tap:
|
|
owner: goreleaser
|
|
name: homebrew-tap
|
|
```
|
|
|
|
### puts
|
|
|
|
> since 2019-11-15, removed 2020-04-14 (v0.132.0)
|
|
|
|
The HTTP upload support was extended to also accept `POST` as a method,
|
|
so the name `puts` kind of lost its meaning.
|
|
|
|
=== "Before"
|
|
|
|
``` yaml
|
|
puts:
|
|
- ...
|
|
```
|
|
|
|
=== "After"
|
|
``` yaml
|
|
uploads:
|
|
- ...
|
|
```
|
|
|
|
Also note that secrets environment variable name prefixes have changed from
|
|
`PUT_` to `UPLOAD_`.
|
|
|
|
### nfpms.name_template
|
|
|
|
> since 2019-11-15, removed 2020-04-14 (v0.132.0)
|
|
|
|
The `name_template` field was deprecated in favor of a more clear one,
|
|
`file_name_template`.
|
|
|
|
=== "Before"
|
|
``` yaml
|
|
nfpms:
|
|
- name_template: foo
|
|
```
|
|
|
|
|
|
=== "After"
|
|
``` yaml
|
|
nfpms:
|
|
- file_name_template: foo
|
|
```
|
|
|
|
### blob
|
|
|
|
> since 2019-08-02, removed 2020-03-22 (v0.130.0)
|
|
|
|
Blob was deprecated in favor of its plural form.
|
|
It was already accepting multiple inputs, but its pluralized now so its more
|
|
clear.
|
|
|
|
=== "Before"
|
|
```yaml
|
|
blob:
|
|
# etc
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
blobs:
|
|
# etc
|
|
```
|
|
|
|
### sign
|
|
|
|
> since 2019-07-20, removed 2020-03-22 (v0.130.0)
|
|
|
|
Sign was deprecated in favor of its plural form.
|
|
|
|
=== "Before"
|
|
```yaml
|
|
sign:
|
|
# etc
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
signs:
|
|
-
|
|
# etc
|
|
```
|
|
|
|
### brew
|
|
|
|
> since 2019-06-09, removed 2020-01-26 (v0.125.0)
|
|
|
|
Brew was deprecated in favor of its plural form.
|
|
|
|
Change this:
|
|
|
|
=== "Before"
|
|
```yaml
|
|
brew:
|
|
# etc
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
brews:
|
|
-
|
|
# etc
|
|
```
|
|
|
|
### s3
|
|
|
|
> since 2019-06-09, removed 2020-01-07 (v0.125.0)
|
|
|
|
S3 was deprecated in favor of the new `blob`, which supports S3, Azure Blob and
|
|
GCS.
|
|
|
|
=== "Before"
|
|
```yaml
|
|
s3:
|
|
-
|
|
# etc
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
blobs:
|
|
-
|
|
provider: s3
|
|
# etc
|
|
```
|
|
|
|
ACLs should be set on the bucket, the `acl` option does not exist anymore.
|
|
|
|
### archive
|
|
|
|
> since 2019-04-16, removed 2019-12-27 (v0.124.0)
|
|
|
|
We now allow multiple archives, so the `archive` statement will be removed.
|
|
|
|
=== "Before"
|
|
```yaml
|
|
archive:
|
|
format: zip
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
archives:
|
|
- id: foo
|
|
format: zip
|
|
```
|
|
|
|
### snapcraft
|
|
|
|
> since 2019-05-27, removed 2019-12-27 (v0.124.0)
|
|
|
|
We now allow multiple Snapcraft configs, so the `snapcraft` statement will be removed.
|
|
|
|
=== "Before"
|
|
```yaml
|
|
snapcraft:
|
|
publish: true
|
|
# ...
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
snapcrafts:
|
|
-
|
|
publish: true
|
|
# ...
|
|
```
|
|
|
|
### nfpm
|
|
|
|
> since 2019-05-07, removed 2019-12-27 (v0.124.0)
|
|
|
|
We now allow multiple NFPM config, so the `nfpm` statement will be removed.
|
|
|
|
=== "Before"
|
|
```yaml
|
|
nfpm:
|
|
formats:
|
|
- deb
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
nfpms:
|
|
-
|
|
formats:
|
|
- deb
|
|
```
|
|
|
|
### docker.binary
|
|
|
|
> since 2018-10-01, removed 2019-08-02 (v0.114.0)
|
|
|
|
You can now create a Docker image with multiple binaries.
|
|
|
|
=== "Before"
|
|
```yaml
|
|
dockers:
|
|
- image: foo/bar
|
|
binary: foo
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
dockers:
|
|
- image: foo/bar
|
|
binaries:
|
|
- foo
|
|
```
|
|
|
|
### docker.image
|
|
|
|
> since 2018-10-20, removed 2019-08-02 (v0.114.0)
|
|
|
|
This property was deprecated in favor of more flexible `image_templates`.
|
|
The idea is to be able to define several images and tags using templates instead of just one image with tag templates.
|
|
This flexibility allows images to be pushed to multiple registries.
|
|
|
|
=== "Before"
|
|
```yaml
|
|
dockers:
|
|
- image: foo/bar
|
|
tag_templates:
|
|
- '{{ .Tag }}'
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
dockers:
|
|
- image_templates:
|
|
- 'foo/bar:{{ .Tag }}'
|
|
```
|
|
|
|
### docker.tag_templates
|
|
|
|
> since 2018-10-20, removed 2019-08-02 (v0.114.0)
|
|
|
|
This property was deprecated in favor of more flexible `image_templates`.
|
|
The idea is to be able to define several images and tags using templates instead of just one image with tag templates.
|
|
|
|
=== "Before"
|
|
```yaml
|
|
dockers:
|
|
- image: foo/bar
|
|
tag_templates:
|
|
- '{{ .Tag }}'
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
dockers:
|
|
- image_templates:
|
|
- 'foo/bar:{{ .Tag }}'
|
|
```
|
|
|
|
### git.short_hash
|
|
|
|
> since 2018-10-03, removed 2019-01-19 (v0.98.0)
|
|
|
|
This property was being used to tell GoReleaser to use short git hashes
|
|
instead of the full ones. This has been removed in favor of specific
|
|
template variables (`.FullCommit` and `.ShortCommit`).
|
|
|
|
=== "Before"
|
|
```yaml
|
|
git:
|
|
short_hash: true
|
|
|
|
fake:
|
|
foo_template: 'blah {{ .Commit }}'
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
fake:
|
|
foo_template: 'blah {{ .ShortCommit }}'
|
|
```
|
|
|
|
### fpm
|
|
|
|
> since 2018-02-17, removed 2017-08-15 (v0.83.0)
|
|
|
|
FPM is deprecated in favor of nfpm, which is a simpler alternative written
|
|
in Go. The objective is to remove the ruby dependency thus simplify the
|
|
CI/CD pipelines.
|
|
|
|
Just replace the `fpm` keyword by `nfpm` in your `.goreleaser.yaml` file.
|
|
|
|
=== "Before"
|
|
```yaml
|
|
fpm:
|
|
# ...
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
nfpm:
|
|
# ...
|
|
```
|
|
|
|
### docker.tag_template
|
|
|
|
> since 2018-01-19, removed 2017-08-15 (v0.83.0)
|
|
|
|
This property was deprecated in favor of the pluralized `tag_templates`.
|
|
The idea is to be able to define several tags instead of just one.
|
|
|
|
=== "Before"
|
|
```yaml
|
|
dockers:
|
|
- image: foo/bar
|
|
tag_template: '{{ .Tag }}'
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
dockers:
|
|
- image: foo/bar
|
|
tag_templates:
|
|
- '{{ .Tag }}'
|
|
```
|
|
|
|
### docker.latest
|
|
|
|
> since 2018-01-19, removed 2017-08-15 (v0.83.0)
|
|
|
|
The `latest` field in Docker config is deprecated in favor of the newer
|
|
`tag_templates` field.
|
|
|
|
=== "Before"
|
|
```yaml
|
|
dockers:
|
|
- image: foo/bar
|
|
latest: true
|
|
```
|
|
|
|
=== "After"
|
|
```yaml
|
|
dockers:
|
|
- image: foo/bar
|
|
tag_templates:
|
|
- '{{ .Tag }}'
|
|
- latest
|
|
```
|