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

111 lines
2.5 KiB
Go
Raw Normal View History

2017-04-15 16:12:32 -03:00
// Package git implements the Pipe interface getting and validating the
// current git repository state
2017-01-14 12:34:22 -02:00
package git
2017-01-29 21:55:32 -02:00
import (
2017-04-29 12:49:22 +02:00
"bytes"
2017-01-30 08:08:42 -02:00
"regexp"
2017-01-29 21:55:32 -02:00
"strings"
2017-04-29 12:49:22 +02:00
"text/template"
2017-06-22 00:09:14 -03:00
"time"
2017-01-29 21:55:32 -02:00
2017-06-22 00:09:14 -03:00
"github.com/apex/log"
2017-01-29 21:55:32 -02:00
"github.com/goreleaser/goreleaser/context"
2017-08-19 12:47:04 -03:00
"github.com/goreleaser/goreleaser/internal/git"
2017-08-20 16:35:46 -03:00
"github.com/goreleaser/goreleaser/pipeline"
"github.com/pkg/errors"
2017-01-29 21:55:32 -02:00
)
2017-01-14 12:34:22 -02:00
// Pipe for brew deployment
type Pipe struct{}
2017-01-14 19:41:32 +01:00
// Description of the pipe
2017-01-14 15:14:35 -02:00
func (Pipe) Description() string {
2017-04-15 16:11:47 -03:00
return "Getting and validating git state"
2017-01-14 12:34:22 -02:00
}
// Run the pipe
func (Pipe) Run(ctx *context.Context) (err error) {
2017-04-19 17:05:10 -03:00
tag, commit, err := getInfo()
2017-01-14 12:34:22 -02:00
if err != nil {
return
}
2017-04-29 12:49:22 +02:00
if tag == "" && !ctx.Snapshot {
return ErrNoTag
}
2017-01-18 15:08:48 -02:00
ctx.Git = context.GitInfo{
2017-04-19 17:05:10 -03:00
CurrentTag: tag,
Commit: commit,
2017-01-14 14:06:57 -02:00
}
2017-09-02 22:51:03 -03:00
log.Infof("releasing %s, commit %s", tag, commit)
2017-05-01 10:39:57 -03:00
if err = setVersion(ctx, tag, commit); err != nil {
return
}
if !ctx.Validate {
2017-08-20 16:35:46 -03:00
return pipeline.Skip("--skip-validate is set")
2017-05-01 10:39:57 -03:00
}
2017-05-01 10:57:37 -03:00
return validate(ctx, commit, tag)
2017-05-01 10:39:57 -03:00
}
func setVersion(ctx *context.Context, tag, commit string) (err error) {
if ctx.Snapshot {
2017-04-29 12:49:22 +02:00
snapshotName, err := getSnapshotName(ctx, tag, commit)
if err != nil {
return errors.Wrap(err, "failed to generate snapshot name")
2017-04-29 12:49:22 +02:00
}
ctx.Version = snapshotName
2017-05-01 10:39:57 -03:00
return nil
}
// removes usual `v` prefix
ctx.Version = strings.TrimPrefix(tag, "v")
return
}
2017-04-29 12:49:22 +02:00
type snapshotNameData struct {
Commit string
Tag string
Timestamp int64
}
func getSnapshotName(ctx *context.Context, tag, commit string) (string, error) {
tmpl, err := template.New("snapshot").Parse(ctx.Config.Snapshot.NameTemplate)
var out bytes.Buffer
if err != nil {
return "", err
}
2017-05-01 10:39:57 -03:00
var data = snapshotNameData{
Commit: commit,
Tag: tag,
Timestamp: time.Now().Unix(),
2017-04-29 12:49:22 +02:00
}
2017-05-01 10:39:57 -03:00
err = tmpl.Execute(&out, data)
return out.String(), err
2017-04-15 17:04:26 -03:00
}
2017-05-01 10:57:37 -03:00
func validate(ctx *context.Context, commit, tag string) error {
2017-08-19 12:47:04 -03:00
out, err := git.Run("status", "--porcelain")
2017-04-15 16:11:47 -03:00
if strings.TrimSpace(out) != "" || err != nil {
return ErrDirty{out}
}
2017-05-01 10:57:37 -03:00
if ctx.Snapshot {
return nil
}
if !regexp.MustCompile("^[0-9.]+").MatchString(ctx.Version) {
return ErrInvalidVersionFormat{ctx.Version}
}
_, err = git.Clean(git.Run("describe", "--exact-match", "--tags", "--match", tag))
2017-05-01 10:57:37 -03:00
if err != nil {
return ErrWrongRef{commit, tag}
2017-04-15 16:11:47 -03:00
}
return nil
2017-01-14 12:34:22 -02:00
}
2017-04-19 17:05:10 -03:00
func getInfo() (tag, commit string, err error) {
tag, err = git.Clean(git.Run("describe", "--tags", "--abbrev=0"))
2017-04-15 17:04:26 -03:00
if err != nil {
2017-06-22 10:47:34 -03:00
log.WithError(err).Info("failed to retrieve current tag")
2017-04-15 17:04:26 -03:00
}
commit, err = git.Clean(git.Run("show", "--format='%H'", "HEAD"))
2017-04-23 16:42:34 -03:00
return
2017-04-23 16:33:44 -03:00
}