diff --git a/tests/e2e-chainsaw/v1beta2/setup/redis-replication/chainsaw-test.yaml b/tests/e2e-chainsaw/v1beta2/setup/redis-replication/chainsaw-test.yaml new file mode 100644 index 000000000..b27d60306 --- /dev/null +++ b/tests/e2e-chainsaw/v1beta2/setup/redis-replication/chainsaw-test.yaml @@ -0,0 +1,18 @@ +# 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: + name: redis-replication-setup +spec: + steps: + - try: + - apply: + file: replication.yaml + - assert: + file: ready-sts.yaml + - assert: + file: ready-svc.yaml + - assert: + file: ready-pvc.yaml + diff --git a/tests/e2e-chainsaw/v1beta2/setup/redis-replication/ready-pvc.yaml b/tests/e2e-chainsaw/v1beta2/setup/redis-replication/ready-pvc.yaml new file mode 100644 index 000000000..f57cb3f61 --- /dev/null +++ b/tests/e2e-chainsaw/v1beta2/setup/redis-replication/ready-pvc.yaml @@ -0,0 +1,44 @@ +apiVersion: v1 +kind: PersistentVolumeClaim +metadata: + name: redis-replication-redis-replication-0 + labels: + app: redis-replication + redis_setup_type: replication + role: replication +status: + accessModes: + - ReadWriteOnce + capacity: + storage: 1Gi + phase: Bound +--- +apiVersion: v1 +kind: PersistentVolumeClaim +metadata: + name: redis-replication-redis-replication-1 + labels: + app: redis-replication + redis_setup_type: replication + role: replication +status: + accessModes: + - ReadWriteOnce + capacity: + storage: 1Gi + phase: Bound +--- +apiVersion: v1 +kind: PersistentVolumeClaim +metadata: + name: redis-replication-redis-replication-2 + labels: + app: redis-replication + redis_setup_type: replication + role: replication +status: + accessModes: + - ReadWriteOnce + capacity: + storage: 1Gi + phase: Bound diff --git a/tests/e2e-chainsaw/v1beta2/setup/redis-replication/ready-sts.yaml b/tests/e2e-chainsaw/v1beta2/setup/redis-replication/ready-sts.yaml new file mode 100644 index 000000000..f2ac67b1a --- /dev/null +++ b/tests/e2e-chainsaw/v1beta2/setup/redis-replication/ready-sts.yaml @@ -0,0 +1,19 @@ +apiVersion: apps/v1 +kind: StatefulSet +metadata: + annotations: + redis.opstreelabs.in: "true" + redis.opstreelabs.instance: redis-replication + labels: + app: redis-replication + redis_setup_type: replication + role: replication + name: redis-replication + ownerReferences: + - apiVersion: redis.redis.opstreelabs.in/v1beta2 + controller: true + kind: RedisReplication + name: redis-replication +status: + readyReplicas: 3 + replicas: 3 \ No newline at end of file diff --git a/tests/e2e-chainsaw/v1beta2/setup/redis-replication/ready-svc.yaml b/tests/e2e-chainsaw/v1beta2/setup/redis-replication/ready-svc.yaml new file mode 100644 index 000000000..707a8df9b --- /dev/null +++ b/tests/e2e-chainsaw/v1beta2/setup/redis-replication/ready-svc.yaml @@ -0,0 +1,90 @@ +apiVersion: v1 +kind: Service +metadata: + annotations: + prometheus.io/port: "9121" + prometheus.io/scrape: "true" + redis.opstreelabs.in: "true" + redis.opstreelabs.instance: redis-replication + labels: + app: redis-replication + redis_setup_type: replication + role: replication + name: redis-replication + ownerReferences: + - apiVersion: redis.redis.opstreelabs.in/v1beta2 + controller: true + kind: RedisReplication + name: redis-replication +spec: + ports: + - name: redis-client + port: 6379 + protocol: TCP + targetPort: 6379 + selector: + app: redis-replication + redis_setup_type: replication + role: replication + type: ClusterIP +--- +apiVersion: v1 +kind: Service +metadata: + annotations: + prometheus.io/port: "9121" + prometheus.io/scrape: "true" + redis.opstreelabs.in: "true" + redis.opstreelabs.instance: redis-replication + labels: + app: redis-replication + redis_setup_type: replication + role: replication + name: redis-replication-additional + ownerReferences: + - apiVersion: redis.redis.opstreelabs.in/v1beta2 + controller: true + kind: RedisReplication + name: redis-replication +spec: + ports: + - name: redis-client + port: 6379 + protocol: TCP + targetPort: 6379 + selector: + app: redis-replication + redis_setup_type: replication + role: replication + type: ClusterIP +--- +apiVersion: v1 +kind: Service +metadata: + annotations: + prometheus.io/port: "9121" + prometheus.io/scrape: "true" + redis.opstreelabs.in: "true" + redis.opstreelabs.instance: redis-replication + labels: + app: redis-replication + redis_setup_type: replication + role: replication + name: redis-replication-headless + ownerReferences: + - apiVersion: redis.redis.opstreelabs.in/v1beta2 + controller: true + kind: RedisReplication + name: redis-replication +spec: + clusterIP: None + ports: + - name: redis-client + port: 6379 + protocol: TCP + targetPort: 6379 + selector: + app: redis-replication + redis_setup_type: replication + role: replication + type: ClusterIP \ No newline at end of file diff --git a/tests/e2e-chainsaw/v1beta2/setup/redis-replication/replication.yaml b/tests/e2e-chainsaw/v1beta2/setup/redis-replication/replication.yaml new file mode 100644 index 000000000..3fb33dcac --- /dev/null +++ b/tests/e2e-chainsaw/v1beta2/setup/redis-replication/replication.yaml @@ -0,0 +1,27 @@ +--- +apiVersion: redis.redis.opstreelabs.in/v1beta2 +kind: RedisReplication +metadata: + name: redis-replication +spec: + clusterSize: 3 + podSecurityContext: + runAsUser: 1000 + fsGroup: 1000 + kubernetesConfig: + image: quay.io/opstree/redis:latest + imagePullPolicy: Always + resources: + requests: + cpu: 101m + memory: 128Mi + limits: + cpu: 101m + memory: 128Mi + storage: + volumeClaimTemplate: + spec: + accessModes: ["ReadWriteOnce"] + resources: + requests: + storage: 1Gi \ No newline at end of file