Gyuho Lee 09a4e059c5 functional-tester/rpcpb: rename "AdvertisePeerURLs", add more tests 7 年之前
..
agent 35d8bc2616 functional-tester: use updated latency for delay network case 7 年之前
cmd 3fe077746f functional-tester/cmd/etcd-tester: add wait health logging 7 年之前
rpcpb 09a4e059c5 functional-tester/rpcpb: rename "AdvertisePeerURLs", add more tests 7 年之前
runner e170d40f90 functional-tester: move "etcd-runner" to "./cmd" 7 年之前
scripts bb73145565 functional-tester: update local test scripts with docker 7 年之前
tester ea4effce84 functional-tester/tester: add randomize delay 7 年之前
README.md 13bf22ba51 functional-tester: update README 7 年之前
build 586a253943 functional-tester: update build paths 7 年之前

README.md

etcd functional test suite

etcd functional test suite tests the functionality of an etcd cluster with a focus on failure resistance under high pressure. It sets up an etcd cluster and inject failures into the cluster by killing the process or isolate the network of the process. It expects the etcd cluster to recover within a short amount of time after fixing the fault.

etcd functional test suite has two components: etcd-agent and etcd-tester. etcd-agent runs on every test machine, and etcd-tester is a single controller of the test. tester controls agents: start etcd process, stop, terminate, inject failures, and so on.

Run locally

PASSES=functional ./test

Run with Docker

To run locally, first build tester image:

pushd ../..
make build-docker-functional-tester
popd

And run example scripts.

# run 3 agents for 3-node local etcd cluster
./scripts/docker-local-agent.sh 1
./scripts/docker-local-agent.sh 2
./scripts/docker-local-agent.sh 3

# to run only 1 tester round
./scripts/docker-local-tester.sh