Skip to content

Commit b157c31

Browse files
[Add] CEL rules for validating App and PackageInstall Spec
This PR: - Adds KB marker to ensure that either spec.ServiceAccount or spec.Cluster is present in App and PackageInstall CR. - Bumps controller-tools to 0.10.0 to support CEL based validation marker. That is the latest version compatible with the k8s release the project is currently at. Signed-off-by: Varsha Prasad Narsing <[email protected]>
1 parent 5b1294b commit b157c31

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

46 files changed

+782
-214
lines changed

config/config/crds.yml

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1434,6 +1434,9 @@ spec:
14341434
required:
14351435
- spec
14361436
type: object
1437+
x-kubernetes-validations:
1438+
- message: Expected service account or cluster.
1439+
rule: has(self.spec.serviceAccountName) || has(self.spec.cluster)
14371440
served: true
14381441
storage: true
14391442
subresources:
@@ -1594,6 +1597,9 @@ spec:
15941597
required:
15951598
- spec
15961599
type: object
1600+
x-kubernetes-validations:
1601+
- message: Expected service account or cluster.
1602+
rule: has(self.spec.serviceAccountName) || has(self.spec.cluster)
15971603
served: true
15981604
storage: true
15991605
subresources:

go.mod

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -22,7 +22,7 @@ require (
2222
k8s.io/kube-aggregator v0.22.17
2323
k8s.io/kube-openapi v0.0.0-20220803162953-67bda5d908f1
2424
sigs.k8s.io/controller-runtime v0.13.1
25-
sigs.k8s.io/controller-tools v0.7.0
25+
sigs.k8s.io/controller-tools v0.10.0
2626
sigs.k8s.io/yaml v1.3.0
2727
)
2828

@@ -61,7 +61,7 @@ require (
6161
github.com/go-openapi/jsonpointer v0.19.5 // indirect
6262
github.com/go-openapi/jsonreference v0.19.6 // indirect
6363
github.com/go-openapi/swag v0.19.15 // indirect
64-
github.com/gobuffalo/flect v0.2.3 // indirect
64+
github.com/gobuffalo/flect v0.2.5 // indirect
6565
github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect
6666
github.com/golang/protobuf v1.5.2 // indirect
6767
github.com/google/gnostic v0.5.7-v3refs // indirect

go.sum

Lines changed: 4 additions & 51 deletions
Large diffs are not rendered by default.

pkg/apis/kappctrl/v1alpha1/types.go

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,7 @@ import (
1414
// +kubebuilder:printcolumn:name=Description,JSONPath=.status.friendlyDescription,description=Friendly description,type=string
1515
// +kubebuilder:printcolumn:name=Since-Deploy,JSONPath=.status.deploy.startedAt,description=Last time app started being deployed. Does not mean anything was changed.,type=date
1616
// +kubebuilder:printcolumn:name=Age,JSONPath=.metadata.creationTimestamp,description=Time since creation,type=date
17+
// +kubebuilder:validation:XValidation:rule="has(self.spec.serviceAccountName) || has(self.spec.cluster)", message="Expected service account or cluster."
1718
// +protobuf=false
1819
// An App is a set of Kubernetes resources. These resources could span any number of namespaces or could be cluster-wide (e.g. CRDs). An App is represented in kapp-controller using a App CR.
1920
// The App CR comprises of three main sections:

pkg/apis/packaging/v1alpha1/package_install.go

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,7 @@ import (
1717
// +kubebuilder:printcolumn:name=Package version,JSONPath=.status.version,description=PackageMetadata version,type=string
1818
// +kubebuilder:printcolumn:name=Description,JSONPath=.status.friendlyDescription,description=Friendly description,type=string
1919
// +kubebuilder:printcolumn:name=Age,JSONPath=.metadata.creationTimestamp,description=Time since creation,type=date
20+
// +kubebuilder:validation:XValidation:rule="has(self.spec.serviceAccountName) || has(self.spec.cluster)", message="Expected service account or cluster."
2021
// A Package Install is an actual installation of a package and its underlying resources on a Kubernetes cluster.
2122
// It is represented in kapp-controller by a PackageInstall CR.
2223
// A PackageInstall CR must reference a Package CR.

test/e2e/kappcontroller/packageinstall_test.go

Lines changed: 61 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -950,3 +950,64 @@ spec:
950950
assert.Equal(t, actualSyncPeriod, expectedSyncPeriod)
951951
})
952952
}
953+
954+
955+
func TestCELValidation(t *testing.T) {
956+
env := e2e.BuildEnv(t)
957+
logger := e2e.Logger{}
958+
kapp := e2e.Kapp{t, env.Namespace, logger}
959+
kubectl := e2e.Kubectl{t, env.Namespace, logger}
960+
961+
name := "incorrect-spec-without-sa-cluster"
962+
963+
appYAML := fmt.Sprintf(`
964+
---
965+
apiVersion: kappctrl.k14s.io/v1alpha1
966+
kind: App
967+
metadata:
968+
name: %s
969+
annotations:
970+
kapp.k14s.io/change-group: kappctrl-e2e.k14s.io/apps
971+
spec:
972+
fetch:
973+
- inline:
974+
paths:
975+
file.yml: |
976+
apiVersion: v1
977+
kind: ConfigMap
978+
metadata:
979+
name: configmap
980+
template:
981+
- ytt: {}
982+
deploy:
983+
- kapp: {}
984+
`, name)
985+
986+
pkginstallYAML := fmt.Sprintf(`
987+
---
988+
apiVersion: packaging.carvel.dev/v1alpha1
989+
kind: PackageInstall
990+
metadata:
991+
name: %[2]s
992+
namespace: %[1]s
993+
annotations:
994+
kapp.k14s.io/change-group: kappctrl-e2e.k14s.io/packageinstalls
995+
spec:
996+
packageRef:
997+
refName: pkg.incorrect.carvel.dev
998+
versionSelection:
999+
constraints: 1.0.0
1000+
`, env.Namespace, name)
1001+
1002+
logger.Section("Create App CR with kubectl", func() {
1003+
_, err := kubectl.RunWithOpts([]string{"apply", "-f", "-"}, e2e.RunOpts{StdinReader: strings.NewReader(appYAML), AllowError: true})
1004+
require.Error(t, err)
1005+
require.ErrorContains(t, err, "Expected service account or cluster.")
1006+
})
1007+
1008+
logger.Section("Create PackageInstall with kapp", func() {
1009+
_, err := kapp.RunWithOpts([]string{"deploy", "-a", name, "-f", "-"}, e2e.RunOpts{StdinReader: strings.NewReader(pkginstallYAML), AllowError: true})
1010+
require.Error(t, err)
1011+
require.ErrorContains(t, err, "Expected service account or cluster.")
1012+
})
1013+
}

vendor/github.com/gobuffalo/flect/camelize.go

Lines changed: 0 additions & 4 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

vendor/github.com/gobuffalo/flect/pascalize.go

Lines changed: 9 additions & 2 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

vendor/github.com/gobuffalo/flect/plural_rules.go

Lines changed: 7 additions & 8 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

vendor/github.com/gobuffalo/flect/singular_rules.go

Lines changed: 4 additions & 4 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

vendor/modules.txt

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -79,7 +79,7 @@ github.com/go-openapi/jsonreference
7979
# github.com/go-openapi/swag v0.19.15
8080
## explicit; go 1.11
8181
github.com/go-openapi/swag
82-
# github.com/gobuffalo/flect v0.2.3
82+
# github.com/gobuffalo/flect v0.2.5
8383
## explicit; go 1.13
8484
github.com/gobuffalo/flect
8585
# github.com/gogo/protobuf v1.3.2
@@ -1248,8 +1248,8 @@ sigs.k8s.io/controller-runtime/pkg/source/internal
12481248
sigs.k8s.io/controller-runtime/pkg/webhook
12491249
sigs.k8s.io/controller-runtime/pkg/webhook/admission
12501250
sigs.k8s.io/controller-runtime/pkg/webhook/internal/metrics
1251-
# sigs.k8s.io/controller-tools v0.7.0
1252-
## explicit; go 1.16
1251+
# sigs.k8s.io/controller-tools v0.10.0
1252+
## explicit; go 1.19
12531253
sigs.k8s.io/controller-tools/cmd/controller-gen
12541254
sigs.k8s.io/controller-tools/pkg/crd
12551255
sigs.k8s.io/controller-tools/pkg/crd/markers

vendor/sigs.k8s.io/controller-tools/cmd/controller-gen/main.go

Lines changed: 1 addition & 1 deletion
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

vendor/sigs.k8s.io/controller-tools/pkg/crd/doc.go

Lines changed: 4 additions & 4 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

vendor/sigs.k8s.io/controller-tools/pkg/crd/flatten.go

Lines changed: 4 additions & 0 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

vendor/sigs.k8s.io/controller-tools/pkg/crd/gen.go

Lines changed: 33 additions & 6 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

0 commit comments

Comments
 (0)