Skip to content

Commit

Permalink
releaser: Replace the magic version handling
Browse files Browse the repository at this point in the history
Take the new version as a string value.
  • Loading branch information
bep committed Jul 5, 2017
1 parent e7a54e7 commit 5f831a6
Show file tree
Hide file tree
Showing 5 changed files with 69 additions and 114 deletions.
12 changes: 8 additions & 4 deletions commands/release.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@
package commands

import (
"errors"

"github.com/gohugoio/hugo/releaser"
"github.com/spf13/cobra"
)
Expand All @@ -27,8 +29,7 @@ func init() {
type releaseCommandeer struct {
cmd *cobra.Command

// Will be zero for main releases.
patchLevel int
version string

skipPublish bool
try bool
Expand All @@ -51,7 +52,7 @@ func createReleaser() *releaseCommandeer {
return r.release()
}

r.cmd.PersistentFlags().IntVarP(&r.patchLevel, "patch", "p", 0, "patch level, defaults to 0 for main releases")
r.cmd.PersistentFlags().StringVarP(&r.version, "rel", "r", "", "new release version, i.e. 0.25.1")
r.cmd.PersistentFlags().IntVarP(&r.step, "step", "s", -1, "release step, defaults to -1 for all steps.")
r.cmd.PersistentFlags().BoolVarP(&r.skipPublish, "skip-publish", "", false, "skip all publishing pipes of the release")
r.cmd.PersistentFlags().BoolVarP(&r.try, "try", "", false, "simulate a release, i.e. no changes")
Expand All @@ -60,5 +61,8 @@ func createReleaser() *releaseCommandeer {
}

func (r *releaseCommandeer) release() error {
return releaser.New(r.patchLevel, r.step, r.skipPublish, r.try).Run()
if r.version == "" {
return errors.New("must set the --rel flag to the relevant version number")
}
return releaser.New(r.version, r.step, r.skipPublish, r.try).Run()
}
54 changes: 42 additions & 12 deletions helpers/hugo.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
package helpers

import (
"errors"
"fmt"
"strings"

Expand All @@ -37,6 +38,29 @@ func (v HugoVersion) String() string {
return hugoVersion(v.Number, v.PatchLevel, v.Suffix)
}

func ParseHugoVersion(s string) (HugoVersion, error) {
var vv HugoVersion

if strings.Contains(s, "DEV") {
return vv, errors.New("DEV versions not supported by parse")
}

v, p := parseVersion(s)

vv.Number = v
vv.PatchLevel = p

return vv, nil
}

func MustParseHugoVersion(s string) HugoVersion {
vv, err := ParseHugoVersion(s)
if err != nil {
panic(err)
}
return vv
}

// ReleaseVersion represents the release version.
func (v HugoVersion) ReleaseVersion() HugoVersion {
v.Suffix = ""
Expand Down Expand Up @@ -100,18 +124,7 @@ func compareVersions(inVersion float32, inPatchVersion int, in interface{}) int
return -1
}

var (
v float32
p int
)

if strings.Count(s, ".") == 2 {
li := strings.LastIndex(s, ".")
p = cast.ToInt(s[li+1:])
s = s[:li]
}

v = float32(cast.ToFloat64(s))
v, p := parseVersion(s)

if v == inVersion && p == inPatchVersion {
return 0
Expand All @@ -125,6 +138,23 @@ func compareVersions(inVersion float32, inPatchVersion int, in interface{}) int
}
}

func parseVersion(s string) (float32, int) {
var (
v float32
p int
)

if strings.Count(s, ".") == 2 {
li := strings.LastIndex(s, ".")
p = cast.ToInt(s[li+1:])
s = s[:li]
}

v = float32(cast.ToFloat64(s))

return v, p
}

func compareFloatVersions(version float32, v float32) int {
if v == version {
return 0
Expand Down
8 changes: 8 additions & 0 deletions helpers/hugo_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -49,3 +49,11 @@ func TestCompareVersions(t *testing.T) {
require.Equal(t, 1, compareVersions(0.20, 1, "0.20.2"))
require.Equal(t, 1, compareVersions(0.21, 1, "0.22.1"))
}

func TestParseHugoVersion(t *testing.T) {
require.Equal(t, "0.25", MustParseHugoVersion("0.25").String())
require.Equal(t, "0.25.2", MustParseHugoVersion("0.25.2").String())

_, err := ParseHugoVersion("0.25-DEV")
require.Error(t, err)
}
30 changes: 11 additions & 19 deletions releaser/releaser.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ import (
const commitPrefix = "releaser:"

type ReleaseHandler struct {
patch int
cliVersion string

// If set, we do the releases in 3 steps:
// 1: Create and write a draft release notes
Expand Down Expand Up @@ -62,33 +62,25 @@ func (r ReleaseHandler) shouldPrepareVersions() bool {
return r.step < 1 || r.step == 2
}

func (r ReleaseHandler) calculateVersions(current helpers.HugoVersion) (helpers.HugoVersion, helpers.HugoVersion) {
var (
newVersion = current
finalVersion = current
)
func (r ReleaseHandler) calculateVersions() (helpers.HugoVersion, helpers.HugoVersion) {

newVersion := helpers.MustParseHugoVersion(r.cliVersion)
finalVersion := newVersion
finalVersion.PatchLevel = 0

newVersion.Suffix = ""

if r.shouldContinue() {
// The version in the current code base is in the state we want for
// the release.
if r.patch == 0 {
finalVersion = newVersion.Next()
}
} else if r.patch > 0 {
newVersion = helpers.CurrentHugoVersion.NextPatchLevel(r.patch)
} else {
finalVersion = newVersion.Next()
if newVersion.PatchLevel == 0 {
finalVersion = finalVersion.Next()
}

finalVersion.Suffix = "-DEV"

return newVersion, finalVersion
}

func New(patch, step int, skipPublish, try bool) *ReleaseHandler {
rh := &ReleaseHandler{patch: patch, step: step, skipPublish: skipPublish, try: try}
func New(version string, step int, skipPublish, try bool) *ReleaseHandler {
rh := &ReleaseHandler{cliVersion: version, step: step, skipPublish: skipPublish, try: try}

if try {
rh.git = func(args ...string) (string, error) {
Expand All @@ -107,7 +99,7 @@ func (r *ReleaseHandler) Run() error {
return errors.New("GITHUB_TOKEN not set, create one here with the repo scope selected: https://github.com/settings/tokens/new")
}

newVersion, finalVersion := r.calculateVersions(helpers.CurrentHugoVersion)
newVersion, finalVersion := r.calculateVersions()

version := newVersion.String()
tag := "v" + version
Expand Down
79 changes: 0 additions & 79 deletions releaser/releaser_test.go

This file was deleted.

0 comments on commit 5f831a6

Please sign in to comment.