keel/util/version/version_test.go

354 lines
8.4 KiB
Go

package version
import (
"reflect"
"testing"
"github.com/rusenask/keel/types"
)
func TestGetVersionFromImageName(t *testing.T) {
type args struct {
name string
}
tests := []struct {
name string
args args
want *types.Version
wantErr bool
}{
{
name: "image",
args: args{name: "karolis/webhook-demo:1.4.5"},
want: MustParse("1.4.5"),
wantErr: false,
},
{
name: "semver with v prefix",
args: args{name: "gcr.io/stemnapp/alpine-api:v0.0.824"},
want: MustParse("v0.0.824"),
wantErr: false,
},
{
name: "image latest",
args: args{name: "karolis/webhook-demo:latest"},
wantErr: true,
},
{
name: "image no tag",
args: args{name: "karolis/webhook-demo"},
wantErr: true,
},
{
name: "image webhookrelay",
args: args{name: "gcr.io/webhookrelay/webhookrelay:0.1.14"},
want: MustParse("0.1.14"),
wantErr: false,
},
{
name: "non semver, missing minor and patch",
args: args{name: "index.docker.io/application:42"},
want: &types.Version{
Major: 42,
Minor: 0,
Patch: 0,
Original: "42",
},
wantErr: false,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
got, err := GetVersionFromImageName(tt.args.name)
if (err != nil) != tt.wantErr {
t.Errorf("GetVersionFromImageName() error = %v, wantErr %v", err, tt.wantErr)
return
}
if !reflect.DeepEqual(got, tt.want) {
t.Errorf("GetVersionFromImageName() = %v, want %v", got, tt.want)
}
})
}
}
func TestShouldUpdate(t *testing.T) {
type args struct {
current *types.Version
new *types.Version
policy types.PolicyType
}
tests := []struct {
name string
args args
want bool
wantErr bool
}{
{
name: "new lower, policy all",
args: args{
current: &types.Version{Major: 1, Minor: 4, Patch: 5},
new: &types.Version{Major: 1, Minor: 4, Patch: 3},
policy: types.PolicyTypeAll,
},
want: false,
wantErr: false,
},
{
name: "new minor increase, policy all",
args: args{
current: &types.Version{Major: 1, Minor: 4, Patch: 5},
new: &types.Version{Major: 1, Minor: 4, Patch: 6},
policy: types.PolicyTypeAll,
},
want: true,
wantErr: false,
},
{
name: "no increase, policy all",
args: args{
current: &types.Version{Major: 1, Minor: 4, Patch: 5},
new: &types.Version{Major: 1, Minor: 4, Patch: 5},
policy: types.PolicyTypeAll,
},
want: false,
wantErr: false,
},
{
name: "minor increase, policy major",
args: args{
current: &types.Version{Major: 1, Minor: 4, Patch: 5},
new: &types.Version{Major: 1, Minor: 5, Patch: 5},
policy: types.PolicyTypeMajor,
},
want: true,
wantErr: false,
},
{
name: "major increase, policy major",
args: args{
current: &types.Version{Major: 1, Minor: 4, Patch: 5},
new: &types.Version{Major: 2, Minor: 4, Patch: 5},
policy: types.PolicyTypeMajor,
},
want: true,
wantErr: false,
},
{
name: "patch increase, policy patch",
args: args{
current: &types.Version{Major: 1, Minor: 4, Patch: 5},
new: &types.Version{Major: 1, Minor: 4, Patch: 6},
policy: types.PolicyTypePatch,
},
want: true,
wantErr: false,
},
{
name: "patch decrease, policy patch",
args: args{
current: &types.Version{Major: 1, Minor: 4, Patch: 5},
new: &types.Version{Major: 1, Minor: 4, Patch: 4},
policy: types.PolicyTypePatch,
},
want: false,
wantErr: false,
},
{
name: "patch AND major increase, policy patch",
args: args{
current: &types.Version{Major: 1, Minor: 4, Patch: 5},
new: &types.Version{Major: 2, Minor: 4, Patch: 6},
policy: types.PolicyTypePatch,
},
want: false,
wantErr: false,
},
{
name: "patch same, policy patch",
args: args{
current: &types.Version{Major: 1, Minor: 4, Patch: 5},
new: &types.Version{Major: 1, Minor: 4, Patch: 5},
policy: types.PolicyTypePatch,
},
want: false,
wantErr: false,
},
{
name: "minor increase, policy minor",
args: args{
current: &types.Version{Major: 1, Minor: 4, Patch: 5},
new: &types.Version{Major: 1, Minor: 5, Patch: 5},
policy: types.PolicyTypeMinor,
},
want: true,
wantErr: false,
},
{
name: "patch increase, policy minor",
args: args{
current: &types.Version{Major: 1, Minor: 4, Patch: 5},
new: &types.Version{Major: 1, Minor: 4, Patch: 6},
policy: types.PolicyTypeMinor,
},
want: true,
wantErr: false,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
got, err := ShouldUpdate(tt.args.current, tt.args.new, tt.args.policy)
if (err != nil) != tt.wantErr {
t.Errorf("ShouldUpdate() error = %v, wantErr %v", err, tt.wantErr)
return
}
if got != tt.want {
t.Errorf("ShouldUpdate() = %v, want %v", got, tt.want)
}
})
}
}
func TestNewAvailable(t *testing.T) {
type args struct {
current string
tags []string
}
tests := []struct {
name string
args args
wantNewVersion string
wantNewAvailable bool
wantErr bool
}{
{
name: "new semver",
args: args{current: "1.1.1", tags: []string{"1.1.1", "1.1.2"}},
wantNewVersion: "1.1.2",
wantNewAvailable: true,
wantErr: false,
},
{
name: "no new semver",
args: args{current: "1.1.1", tags: []string{"1.1.0", "1.1.1"}},
wantNewVersion: "",
wantNewAvailable: false,
wantErr: false,
},
{
name: "no semvers in tag list",
args: args{current: "1.1.1", tags: []string{"latest", "alpha"}},
wantNewVersion: "",
wantNewAvailable: false,
wantErr: false,
},
{
name: "mixed tag list",
args: args{current: "1.1.1", tags: []string{"latest", "alpha", "1.1.2"}},
wantNewVersion: "1.1.2",
wantNewAvailable: true,
wantErr: false,
},
{
name: "mixed tag list",
args: args{current: "1.1.1", tags: []string{"1.1.0", "alpha", "1.1.2", "latest"}},
wantNewVersion: "1.1.2",
wantNewAvailable: true,
wantErr: false,
},
{
name: "empty tags list",
args: args{current: "1.1.1", tags: []string{}},
wantNewVersion: "",
wantNewAvailable: false,
wantErr: false,
},
{
name: "not semver current tag",
args: args{current: "latest", tags: []string{"1.1.1"}},
wantNewVersion: "",
wantNewAvailable: false,
wantErr: true,
},
{
name: "staging",
args: args{current: "1.1.1", tags: []string{"v1.2.1-staging.1"}},
wantNewVersion: "1.2.1-staging.1",
wantNewAvailable: true,
wantErr: false,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
gotNewVersion, gotNewAvailable, err := NewAvailable(tt.args.current, tt.args.tags)
if (err != nil) != tt.wantErr {
t.Errorf("NewAvailable() error = %v, wantErr %v", err, tt.wantErr)
return
}
if gotNewVersion != tt.wantNewVersion {
t.Errorf("NewAvailable() gotNewVersion = %v, want %v", gotNewVersion, tt.wantNewVersion)
}
if gotNewAvailable != tt.wantNewAvailable {
t.Errorf("NewAvailable() gotNewAvailable = %v, want %v", gotNewAvailable, tt.wantNewAvailable)
}
})
}
}
func TestGetVersion(t *testing.T) {
type args struct {
version string
}
tests := []struct {
name string
args args
want *types.Version
wantErr bool
}{
{
name: "normal version",
args: args{version: "1.2.3"},
want: &types.Version{
Major: 1,
Minor: 2,
Patch: 3,
Original: "1.2.3",
},
wantErr: false,
},
{
name: "legacy semver version",
args: args{version: "v1.2.3"},
want: &types.Version{
Major: 1,
Minor: 2,
Patch: 3,
Original: "v1.2.3",
},
wantErr: false,
},
{
name: "not semver",
args: args{version: "23"},
want: &types.Version{
Major: 23,
Minor: 0,
Patch: 0,
Original: "23",
},
wantErr: false,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
got, err := GetVersion(tt.args.version)
if (err != nil) != tt.wantErr {
t.Errorf("GetVersion() error = %v, wantErr %v", err, tt.wantErr)
return
}
if !reflect.DeepEqual(got, tt.want) {
t.Errorf("GetVersion() = %v, want %v", got, tt.want)
}
})
}
}