mirror of
https://github.com/kyverno/kyverno.git
synced 2025-03-31 03:45:17 +00:00
CR comments
This commit is contained in:
parent
d88b0bf2e4
commit
a5ce084da4
4 changed files with 15 additions and 53 deletions
|
@ -65,8 +65,6 @@ type RuleResponse struct {
|
|||
Success bool `json:"success"`
|
||||
// statistics
|
||||
RuleStats `json:",inline"`
|
||||
// PathNotPresent indicates whether referenced path in variable substitution exist
|
||||
PathNotPresent bool `json:"pathNotPresent"`
|
||||
}
|
||||
|
||||
//ToString ...
|
||||
|
@ -121,13 +119,3 @@ func (er EngineResponse) getRules(success bool) []string {
|
|||
}
|
||||
return rules
|
||||
}
|
||||
|
||||
// IsPathNotPresent checks if the referenced path(in variable substitution) exist
|
||||
func (er EngineResponse) IsPathNotPresent() bool {
|
||||
for _, r := range er.PolicyResponse.Rules {
|
||||
if r.PathNotPresent {
|
||||
return true
|
||||
}
|
||||
}
|
||||
return false
|
||||
}
|
||||
|
|
|
@ -5,18 +5,6 @@ import (
|
|||
"strconv"
|
||||
)
|
||||
|
||||
//ValidationFailureReason defeins type for Validation Failure reason
|
||||
type ValidationFailureReason int
|
||||
|
||||
const (
|
||||
// PathNotPresent if path is not present
|
||||
PathNotPresent ValidationFailureReason = iota
|
||||
// Rulefailure if the rule failed
|
||||
Rulefailure
|
||||
// OtherError if there is any other type of error
|
||||
OtherError
|
||||
)
|
||||
|
||||
// convertToString converts value to string
|
||||
func convertToString(value interface{}) (string, error) {
|
||||
switch typed := value.(type) {
|
||||
|
@ -46,14 +34,3 @@ func getRawKeyIfWrappedWithAttributes(str string) string {
|
|||
return str
|
||||
}
|
||||
}
|
||||
|
||||
//ValidationError stores error for validation error
|
||||
type ValidationError struct {
|
||||
StatusCode ValidationFailureReason
|
||||
ErrorMsg string
|
||||
}
|
||||
|
||||
// newValidatePatternError returns an validation error using the ValidationFailureReason and errorMsg
|
||||
func newValidatePatternError(reason ValidationFailureReason, msg string) ValidationError {
|
||||
return ValidationError{StatusCode: reason, ErrorMsg: msg}
|
||||
}
|
||||
|
|
|
@ -16,8 +16,8 @@ func GeneratePVsFromEngineResponse(ers []response.EngineResponse) (pvInfos []Inf
|
|||
glog.V(4).Infof("resource %v, has not been assigned a name, not creating a policy violation for it", er.PolicyResponse.Resource)
|
||||
continue
|
||||
}
|
||||
// skip when response succeed AND referenced paths exist
|
||||
if er.IsSuccesful() && !er.IsPathNotPresent() {
|
||||
// skip when response succeed
|
||||
if er.IsSuccesful() {
|
||||
continue
|
||||
}
|
||||
glog.V(4).Infof("Building policy violation for engine response %v", er)
|
||||
|
@ -82,7 +82,7 @@ func buildPVInfo(er response.EngineResponse) Info {
|
|||
func buildViolatedRules(er response.EngineResponse) []kyverno.ViolatedRule {
|
||||
var violatedRules []kyverno.ViolatedRule
|
||||
for _, rule := range er.PolicyResponse.Rules {
|
||||
if rule.Success && !rule.PathNotPresent {
|
||||
if rule.Success {
|
||||
continue
|
||||
}
|
||||
vrule := kyverno.ViolatedRule{
|
||||
|
|
|
@ -19,17 +19,15 @@ func Test_GeneratePVsFromEngineResponse_PathNotExist(t *testing.T) {
|
|||
},
|
||||
Rules: []response.RuleResponse{
|
||||
{
|
||||
Name: "test-path-not-exist",
|
||||
Type: "Mutation",
|
||||
Message: "referenced paths are not present: request.object.metadata.name1",
|
||||
Success: true,
|
||||
PathNotPresent: true,
|
||||
Name: "test-path-not-exist",
|
||||
Type: "Mutation",
|
||||
Message: "referenced paths are not present: request.object.metadata.name1",
|
||||
Success: false,
|
||||
},
|
||||
{
|
||||
Name: "test-path-exist",
|
||||
Type: "Mutation",
|
||||
Success: true,
|
||||
PathNotPresent: false,
|
||||
Name: "test-path-exist",
|
||||
Type: "Mutation",
|
||||
Success: true,
|
||||
},
|
||||
},
|
||||
},
|
||||
|
@ -44,11 +42,10 @@ func Test_GeneratePVsFromEngineResponse_PathNotExist(t *testing.T) {
|
|||
},
|
||||
Rules: []response.RuleResponse{
|
||||
{
|
||||
Name: "test-path-not-exist-across-policy",
|
||||
Type: "Mutation",
|
||||
Message: "referenced paths are not present: request.object.metadata.name1",
|
||||
Success: true,
|
||||
PathNotPresent: true,
|
||||
Name: "test-path-not-exist-across-policy",
|
||||
Type: "Mutation",
|
||||
Message: "referenced paths are not present: request.object.metadata.name1",
|
||||
Success: true,
|
||||
},
|
||||
},
|
||||
},
|
||||
|
@ -56,5 +53,5 @@ func Test_GeneratePVsFromEngineResponse_PathNotExist(t *testing.T) {
|
|||
}
|
||||
|
||||
pvInfos := GeneratePVsFromEngineResponse(ers)
|
||||
assert.Assert(t, len(pvInfos) == 2)
|
||||
assert.Assert(t, len(pvInfos) == 1)
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue