本文整理匯總了Golang中github.com/juju/juju/state.State.StartSync方法的典型用法代碼示例。如果您正苦於以下問題:Golang State.StartSync方法的具體用法?Golang State.StartSync怎麽用?Golang State.StartSync使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/juju/juju/state.State
的用法示例。
在下文中一共展示了State.StartSync方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: waitForUnitStarted
func waitForUnitStarted(stateConn *state.State, unit *state.Unit, c *gc.C) {
timeout := time.After(5 * time.Second)
for {
select {
case <-timeout:
c.Fatalf("no activity detected")
case <-time.After(coretesting.ShortWait):
err := unit.Refresh()
c.Assert(err, gc.IsNil)
st, info, data, err := unit.Status()
c.Assert(err, gc.IsNil)
switch st {
case params.StatusPending, params.StatusInstalled:
c.Logf("waiting...")
continue
case params.StatusStarted:
c.Logf("started!")
return
case params.StatusDown:
stateConn.StartSync()
c.Logf("unit is still down")
default:
c.Fatalf("unexpected status %s %s %v", st, info, data)
}
}
}
}
示例2: waitForUnitActive
func waitForUnitActive(stateConn *state.State, unit *state.Unit, c *gc.C) {
timeout := time.After(5 * time.Second)
for {
select {
case <-timeout:
c.Fatalf("no activity detected")
case <-time.After(coretesting.ShortWait):
err := unit.Refresh()
c.Assert(err, jc.ErrorIsNil)
statusInfo, err := unit.Status()
c.Assert(err, jc.ErrorIsNil)
switch statusInfo.Status {
case state.StatusMaintenance, state.StatusWaiting, state.StatusBlocked:
c.Logf("waiting...")
continue
case state.StatusActive:
c.Logf("active!")
return
case state.StatusUnknown:
// Active units may have a status of unknown if they have
// started but not run status-set.
c.Logf("unknown but active!")
return
default:
c.Fatalf("unexpected status %s %s %v", statusInfo.Status, statusInfo.Message, statusInfo.Data)
}
statusInfo, err = unit.AgentStatus()
c.Assert(err, jc.ErrorIsNil)
switch statusInfo.Status {
case state.StatusAllocating, state.StatusExecuting, state.StatusRebooting, state.StatusIdle:
c.Logf("waiting...")
continue
case state.StatusError:
stateConn.StartSync()
c.Logf("unit is still down")
default:
c.Fatalf("unexpected status %s %s %v", statusInfo.Status, statusInfo.Message, statusInfo.Data)
}
}
}
}