constellation/internal/semver/semver_test.go
Moritz Sanft 2d41a19fbf
internal: semver support for pseudoversions (#1564)
* support for prerelease tag / pseudoversion

* build version first

Co-authored-by: Daniel Weiße <66256922+daniel-weisse@users.noreply.github.com>

* use strings.Cut

Co-authored-by: Daniel Weiße <66256922+daniel-weisse@users.noreply.github.com>

---------

Co-authored-by: Daniel Weiße <66256922+daniel-weisse@users.noreply.github.com>
2023-04-03 10:48:28 +02:00

307 lines
5.7 KiB
Go

/*
Copyright (c) Edgeless Systems GmbH
SPDX-License-Identifier: AGPL-3.0-only
*/
package semver
import (
"testing"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
var (
v1_18_0 = Semver{Major: 1, Minor: 18, Patch: 0}
v1_18_0Pre = Semver{Major: 1, Minor: 18, Patch: 0, Prerelease: "pre"}
v1_18_0PreExtra = Semver{Major: 1, Minor: 18, Patch: 0, Prerelease: "pre.1"}
v1_19_0 = Semver{Major: 1, Minor: 19, Patch: 0}
v1_18_1 = Semver{Major: 1, Minor: 18, Patch: 1}
v1_20_0 = Semver{Major: 1, Minor: 20, Patch: 0}
v2_0_0 = Semver{Major: 2, Minor: 0, Patch: 0}
)
func TestNewVersion(t *testing.T) {
testCases := map[string]struct {
version string
want Semver
wantErr bool
}{
"valid version": {
version: "v1.18.0",
want: Semver{
Major: 1,
Minor: 18,
Patch: 0,
},
wantErr: false,
},
"valid version prerelease": {
version: "v1.18.0-pre+yyyymmddhhmmss-abcdefabcdef",
want: Semver{
Major: 1,
Minor: 18,
Patch: 0,
Prerelease: "pre",
},
wantErr: false,
},
"only prerelease": {version: "v-pre.0.yyyymmddhhmmss-abcdefabcdef", wantErr: true},
"invalid version": {version: "v1.18. 0", wantErr: true},
"add prefix": {
version: "1.18.0",
want: Semver{
Major: 1,
Minor: 18,
Patch: 0,
},
wantErr: false,
},
"only major.minor": {
version: "v1.18",
want: Semver{
Major: 1,
Minor: 18,
Patch: 0,
},
wantErr: false,
},
"only major": {
version: "v1",
want: Semver{
Major: 1,
Minor: 0,
Patch: 0,
},
wantErr: false,
},
}
for name, tc := range testCases {
t.Run(name, func(t *testing.T) {
assert := assert.New(t)
ver, err := New(tc.version)
if tc.wantErr {
assert.Error(err)
} else {
assert.NoError(err)
assert.Equal(tc.want, ver)
}
})
}
}
func TestJSONMarshal(t *testing.T) {
testCases := map[string]struct {
version Semver
wantString string
wantErr bool
}{
"valid version": {
version: v1_18_0,
wantString: `"v1.18.0"`,
},
"prerelease": {
version: v1_18_0Pre,
wantString: `"v1.18.0-pre"`,
},
}
for name, tc := range testCases {
t.Run(name, func(t *testing.T) {
assert := assert.New(t)
require := require.New(t)
b, err := tc.version.MarshalJSON()
if tc.wantErr {
require.Error(err)
} else {
assert.NoError(err)
assert.Equal(tc.wantString, string(b))
}
})
}
}
func TestJSONUnmarshal(t *testing.T) {
testCases := map[string]struct {
version string
wantString string
wantErr bool
}{
"valid version": {
version: `"v1.18.0"`,
wantString: "v1.18.0",
},
"invalid version": {
version: `"v1. 18.0"`,
wantErr: true,
},
"prerelease": {
version: `"v1.18.0-pre"`,
wantString: "v1.18.0-pre",
},
}
for name, tc := range testCases {
t.Run(name, func(t *testing.T) {
assert := assert.New(t)
require := require.New(t)
var version Semver
err := version.UnmarshalJSON([]byte(tc.version))
if tc.wantErr {
require.Error(err)
} else {
assert.NoError(err)
assert.Equal(tc.wantString, version.String())
}
})
}
}
func TestComparison(t *testing.T) {
testCases := map[string]struct {
version1 Semver
version2 Semver
want int
}{
"equal": {
version1: v1_18_0,
version2: v1_18_0,
want: 0,
},
"less than": {
version1: v1_18_0,
version2: v1_18_1,
want: -1,
},
"greater than": {
version1: v1_18_1,
version2: v1_18_0,
want: 1,
},
"prerelease less than": {
version1: v1_18_0Pre,
version2: v1_18_0,
want: -1,
},
"prerelease greater than": {
version1: v1_18_0,
version2: v1_18_0Pre,
want: 1,
},
"prerelease equal": {
version1: v1_18_0Pre,
version2: v1_18_0Pre,
want: 0,
},
"prerelease extra less than": {
version1: v1_18_0Pre,
version2: v1_18_0PreExtra,
want: -1,
},
}
for name, tc := range testCases {
t.Run(name, func(t *testing.T) {
assert := assert.New(t)
assert.Equal(tc.want, tc.version1.Compare(tc.version2))
})
}
}
func TestCanUpgrade(t *testing.T) {
testCases := map[string]struct {
version1 Semver
version2 Semver
want bool
wantErr bool
}{
"equal": {
version1: v1_18_0,
version2: v1_18_0,
want: false,
},
"patch less than": {
version1: v1_18_0,
version2: v1_18_1,
want: true,
},
"minor less then": {
version1: v1_18_0,
version2: v1_19_0,
want: true,
},
"minor too big drift": {
version1: v1_18_0,
version2: v1_20_0,
want: false,
},
"major too big drift": {
version1: v1_18_0,
version2: v2_0_0,
want: false,
},
"greater than": {
version1: v1_18_1,
version2: v1_18_0,
want: false,
},
"prerelease less than": {
version1: v1_18_0Pre,
version2: v1_18_0,
want: true,
},
"prerelease greater than": {
version1: v1_18_0,
version2: v1_18_0Pre,
want: false,
},
"prerelease equal": {
version1: v1_18_0Pre,
version2: v1_18_0Pre,
want: false,
},
"prerelease extra": {
version1: v1_18_0Pre,
version2: v1_18_0PreExtra,
want: true,
},
}
for name, tc := range testCases {
t.Run(name, func(t *testing.T) {
assert := assert.New(t)
assert.Equal(tc.want, tc.version2.IsUpgradeTo(tc.version1))
})
}
}
func TestNextMinor(t *testing.T) {
testCases := map[string]struct {
version Semver
want string
}{
"valid version": {
version: v1_18_0,
want: "v1.19",
},
"prerelease": {
version: v1_18_0Pre,
want: "v1.19",
},
}
for name, tc := range testCases {
t.Run(name, func(t *testing.T) {
assert := assert.New(t)
assert.Equal(tc.want, tc.version.NextMinor())
})
}
}