Skip to content

Commit

Permalink
fix: fixing nil pointer error when converting VAPB from v1beta1 to v1 (
Browse files Browse the repository at this point in the history
…open-policy-agent#3754)

Signed-off-by: Jaydip Gabani <[email protected]>
(cherry picked from commit 14e6c8a)
  • Loading branch information
JaydipGabani committed Jan 18, 2025
1 parent e8d5d49 commit 5a95c29
Show file tree
Hide file tree
Showing 2 changed files with 103 additions and 0 deletions.
1 change: 1 addition & 0 deletions pkg/controller/constraint/constraint_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -787,6 +787,7 @@ func v1beta1ToV1(v1beta1Obj *admissionregistrationv1beta1.ValidatingAdmissionPol

obj.Spec.ValidationActions = actions
if v1beta1Obj.Spec.MatchResources != nil {
obj.Spec.MatchResources = &admissionregistrationv1.MatchResources{}
if v1beta1Obj.Spec.MatchResources.ObjectSelector != nil {
obj.Spec.MatchResources.ObjectSelector = v1beta1Obj.Spec.MatchResources.ObjectSelector
}
Expand Down
102 changes: 102 additions & 0 deletions pkg/controller/constraint/constraint_controller_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package constraint

import (
"errors"
"fmt"
"reflect"
"strings"
"testing"
Expand All @@ -12,9 +13,12 @@ import (
celSchema "github.com/open-policy-agent/frameworks/constraint/pkg/client/drivers/k8scel/schema"
regoSchema "github.com/open-policy-agent/frameworks/constraint/pkg/client/drivers/rego/schema"
"github.com/open-policy-agent/frameworks/constraint/pkg/core/templates"
"github.com/open-policy-agent/frameworks/constraint/pkg/client/drivers/k8scel/transform"
"github.com/open-policy-agent/gatekeeper/v3/pkg/metrics"
"github.com/open-policy-agent/gatekeeper/v3/pkg/target"
"github.com/open-policy-agent/gatekeeper/v3/pkg/util"
admissionregistrationv1 "k8s.io/api/admissionregistration/v1"
admissionregistrationv1beta1 "k8s.io/api/admissionregistration/v1beta1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/apis/meta/v1/unstructured"
"k8s.io/utils/ptr"
Expand Down Expand Up @@ -534,3 +538,101 @@ func TestShouldGenerateVAP(t *testing.T) {
})
}
}
func TestV1beta1ToV1(t *testing.T) {
tests := []struct {
name string
v1beta1Obj *admissionregistrationv1beta1.ValidatingAdmissionPolicyBinding
expectedObj *admissionregistrationv1.ValidatingAdmissionPolicyBinding
expectedError error
}{
{
name: "valid conversion",
v1beta1Obj: &admissionregistrationv1beta1.ValidatingAdmissionPolicyBinding{
ObjectMeta: metav1.ObjectMeta{
Name: "test-binding",
},
Spec: admissionregistrationv1beta1.ValidatingAdmissionPolicyBindingSpec{
PolicyName: "test-policy",
ParamRef: &admissionregistrationv1beta1.ParamRef{
Name: "test-param",
},
ValidationActions: []admissionregistrationv1beta1.ValidationAction{
admissionregistrationv1beta1.Deny,
admissionregistrationv1beta1.Warn,
},
MatchResources: &admissionregistrationv1beta1.MatchResources{
ObjectSelector: &metav1.LabelSelector{
MatchLabels: map[string]string{"key": "value"},
},
NamespaceSelector: &metav1.LabelSelector{
MatchLabels: map[string]string{"key": "value"},
},
},
},
},
expectedObj: &admissionregistrationv1.ValidatingAdmissionPolicyBinding{
ObjectMeta: metav1.ObjectMeta{
Name: "test-binding",
},
Spec: admissionregistrationv1.ValidatingAdmissionPolicyBindingSpec{
PolicyName: "test-policy",
ParamRef: &admissionregistrationv1.ParamRef{
Name: "test-param",
ParameterNotFoundAction: ptr.To[admissionregistrationv1.ParameterNotFoundActionType](admissionregistrationv1.AllowAction),
},
ValidationActions: []admissionregistrationv1.ValidationAction{
admissionregistrationv1.Deny,
admissionregistrationv1.Warn,
},
MatchResources: &admissionregistrationv1.MatchResources{
ObjectSelector: &metav1.LabelSelector{
MatchLabels: map[string]string{"key": "value"},
},
NamespaceSelector: &metav1.LabelSelector{
MatchLabels: map[string]string{"key": "value"},
},
},
},
},
expectedError: nil,
},
{
name: "unrecognized enforcement action",
v1beta1Obj: &admissionregistrationv1beta1.ValidatingAdmissionPolicyBinding{
ObjectMeta: metav1.ObjectMeta{
Name: "test-binding",
},
Spec: admissionregistrationv1beta1.ValidatingAdmissionPolicyBindingSpec{
PolicyName: "test-policy",
ParamRef: &admissionregistrationv1beta1.ParamRef{
Name: "test-param",
},
ValidationActions: []admissionregistrationv1beta1.ValidationAction{
"unknown",
},
},
},
expectedObj: nil,
expectedError: fmt.Errorf("%w: unrecognized enforcement action unknown, must be `warn` or `deny`", transform.ErrBadEnforcementAction),
},
}

for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
obj, err := v1beta1ToV1(tt.v1beta1Obj)
if err != nil && tt.expectedError == nil {
t.Fatalf("expected no error, got %v", err)
}
if err == nil && tt.expectedError != nil {
t.Fatalf("expected error %v, got none", tt.expectedError)
}
if err != nil && tt.expectedError != nil && err.Error() != tt.expectedError.Error() {
t.Fatalf("expected error %v, got %v", tt.expectedError, err)
}
if !reflect.DeepEqual(obj, tt.expectedObj) {
t.Errorf("expected object %v, got %v", tt.expectedObj, obj)
}
})
}
}

0 comments on commit 5a95c29

Please sign in to comment.