|
|
@@ -27,8 +27,47 @@ func TestBasicProgress(t *testing.T) {
|
|
|
time.Sleep(100 * time.Millisecond)
|
|
|
for _, n := range nodes {
|
|
|
n.stop()
|
|
|
- if n.state.Commit < 1000 {
|
|
|
- t.Errorf("commit = %d, want > 1000", n.state.Commit)
|
|
|
+ if n.state.Commit != 1006 {
|
|
|
+ t.Errorf("commit = %d, want = 1006", n.state.Commit)
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+func TestRestart(t *testing.T) {
|
|
|
+ peers := []raft.Peer{{1, nil}, {2, nil}, {3, nil}, {4, nil}, {5, nil}}
|
|
|
+ nt := newRaftNetwork(1, 2, 3, 4, 5)
|
|
|
+
|
|
|
+ nodes := make([]*node, 0)
|
|
|
+
|
|
|
+ for i := 1; i <= 5; i++ {
|
|
|
+ n := startNode(uint64(i), peers, nt.nodeNetwork(uint64(i)))
|
|
|
+ nodes = append(nodes, n)
|
|
|
+ }
|
|
|
+
|
|
|
+ time.Sleep(50 * time.Millisecond)
|
|
|
+ for i := 0; i < 300; i++ {
|
|
|
+ nodes[0].Propose(context.TODO(), []byte("somedata"))
|
|
|
+ }
|
|
|
+ nodes[1].stop()
|
|
|
+ for i := 0; i < 300; i++ {
|
|
|
+ nodes[0].Propose(context.TODO(), []byte("somedata"))
|
|
|
+ }
|
|
|
+ nodes[2].stop()
|
|
|
+ for i := 0; i < 300; i++ {
|
|
|
+ nodes[0].Propose(context.TODO(), []byte("somedata"))
|
|
|
+ }
|
|
|
+ nodes[2].restart()
|
|
|
+ for i := 0; i < 300; i++ {
|
|
|
+ nodes[0].Propose(context.TODO(), []byte("somedata"))
|
|
|
+ }
|
|
|
+ nodes[1].restart()
|
|
|
+
|
|
|
+ // give some time for nodes to catch up with the raft leader
|
|
|
+ time.Sleep(300 * time.Millisecond)
|
|
|
+ for _, n := range nodes {
|
|
|
+ n.stop()
|
|
|
+ if n.state.Commit != 1206 {
|
|
|
+ t.Errorf("commit = %d, want = 1206", n.state.Commit)
|
|
|
}
|
|
|
}
|
|
|
}
|