Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add other policies in CEL expressions - Part 3 #961

Merged
merged 18 commits into from
May 15, 2024
Merged
Show file tree
Hide file tree
Changes from 11 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@ jobs:
- ^other$/^re[c-q]
- ^other$/^res
- ^other$/^[s-z]
- ^other-cel$/^[m-q]
- ^pod-security$
- ^pod-security-cel$
- ^psa$
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
apiVersion: kyverno.io/v1
kind: ClusterPolicy
metadata:
name: memory-requests-equal-limits
status:
ready: true
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
# yaml-language-server: $schema=https://raw.githubusercontent.com/kyverno/chainsaw/main/.schemas/json/test-chainsaw-v1alpha1.json
apiVersion: chainsaw.kyverno.io/v1alpha1
kind: Test
metadata:
creationTimestamp: null
name: memory-requests-equal-limits
spec:
steps:
- name: step-01
try:
- apply:
file: ../memory-requests-equal-limits.yaml
- patch:
resource:
apiVersion: kyverno.io/v1
kind: ClusterPolicy
metadata:
name: memory-requests-equal-limits
spec:
validationFailureAction: Enforce
- assert:
file: chainsaw-step-01-assert-1.yaml
- name: step-02
try:
- apply:
file: pod-good.yaml
- apply:
expect:
- check:
($error != null): true
file: pod-bad.yaml
- apply:
file: podcontroller-good.yaml
- apply:
expect:
- check:
($error != null): true
file: podcontroller-bad.yaml
76 changes: 76 additions & 0 deletions other-cel/memory-requests-equal-limits/.chainsaw-test/pod-bad.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
apiVersion: v1
kind: Pod
metadata:
name: badpod01
spec:
containers:
- name: busybox
image: busybox:1.35
resources:
requests:
memory: "100Mi"
limits:
memory: "200Mi"
---
apiVersion: v1
kind: Pod
metadata:
name: badpod02
spec:
containers:
- name: busybox
image: busybox:1.35
resources:
requests:
memory: "10Mi"
limits:
memory: "140Mi"
- name: busybox02
image: busybox:1.35
resources:
requests:
memory: "100Mi"
limits:
memory: "150Mi"
---
apiVersion: v1
kind: Pod
metadata:
name: badpod03
spec:
containers:
- name: busybox
image: busybox:1.35
resources:
requests:
memory: "120Mi"
limits:
memory: "120Mi"
- name: busybox02
image: busybox:1.35
resources:
requests:
memory: "100Mi"
limits:
memory: "150Mi"
---
apiVersion: v1
kind: Pod
metadata:
name: badpod04
spec:
containers:
- name: busybox02
image: busybox:1.35
resources:
requests:
memory: "100Mi"
limits:
memory: "200Mi"
- name: busybox
image: busybox:1.35
resources:
requests:
memory: "100Mi"
limits:
memory: "100Mi"
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
apiVersion: v1
kind: Pod
metadata:
name: goodpod00
spec:
containers:
- name: busybox
image: busybox:1.35
---
apiVersion: v1
kind: Pod
metadata:
name: goodpod01
spec:
containers:
- name: busybox
image: busybox:1.35
resources:
requests:
memory: "100Mi"
limits:
memory: "100Mi"
---
apiVersion: v1
kind: Pod
metadata:
name: goodpod02
spec:
containers:
- name: busybox
image: busybox:1.35
resources:
requests:
memory: "100Mi"
limits:
memory: "100Mi"
- name: busybox02
image: busybox:1.35
- name: busybox03
image: busybox:1.35
resources:
requests:
memory: "50Mi"
limits:
memory: "50Mi"
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: busybox
name: baddeployment01
spec:
replicas: 1
selector:
matchLabels:
app: busybox
strategy: {}
template:
metadata:
labels:
app: busybox
spec:
containers:
- name: busybox
image: busybox:1.35
resources:
requests:
memory: "10Mi"
limits:
memory: "140Mi"
- name: busybox02
image: busybox:1.35
resources:
requests:
memory: "100Mi"
limits:
memory: "150Mi"
---
apiVersion: batch/v1
kind: CronJob
metadata:
name: badcronjob01
spec:
schedule: "* * * * *"
jobTemplate:
spec:
template:
spec:
containers:
- name: busybox
image: busybox:1.35
resources:
requests:
memory: "10Mi"
limits:
memory: "140Mi"
- name: busybox02
image: busybox:1.35
resources:
requests:
memory: "100Mi"
limits:
memory: "150Mi"
restartPolicy: OnFailure
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: busybox
name: gooddeployment01
spec:
replicas: 1
selector:
matchLabels:
app: busybox
strategy: {}
template:
metadata:
labels:
app: busybox
spec:
containers:
- name: busybox
image: busybox:1.35
resources:
requests:
memory: "100Mi"
limits:
memory: "100Mi"
- name: busybox02
image: busybox:1.35
- name: busybox03
image: busybox:1.35
resources:
requests:
memory: "50Mi"
limits:
memory: "50Mi"
---
apiVersion: batch/v1
kind: CronJob
metadata:
name: goodcronjob01
spec:
schedule: "* * * * *"
jobTemplate:
spec:
template:
spec:
containers:
- name: busybox
image: busybox:1.35
resources:
requests:
memory: "100Mi"
limits:
memory: "100Mi"
- name: busybox02
image: busybox:1.35
- name: busybox03
image: busybox:1.35
resources:
requests:
memory: "50Mi"
limits:
memory: "50Mi"
restartPolicy: OnFailure
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
apiVersion: cli.kyverno.io/v1alpha1
kind: Test
metadata:
name: memory-requests-equal-limits
policies:
- ../memory-requests-equal-limits.yaml
resources:
- resource.yaml
results:
- kind: CronJob
policy: memory-requests-equal-limits
resources:
- hello
result: pass
rule: autogen-cronjob-memory-requests-equal-limits
- kind: DaemonSet
policy: memory-requests-equal-limits
resources:
- fluentd-elasticsearch
result: pass
rule: autogen-memory-requests-equal-limits
- kind: Pod
policy: memory-requests-equal-limits
resources:
- myapp-pod
result: fail
rule: memory-requests-equal-limits
Loading
Loading