MIT6.824 Lab2 Raft(3)

  最后一部分介绍一下测试代码中的测试函数。
  紧接着上次,现在是TestFailNoAgree函数测试在节点Fail太多的情况下无法达成一致性。

func TestFailNoAgree(t *testing.T) {
    servers := 5
    cfg := make_config(t, servers, false)
    defer cfg.cleanup()

    fmt.Printf("Test: no agreement if too many followers fail ...\n")

    cfg.one(10, servers)

    // 3 of 5 followers disconnect
    leader := cfg.checkOneLeader()
    cfg.disconnect((leader + 1) % servers)
    cfg.disconnect((leader + 2) % servers)
    cfg.disconnect((leader + 3) % servers)

    index, _, ok := cfg.rafts[leader].Start(20)
    if ok != true {
        t.Fatalf("leader rejected Start()")
    }
    if index != 2 {
        t.Fatalf("expected index 2, got %v", index)
    }

    time.Sleep(2 * RaftElectionTimeout)

    n, _ := cfg.nCommitted(index)
    if n > 0 {
        t.Fatalf("%v committed but no majority", n)
    }

    // repair failures
    cfg.connect((leader + 1) % servers)
    cfg.connect((leader + 2) % servers)
    cfg.connect((leader + 3) % servers)

    // the disconnected majority may have chosen a leader from
    // among their own ranks, forgetting index 2.
    // or perhaps
    leader2 := cfg.checkOneLeader()
    index2, _, ok2 := cfg.rafts[leader2].Start(30)
    if ok2 == false {
        t.Fatalf("leader2 rejected Start()")
    }
    if index2 <
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值