node_bench_test.go 739 B

123456789101112131415161718192021222324252627282930313233343536373839
  1. package rafttest
  2. import (
  3. "testing"
  4. "time"
  5. "github.com/coreos/etcd/Godeps/_workspace/src/golang.org/x/net/context"
  6. "github.com/coreos/etcd/raft"
  7. )
  8. func BenchmarkProposal3Nodes(b *testing.B) {
  9. peers := []raft.Peer{{1, nil}, {2, nil}, {3, nil}}
  10. nt := newRaftNetwork(1, 2, 3)
  11. nodes := make([]*node, 0)
  12. for i := 1; i <= 3; i++ {
  13. n := startNode(uint64(i), peers, nt.nodeNetwork(uint64(i)))
  14. nodes = append(nodes, n)
  15. }
  16. // get ready and warm up
  17. time.Sleep(50 * time.Millisecond)
  18. b.ResetTimer()
  19. for i := 0; i < b.N; i++ {
  20. nodes[0].Propose(context.TODO(), []byte("somedata"))
  21. }
  22. for _, n := range nodes {
  23. if n.state.Commit != uint64(b.N+4) {
  24. continue
  25. }
  26. }
  27. b.StopTimer()
  28. for _, n := range nodes {
  29. n.stop()
  30. }
  31. }