1
0
Fork 0
mirror of https://github.com/kyverno/kyverno.git synced 2025-01-20 18:52:16 +00:00
kyverno/pkg/engine/anchor/error_test.go
Vishal Choudhary 48d9ebba2c
Replaces manually written logic with regex for matching anchor elements (#6133)
* uses regular expressions

Signed-off-by: Vishal Choudhary <sendtovishalchoudhary@gmail.com>

* adds regex capture

Signed-off-by: Vishal Choudhary <sendtovishalchoudhary@gmail.com>

* creates anchor instance

Signed-off-by: Vishal Choudhary <sendtovishalchoudhary@gmail.com>

* remove IsAnchor

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* more

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* added interface

Signed-off-by: Vishal Choudhary <sendtovishalchoudhary@gmail.com>

* remove static funcs

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* adapt

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* value receiver

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* simplify

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* fix

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* error

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* renames

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* private

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* nit

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* fix

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* fix

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* ficx

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* refactor

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* test

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* tests

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* test

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* fix

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* error

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* unit tests

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* refactor

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* fix

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* fix

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* unit tests

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* fix

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* fix

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

* fix

Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>

---------

Signed-off-by: Vishal Choudhary <sendtovishalchoudhary@gmail.com>
Signed-off-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>
Co-authored-by: Charles-Edouard Brétéché <charles.edouard@nirmata.com>
Co-authored-by: Charles-Edouard Brétéché <charled.breteche@gmail.com>
Co-authored-by: shuting <shuting@nirmata.com>
2023-01-30 12:17:19 +00:00

276 lines
5.1 KiB
Go

package anchor
import (
"errors"
"reflect"
"testing"
)
func Test_validateAnchorError_Error(t *testing.T) {
type fields struct {
err anchorError
message string
}
tests := []struct {
name string
fields fields
want string
}{{
fields: fields{
err: negationAnchorErr,
message: "test",
},
want: "test",
}, {
fields: fields{
err: conditionalAnchorErr,
message: "test",
},
want: "test",
}, {
fields: fields{
err: globalAnchorErr,
message: "test",
},
want: "test",
}, {
fields: fields{
err: globalAnchorErr,
message: "",
},
want: "",
}}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
e := validateAnchorError{
err: tt.fields.err,
message: tt.fields.message,
}
if got := e.Error(); got != tt.want {
t.Errorf("validateAnchorError.Error() = %v, want %v", got, tt.want)
}
})
}
}
func Test_newNegationAnchorError(t *testing.T) {
type args struct {
msg string
}
tests := []struct {
name string
args args
want validateAnchorError
}{{
args: args{
msg: "test",
},
want: validateAnchorError{
err: negationAnchorErr,
message: "negation anchor matched in resource: test",
},
}, {
want: validateAnchorError{
err: negationAnchorErr,
message: "negation anchor matched in resource: ",
},
}}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := newNegationAnchorError(tt.args.msg); !reflect.DeepEqual(got, tt.want) {
t.Errorf("newNegationAnchorError() = %v, want %v", got, tt.want)
}
})
}
}
func Test_newConditionalAnchorError(t *testing.T) {
type args struct {
msg string
}
tests := []struct {
name string
args args
want validateAnchorError
}{{
args: args{
msg: "test",
},
want: validateAnchorError{
err: conditionalAnchorErr,
message: "conditional anchor mismatch: test",
},
}, {
want: validateAnchorError{
err: conditionalAnchorErr,
message: "conditional anchor mismatch: ",
},
}}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := newConditionalAnchorError(tt.args.msg); !reflect.DeepEqual(got, tt.want) {
t.Errorf("newConditionalAnchorError() = %v, want %v", got, tt.want)
}
})
}
}
func Test_newGlobalAnchorError(t *testing.T) {
type args struct {
msg string
}
tests := []struct {
name string
args args
want validateAnchorError
}{{
args: args{
msg: "test",
},
want: validateAnchorError{
err: globalAnchorErr,
message: "global anchor mismatch: test",
},
}, {
want: validateAnchorError{
err: globalAnchorErr,
message: "global anchor mismatch: ",
},
}}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := newGlobalAnchorError(tt.args.msg); !reflect.DeepEqual(got, tt.want) {
t.Errorf("newGlobalAnchorError() = %v, want %v", got, tt.want)
}
})
}
}
func TestIsNegationAnchorError(t *testing.T) {
type args struct {
err error
}
tests := []struct {
name string
args args
want bool
}{{
args: args{
err: nil,
},
want: false,
}, {
args: args{
err: errors.New("negation anchor matched in resource: test"),
},
want: true,
}, {
args: args{
err: newConditionalAnchorError("test"),
},
want: false,
}, {
args: args{
err: newGlobalAnchorError("test"),
},
want: false,
}, {
args: args{
err: newNegationAnchorError("test"),
},
want: true,
}}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := IsNegationAnchorError(tt.args.err); got != tt.want {
t.Errorf("IsNegationAnchorError() = %v, want %v", got, tt.want)
}
})
}
}
func TestIsConditionalAnchorError(t *testing.T) {
type args struct {
err error
}
tests := []struct {
name string
args args
want bool
}{{
args: args{
err: nil,
},
want: false,
}, {
args: args{
err: errors.New("conditional anchor mismatch: test"),
},
want: true,
}, {
args: args{
err: newConditionalAnchorError("test"),
},
want: true,
}, {
args: args{
err: newGlobalAnchorError("test"),
},
want: false,
}, {
args: args{
err: newNegationAnchorError("test"),
},
want: false,
}}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := IsConditionalAnchorError(tt.args.err); got != tt.want {
t.Errorf("IsConditionalAnchorError() = %v, want %v", got, tt.want)
}
})
}
}
func TestIsGlobalAnchorError(t *testing.T) {
type args struct {
err error
}
tests := []struct {
name string
args args
want bool
}{{
args: args{
err: nil,
},
want: false,
}, {
args: args{
err: errors.New("global anchor mismatch: test"),
},
want: true,
}, {
args: args{
err: newConditionalAnchorError("test"),
},
want: false,
}, {
args: args{
err: newGlobalAnchorError("test"),
},
want: true,
}, {
args: args{
err: newNegationAnchorError("test"),
},
want: false,
}}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := IsGlobalAnchorError(tt.args.err); got != tt.want {
t.Errorf("IsGlobalAnchorError() = %v, want %v", got, tt.want)
}
})
}
}