tests moved to policy package

feature/regexp_matching
Karolis Rusenas 2018-09-02 21:08:26 +01:00
parent dfe21c5fc0
commit 31ae67f3ba
1 changed files with 0 additions and 287 deletions

View File

@ -71,293 +71,6 @@ func TestGetVersionFromImageName(t *testing.T) {
}
}
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,
},
{
name: "prerelease patch increase, policy minor, no prerelease",
args: args{
current: &types.Version{Major: 1, Minor: 4, Patch: 5},
new: &types.Version{Major: 1, Minor: 4, Patch: 6, PreRelease: "xx"},
policy: types.PolicyTypeMinor,
},
want: false,
wantErr: false,
},
{
name: "parsed prerelease patch increase, policy minor, no prerelease",
args: args{
current: MustParse("v1.0.0"),
new: MustParse("v1.0.1-metadata"),
policy: types.PolicyTypeMinor,
},
want: false,
wantErr: false,
},
{
name: "parsed prerelease minor increase, policy minor, both have metadata",
args: args{
current: MustParse("v1.0.0-metadata"),
new: MustParse("v1.0.1-metadata"),
policy: types.PolicyTypeMinor,
},
want: true,
wantErr: false,
},
{
name: "prerelease patch increase, policy minor",
args: args{
current: &types.Version{Major: 1, Minor: 4, Patch: 5, PreRelease: "xx"},
new: &types.Version{Major: 1, Minor: 4, Patch: 6, PreRelease: "xx"},
policy: types.PolicyTypeMinor,
},
want: true,
wantErr: false,
},
{
name: "patch increase, policy minor, wrong prerelease",
args: args{
current: &types.Version{Major: 1, Minor: 4, Patch: 5, PreRelease: "xx"},
new: &types.Version{Major: 1, Minor: 4, Patch: 6, PreRelease: "yy"},
policy: types.PolicyTypeMinor,
},
want: false,
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: "v1.2.1-staging.1",
wantNewAvailable: true,
wantErr: false,
},
{
name: "without patch version",
args: args{current: "8.1", tags: []string{"8.1", "8.2", "8.3"}},
wantNewVersion: "8.3",
wantNewAvailable: true,
wantErr: false,
},
{
name: "only major version",
args: args{current: "8.1.1", tags: []string{"8", "9", "10"}},
wantNewVersion: "10",
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