diff --git a/go-chaos/internal/chaos-experiments/camunda-cloud/job-push/cluster-restart.json b/go-chaos/internal/chaos-experiments/camunda-cloud/job-push/cluster-restart.json new file mode 100644 index 000000000..37ed444c4 --- /dev/null +++ b/go-chaos/internal/chaos-experiments/camunda-cloud/job-push/cluster-restart.json @@ -0,0 +1,76 @@ +{ + "version": "0.1.0", + "title": "Job push cluster restart experiment", + "description": "Job workers with streaming enabled should be fault-tolerant. The worker should receive and complete jobs even if all brokers restart.", + "contributions": { + "performance": "high", + "reliability": "high", + "availability": "high" + }, + "steady-state-hypothesis": { + "title": "Zeebe is alive", + "probes": [ + { + "name": "All pods should be ready", + "type": "probe", + "tolerance": 0, + "provider": { + "type": "process", + "path": "zbchaos", + "arguments": ["verify", "readiness"], + "timeout": 900 + } + }, + { + "name": "Can deploy process model", + "type": "probe", + "tolerance": 0, + "provider": { + "type": "process", + "path": "zbchaos", + "arguments": ["deploy", "process"], + "timeout": 900 + } + }, + { + "name": "Can deploy workers", + "type": "probe", + "tolerance": 0, + "provider": { + "type": "process", + "path": "zbchaos", + "arguments": ["deploy", "worker", "--pollingDelay", "86400000"], + "timeout": 900 + }, + "pauses": { + "after": 5 + } + }, + { + "name": "Should be able to create process instances", + "type": "probe", + "tolerance": 0, + "provider": { + "type": "process", + "path": "zbchaos", + "arguments": ["verify", "instance-creation", "--awaitResult"], + "timeout": 900 + } + } + ] + }, + "method": [ + { + "name": "Restart all brokers", + "type": "probe", + "tolerance": 0, + "provider": { + "type": "process", + "path": "zbchaos", + "arguments": ["restart", "broker", "--all"], + "timeout": 900 + } + } + ], + "rollbacks": [] +} diff --git a/go-chaos/internal/chaos-experiments/camunda-cloud/job-push/cluster-terminate.json b/go-chaos/internal/chaos-experiments/camunda-cloud/job-push/cluster-terminate.json new file mode 100644 index 000000000..ed7cf0937 --- /dev/null +++ b/go-chaos/internal/chaos-experiments/camunda-cloud/job-push/cluster-terminate.json @@ -0,0 +1,76 @@ +{ + "version": "0.1.0", + "title": "Job push cluster restart experiment", + "description": "Job workers with streaming enabled should be fault-tolerant. The worker should receive and complete jobs even if all brokers crash.", + "contributions": { + "performance": "high", + "reliability": "high", + "availability": "high" + }, + "steady-state-hypothesis": { + "title": "Zeebe is alive", + "probes": [ + { + "name": "All pods should be ready", + "type": "probe", + "tolerance": 0, + "provider": { + "type": "process", + "path": "zbchaos", + "arguments": ["verify", "readiness"], + "timeout": 900 + } + }, + { + "name": "Can deploy process model", + "type": "probe", + "tolerance": 0, + "provider": { + "type": "process", + "path": "zbchaos", + "arguments": ["deploy", "process"], + "timeout": 900 + } + }, + { + "name": "Can deploy workers", + "type": "probe", + "tolerance": 0, + "provider": { + "type": "process", + "path": "zbchaos", + "arguments": ["deploy", "worker", "--pollingDelay", "86400000"], + "timeout": 900 + }, + "pauses": { + "after": 5 + } + }, + { + "name": "Should be able to create process instances", + "type": "probe", + "tolerance": 0, + "provider": { + "type": "process", + "path": "zbchaos", + "arguments": ["verify", "instance-creation", "--awaitResult"], + "timeout": 900 + } + } + ] + }, + "method": [ + { + "name": "Terminate all brokers", + "type": "probe", + "tolerance": 0, + "provider": { + "type": "process", + "path": "zbchaos", + "arguments": ["terminate", "broker", "--all"], + "timeout": 900 + } + } + ], + "rollbacks": [] +} diff --git a/go-chaos/internal/chaos-experiments/camunda-cloud/job-push-gateway/restart.json b/go-chaos/internal/chaos-experiments/camunda-cloud/job-push/gateway-restart.json similarity index 100% rename from go-chaos/internal/chaos-experiments/camunda-cloud/job-push-gateway/restart.json rename to go-chaos/internal/chaos-experiments/camunda-cloud/job-push/gateway-restart.json diff --git a/go-chaos/internal/chaos-experiments/camunda-cloud/job-push-gateway/terminate.json b/go-chaos/internal/chaos-experiments/camunda-cloud/job-push/gateway-terminate.json similarity index 100% rename from go-chaos/internal/chaos-experiments/camunda-cloud/job-push-gateway/terminate.json rename to go-chaos/internal/chaos-experiments/camunda-cloud/job-push/gateway-terminate.json diff --git a/go-chaos/internal/chaos-experiments/camunda-cloud/manifest.yml b/go-chaos/internal/chaos-experiments/camunda-cloud/manifest.yml index 8f38344fc..5374a1a99 100644 --- a/go-chaos/internal/chaos-experiments/camunda-cloud/manifest.yml +++ b/go-chaos/internal/chaos-experiments/camunda-cloud/manifest.yml @@ -39,11 +39,19 @@ experiments: - path: worker-restart/experiment.json clusterPlans: - production-s - - path: job-push-gateway/restart.json + - path: job-push/gateway-restart.json clusterPlans: - production-s minVersion: 8.4 - - path: job-push-gateway/terminate.json + - path: job-push/gateway-terminate.json + clusterPlans: + - production-s + minVersion: 8.4 + - path: job-push/cluster-restart.json + clusterPlans: + - production-s + minVersion: 8.4 + - path: job-push/cluster-terminate.json clusterPlans: - production-s minVersion: 8.4