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

Merge pull request #202 from goreleaser/brew-fpm-alike

make brew and fpm config more alike
This commit is contained in:
Carlos Alexandro Becker 2017-04-21 17:17:59 -03:00 committed by GitHub
commit 8d914d129a
10 changed files with 61 additions and 88 deletions

View File

@ -288,6 +288,14 @@ brew:
# Default is empty.
caveats: "How to use this binary"
# Your app's homepage
# Default is empty
homepage: "https://example.com/"
# Your app's description
# Default is empty
description: "Software to create fast and easy drum rolls."
# Dependencies of your package
dependencies:
- git
@ -339,13 +347,25 @@ GoReleaser can be wired to [fpm]() to generate `.deb`, `.rpm` and other archives
```yml
# goreleaser.yml
fpm:
# Options used in deb control file etc.
options:
vendor: "Drum Roll Inc."
url: "https://example.com/"
maintainer: "<Drummer drum-roll@example.com>"
description: "Software to create fast and easy drum rolls."
license: "Apache 2.0"
# Your app's vendor
# Default is empty
vendor: Drum Roll Inc.
# Your app's homepage
# Default is empty
homepage: https://example.com/
# Your app's maintainer (probably you)
# Default is empty
maintainer: <Drummer drum-roll@example.com>
# Your app's description
# Default is empty
description: Software to create fast and easy drum rolls.
# Your app's license
# Default is empty
license: Apache 2.0
# Formats to generate as output
formats:
- deb

View File

@ -17,7 +17,6 @@ type Info struct {
// Client interface
type Client interface {
GetInfo(ctx *context.Context) (info Info, err error)
CreateRelease(ctx *context.Context, body string) (releaseID int, err error)
CreateFile(ctx *context.Context, content bytes.Buffer, path string) (err error)
Upload(ctx *context.Context, releaseID int, name string, file *os.File) (err error)

View File

@ -67,21 +67,6 @@ func (c *githubClient) CreateFile(
return
}
func (c *githubClient) GetInfo(ctx *context.Context) (info Info, err error) {
rep, _, err := c.client.Repositories.Get(
ctx,
ctx.Config.Release.GitHub.Owner,
ctx.Config.Release.GitHub.Name,
)
if err != nil {
return
}
info.Homepage = rep.GetHomepage()
info.URL = rep.GetHTMLURL()
info.Description = rep.GetDescription()
return
}
func (c *githubClient) CreateRelease(ctx *context.Context, body string) (releaseID int, err error) {
data := &github.RepositoryRelease{
Name: github.String(ctx.Git.CurrentTag),

View File

@ -28,6 +28,8 @@ type Homebrew struct {
Install string
Dependencies []string
Conflicts []string
Description string
URL string
}
// Hooks define actions to run before and/or after something
@ -72,16 +74,11 @@ type FPM struct {
Formats []string
Dependencies []string
Conflicts []string
Options FPMOptions
}
// FPMOptions config options
type FPMOptions struct {
Vendor string
URL string
Maintainer string
Description string
License string
Vendor string
Homepage string
Maintainer string
Description string
License string
}
// Project includes all project configuration

View File

@ -1,3 +1,5 @@
homepage: &homepage http://goreleaser.github.io
description: &description Deliver Go binaries as fast and easily as possible
build:
main: ./cmd/goreleaser/main.go
goos:
@ -18,9 +20,16 @@ brew:
owner: goreleaser
name: homebrew-tap
folder: Formula
homepage: *homepage
description: *description
dependencies:
- git
fpm:
homepage: *homepage
description: *description
maintainer: Carlos Alexandro Becker <root@carlosbecker.com>
license: MIT
vendor: GoReleaser
formats:
- deb
dependencies:

View File

@ -143,21 +143,17 @@ func dataFor(ctx *context.Context, client client.Client) (result templateData, e
if err != nil {
return
}
homepage, description, err := getInfo(ctx, client)
if err != nil {
return
}
return templateData{
Name: formulaNameFor(ctx.Config.Build.Binary),
Desc: description,
Homepage: homepage,
Desc: ctx.Config.Brew.Description,
Homepage: ctx.Config.Brew.URL,
Repo: ctx.Config.Release.GitHub,
Tag: ctx.Git.CurrentTag,
Version: ctx.Version,
Binary: ctx.Config.Build.Binary,
Caveats: ctx.Config.Brew.Caveats,
File: file,
Format: ctx.Config.Archive.Format,
Format: ctx.Config.Archive.Format, // TODO this can be broken by format_overrides
SHA256: sum,
Dependencies: ctx.Config.Brew.Dependencies,
Conflicts: ctx.Config.Brew.Conflicts,
@ -166,27 +162,6 @@ func dataFor(ctx *context.Context, client client.Client) (result templateData, e
}, err
}
func getInfo(
ctx *context.Context,
client client.Client,
) (homepage string, description string, err error) {
info, err := client.GetInfo(ctx)
if err != nil {
return
}
if info.Homepage == "" {
homepage = info.URL
} else {
homepage = info.Homepage
}
if info.Description == "" {
description = "TODO"
} else {
description = info.Description
}
return
}
func formulaNameFor(name string) string {
name = strings.Replace(name, "-", " ", -1)
name = strings.Replace(name, "_", " ", -1)

View File

@ -7,7 +7,6 @@ import (
"path/filepath"
"testing"
"github.com/goreleaser/goreleaser/client"
"github.com/goreleaser/goreleaser/config"
"github.com/goreleaser/goreleaser/context"
"github.com/stretchr/testify/assert"
@ -170,10 +169,6 @@ type DummyClient struct {
CreatedFile bool
}
func (client *DummyClient) GetInfo(ctx *context.Context) (info client.Info, err error) {
return
}
func (client *DummyClient) CreateRelease(ctx *context.Context, body string) (releaseID int, err error) {
return
}

View File

@ -71,20 +71,20 @@ func create(ctx *context.Context, format, archive, arch string) error {
"--force",
}
if ctx.Config.FPM.Options.Vendor != "" {
options = append(options, "--vendor", ctx.Config.FPM.Options.Vendor)
if ctx.Config.FPM.Vendor != "" {
options = append(options, "--vendor", ctx.Config.FPM.Vendor)
}
if ctx.Config.FPM.Options.URL != "" {
options = append(options, "--url", ctx.Config.FPM.Options.URL)
if ctx.Config.FPM.Homepage != "" {
options = append(options, "--url", ctx.Config.FPM.Homepage)
}
if ctx.Config.FPM.Options.Maintainer != "" {
options = append(options, "--maintainer", ctx.Config.FPM.Options.Maintainer)
if ctx.Config.FPM.Maintainer != "" {
options = append(options, "--maintainer", ctx.Config.FPM.Maintainer)
}
if ctx.Config.FPM.Options.Description != "" {
options = append(options, "--description", ctx.Config.FPM.Options.Description)
if ctx.Config.FPM.Description != "" {
options = append(options, "--description", ctx.Config.FPM.Description)
}
if ctx.Config.FPM.Options.License != "" {
options = append(options, "--license", ctx.Config.FPM.Options.License)
if ctx.Config.FPM.License != "" {
options = append(options, "--license", ctx.Config.FPM.License)
}
for _, dep := range ctx.Config.FPM.Dependencies {
options = append(options, "--depends", dep)

View File

@ -49,13 +49,11 @@ func TestRunPipe(t *testing.T) {
Formats: []string{"deb"},
Dependencies: []string{"make"},
Conflicts: []string{"git"},
Options: config.FPMOptions{
Description: "Some description",
License: "MIT",
Maintainer: "me@me",
Vendor: "asdf",
URL: "https://goreleaser.github.io",
},
Description: "Some description",
License: "MIT",
Maintainer: "me@me",
Vendor: "asdf",
Homepage: "https://goreleaser.github.io",
},
},
}

View File

@ -8,7 +8,6 @@ import (
"path/filepath"
"testing"
"github.com/goreleaser/goreleaser/client"
"github.com/goreleaser/goreleaser/config"
"github.com/goreleaser/goreleaser/context"
"github.com/stretchr/testify/assert"
@ -144,10 +143,6 @@ type DummyClient struct {
UploadedFile bool
}
func (client *DummyClient) GetInfo(ctx *context.Context) (info client.Info, err error) {
return
}
func (client *DummyClient) CreateRelease(ctx *context.Context, body string) (releaseID int, err error) {
if client.FailToCreateRelease {
return 0, errors.New("release failed")