本文整理汇总了Golang中testing.T.joinAgreement方法的典型用法代码示例。如果您正苦于以下问题:Golang T.joinAgreement方法的具体用法?Golang T.joinAgreement怎么用?Golang T.joinAgreement使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类testing.T
的用法示例。
在下文中一共展示了T.joinAgreement方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: TestTribeMembership
func TestTribeMembership(t *testing.T) {
numOfTribes := 5
tribes := getTribes(numOfTribes, nil)
Convey(fmt.Sprintf("%d tribes are started", numOfTribes), t, func() {
for i := 0; i < numOfTribes; i++ {
log.Debugf("%v is reporting %v members", i, len(tribes[i].memberlist.Members()))
So(len(tribes[0].memberlist.Members()), ShouldEqual, len(tribes[i].memberlist.Members()))
}
Convey("The cluster agrees on membership", func() {
for i := 0; i < numOfTribes; i++ {
So(
len(tribes[0].memberlist.Members()),
ShouldEqual,
len(tribes[i].memberlist.Members()),
)
So(len(tribes[0].members), ShouldEqual, len(tribes[i].members))
}
Convey("Adds an agreement", func(c C) {
a := "agreement1"
t := tribes[numOfTribes-1]
t.AddAgreement("agreement1")
var wg sync.WaitGroup
for _, t := range tribes {
wg.Add(1)
go func(t *tribe) {
defer wg.Done()
for {
if t.agreements != nil {
if _, ok := t.agreements[a]; ok {
c.So(ok, ShouldEqual, true)
return
}
logger.Debugf(
"%v has %d agreements",
t.memberlist.LocalNode().Name,
len(t.agreements),
)
}
time.Sleep(50 * time.Millisecond)
}
}(t)
}
wg.Wait()
for _, t := range tribes {
So(len(t.agreements), ShouldEqual, 1)
So(t.agreements[a], ShouldNotBeNil)
}
Convey("A member", func() {
Convey("joins an agreement", func() {
err := t.JoinAgreement(a, t.memberlist.LocalNode().Name)
So(err, ShouldBeNil)
})
Convey("is added to an agreement it already belongs to", func() {
Convey("adds a plugin to agreement", func() {
err := t.AddPlugin(a, agreement.Plugin{Name_: "plugin1", Version_: 1})
So(err, ShouldBeNil)
})
err := t.JoinAgreement(a, t.memberlist.LocalNode().Name)
So(err.Error(), ShouldResemble, errAlreadyMemberOfPluginAgreement.Error())
})
Convey("leaves an agreement that doesn't exist", func() {
err := t.LeaveAgreement("whatever", t.memberlist.LocalNode().Name)
So(err.Error(), ShouldResemble, errAgreementDoesNotExist.Error())
})
Convey("handles an unknown member trying to leave an agreement", func() {
err := t.LeaveAgreement(a, "whatever")
So(err.Error(), ShouldResemble, errUnknownMember.Error())
})
Convey("handles a member leaving an agreement it isn't part of", func() {
err := t.LeaveAgreement(a, tribes[0].memberlist.LocalNode().Name)
So(err.Error(), ShouldResemble, errNotAMember.Error())
})
Convey("handles an unknown member trying to join an agreement", func() {
msg := &agreementMsg{
LTime: t.clock.Time(),
UUID: uuid.New(),
AgreementName: a,
MemberName: "whatever",
Type: joinAgreementMsgType,
}
err := t.joinAgreement(msg)
So(err, ShouldNotBeNil)
So(err.Error(), ShouldResemble, errUnknownMember.Error())
})
})
})
})
})
}
示例2: TestTribeAgreements
func TestTribeAgreements(t *testing.T) {
numOfTribes := 5
tribes := getTribes(numOfTribes, nil)
Convey(fmt.Sprintf("%d tribes are started", numOfTribes), t, func() {
for i := 0; i < numOfTribes; i++ {
log.Debugf("%v is reporting %v members", i, len(tribes[i].memberlist.Members()))
So(len(tribes[0].memberlist.Members()), ShouldEqual, len(tribes[i].memberlist.Members()))
}
Convey("The cluster agrees on membership", func() {
for i := 0; i < numOfTribes; i++ {
So(
len(tribes[0].memberlist.Members()),
ShouldEqual,
len(tribes[i].memberlist.Members()),
)
So(len(tribes[0].members), ShouldEqual, len(tribes[i].members))
}
Convey("A member handles", func() {
agreementName := "agreement1"
t := tribes[0]
t2 := tribes[1]
Convey("an out-of-order join agreement message", func() {
msg := &agreementMsg{
LTime: t.clock.Increment(),
UUID: uuid.New(),
AgreementName: agreementName,
MemberName: t.memberlist.LocalNode().Name,
Type: joinAgreementMsgType,
}
msg2 := &agreementMsg{
LTime: t.clock.Increment(),
UUID: uuid.New(),
AgreementName: agreementName,
MemberName: t2.memberlist.LocalNode().Name,
Type: joinAgreementMsgType,
}
b := t.handleJoinAgreement(msg)
So(b, ShouldEqual, true)
So(len(t.intentBuffer), ShouldEqual, 1)
t.broadcast(joinAgreementMsgType, msg, nil)
timer := time.After(2 * time.Second)
loop1:
for {
select {
case <-timer:
So("Timed out", ShouldEqual, "")
default:
if len(t2.intentBuffer) > 0 {
break loop1
}
}
}
So(len(t2.intentBuffer), ShouldEqual, 1)
b = t.handleJoinAgreement(msg2)
So(b, ShouldEqual, true)
So(len(t.intentBuffer), ShouldEqual, 2)
t.broadcast(joinAgreementMsgType, msg2, nil)
timer = time.After(2 * time.Second)
loop2:
for {
select {
case <-timer:
So("Timed out", ShouldEqual, "")
default:
if len(t2.intentBuffer) == 2 {
break loop2
}
}
}
So(len(t2.intentBuffer), ShouldEqual, 2)
Convey("an out-of-order add plugin message", func() {
plugin := agreement.Plugin{Name_: "plugin1", Version_: 1}
msg := &pluginMsg{
LTime: t.clock.Increment(),
UUID: uuid.New(),
Plugin: plugin,
AgreementName: agreementName,
Type: addPluginMsgType,
}
b := t.handleAddPlugin(msg)
So(b, ShouldEqual, true)
So(len(t.intentBuffer), ShouldEqual, 3)
t.broadcast(addPluginMsgType, msg, nil)
Convey("an add agreement", func() {
err := t.AddAgreement(agreementName)
So(err, ShouldBeNil)
err = t.AddAgreement(agreementName)
So(err.Error(), ShouldResemble, errAgreementAlreadyExists.Error())
var wg sync.WaitGroup
for _, t := range tribes {
wg.Add(1)
go func(t *tribe) {
defer wg.Done()
//.........这里部分代码省略.........