apiVersion: argoproj.io/v1alpha1 kind: Workflow metadata: name: argowf-chaos-hello-world-pod-delete labels: subject: "{{workflow.parameters.adminModeNamespace}}_hello-world" spec: entrypoint: argowf-chaos serviceAccountName: argo-chaos securityContext: runAsUser: 1000 runAsNonRoot: true arguments: parameters: - name: adminModeNamespace value: litmus templates: - name: argowf-chaos steps: - - name: install-chaos-faults template: install-chaos-faults - - name: run-chaos template: run-chaos - - name: cleanup-chaos-resources template: cleanup-chaos-resources - name: install-chaos-faults inputs: artifacts: - name: install-chaos-faults path: /tmp/pod-delete.yaml raw: data: | apiVersion: litmuschaos.io/v1alpha1 description: message: | Deletes a pod belonging to a deployment/statefulset/daemonset kind: ChaosExperiment metadata: name: pod-delete spec: definition: scope: Namespaced permissions: - apiGroups: - "" - "apps" - "batch" - "litmuschaos.io" resources: - "deployments" - "jobs" - "pods" - "pods/log" - "events" - "configmaps" - "chaosengines" - "chaosexperiments" - "chaosresults" verbs: - "create" - "list" - "get" - "patch" - "update" - "delete" - apiGroups: - "" resources: - "nodes" verbs: - "get" - "list" image: "litmuschaos/go-runner:latest" imagePullPolicy: Always args: - -c - ./experiments -name pod-delete command: - /bin/bash env: - name: TOTAL_CHAOS_DURATION value: '15' # Period to wait before and after injection of chaos in sec - name: RAMP_TIME value: '' # provide the kill count - name: KILL_COUNT value: '' - name: FORCE value: 'true' - name: CHAOS_INTERVAL value: '5' labels: name: pod-delete container: image: litmuschaos/k8s:latest resources: limits: memory: 128Mi cpu: 50m command: [sh, -c] args: [ "kubectl apply -f /tmp/pod-delete.yaml -n {{workflow.parameters.adminModeNamespace}}", ] - name: run-chaos inputs: artifacts: - name: run-chaos path: /tmp/chaosengine.yaml raw: data: | apiVersion: litmuschaos.io/v1alpha1 kind: ChaosEngine metadata: name: pod-delete-chaos namespace: {{workflow.parameters.adminModeNamespace}} labels: context: "{{workflow.parameters.adminModeNamespace}}_hello-world" annotations: {} spec: appinfo: appns: {{workflow.parameters.adminModeNamespace}} applabel: 'app=hello-world' appkind: deployment jobCleanUpPolicy: retain engineState: 'active' chaosServiceAccount: litmus-namespace-admin experiments: - name: pod-delete spec: components: resources: requests: memory: 128Mi cpu: 50m limits: memory: 128Mi cpu: 50m env: - name: TOTAL_CHAOS_DURATION value: "30" - name: CHAOS_INTERVAL value: "10" - name: FORCE value: "false" container: image: litmuschaos/litmus-checker:latest resources: limits: memory: 128Mi cpu: 50m args: - -file=/tmp/chaosengine.yaml - -saveName=/tmp/engine-name - name: cleanup-chaos-resources container: image: litmuschaos/k8s:latest resources: limits: memory: 128Mi cpu: 50m command: [sh, -c] args: - "kubectl delete chaosengine pod-delete-chaos -n {{workflow.parameters.adminModeNamespace}}"