本文整理匯總了Golang中github.com/juju/juju/worker/workertest.CheckAlive函數的典型用法代碼示例。如果您正苦於以下問題:Golang CheckAlive函數的具體用法?Golang CheckAlive怎麽用?Golang CheckAlive使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了CheckAlive函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: TestPartialInstanceErrors
func (s *aggregateSuite) TestPartialInstanceErrors(c *gc.C) {
testGetter := new(testInstanceGetter)
clock := jujutesting.NewClock(time.Now())
delay := time.Second
cfg := aggregatorConfig{
Clock: clock,
Delay: delay,
Environ: testGetter,
}
testGetter.err = environs.ErrPartialInstances
testGetter.newTestInstance("foo", "not foobar", []string{"192.168.1.2"})
aggregator, err := newAggregator(cfg)
c.Check(err, jc.ErrorIsNil)
// Ensure the worker is killed and cleaned up if the test exits early.
defer workertest.CleanKill(c, aggregator)
// // Create a checker we can launch as goroutines
var wg sync.WaitGroup
checkInfo := func(id instance.Id, expectStatus string, expectedError error) {
defer wg.Done()
info, err := aggregator.instanceInfo(id)
if expectedError == nil {
c.Check(err, jc.ErrorIsNil)
} else {
c.Check(err.Error(), gc.Equals, expectedError.Error())
}
c.Check(info.status.Message, gc.Equals, expectStatus)
}
// Launch and wait for these
wg.Add(2)
go checkInfo("foo", "not foobar", nil)
go checkInfo("foo2", "", errors.New("instance foo2 not found"))
// Unwind the testing clock to let our requests through.
waitAlarms(c, clock, 2)
clock.Advance(delay)
// Check we're still alive.
workertest.CheckAlive(c, aggregator)
// Wait until the checkers pass.
wg.Wait()
// Now kill the worker so we don't risk a race in the following assertions.
workertest.CleanKill(c, aggregator)
// Ensure we got our list back with the correct length.
c.Assert(len(testGetter.ids), gc.Equals, 2)
// Ensure we called instances once.
// TODO(redir): all this stuff is really crying out to be, e.g.
// testGetter.CheckOneCall(c, "foo", "foo2") per
// http://reviews.vapour.ws/r/4885/
c.Assert(testGetter.counter, gc.Equals, int32(1))
}
示例2: TestConfigError
func (s *WaitSuite) TestConfigError(c *gc.C) {
fix := &fixture{
observerErrs: []error{
errors.New("biff zonk"),
},
}
fix.Run(c, func(context *runContext) {
abort := make(chan struct{})
defer close(abort)
done := make(chan struct{})
go func() {
defer close(done)
env, err := environ.WaitForEnviron(context.watcher, context, nil, abort)
c.Check(env, gc.IsNil)
c.Check(err, gc.ErrorMatches, "cannot read environ config: biff zonk")
}()
context.SendNotify()
select {
case <-done:
case <-time.After(coretesting.LongWait):
c.Errorf("timed out waiting for failure")
}
workertest.CheckAlive(c, context.watcher)
})
}
示例3: TestFlagLocked
func (*FlagSuite) TestFlagLocked(c *gc.C) {
lock := gate.NewLock()
worker, err := gate.NewFlag(lock)
c.Assert(err, jc.ErrorIsNil)
defer workertest.CleanKill(c, worker)
workertest.CheckAlive(c, worker)
c.Check(worker.Check(), jc.IsFalse)
}
示例4: TestClaimFailure
func (s *FlagSuite) TestClaimFailure(c *gc.C) {
fix := newFixture(c, errClaimDenied, nil)
fix.Run(c, func(flag *singular.FlagWorker, _ *coretesting.Clock, _ func()) {
c.Check(flag.Check(), jc.IsFalse)
workertest.CheckAlive(c, flag)
})
fix.CheckClaimWait(c)
}
示例5: TestMultipleResponseHandling
// Test several requests in a short space of time get batched.
func (s *aggregateSuite) TestMultipleResponseHandling(c *gc.C) {
// We setup a couple variables here so that we can use them locally without
// type assertions. Then we use them in the aggregatorConfig.
testGetter := new(testInstanceGetter)
clock := jujutesting.NewClock(time.Now())
delay := time.Minute
cfg := aggregatorConfig{
Clock: clock,
Delay: delay,
Environ: testGetter,
}
// Setup multiple instances to batch
testGetter.newTestInstance("foo", "foobar", []string{"127.0.0.1", "192.168.1.1"})
testGetter.newTestInstance("foo2", "not foobar", []string{"192.168.1.2"})
testGetter.newTestInstance("foo3", "ok-ish", []string{"192.168.1.3"})
aggregator, err := newAggregator(cfg)
c.Check(err, jc.ErrorIsNil)
// Ensure the worker is killed and cleaned up if the test exits early.
defer workertest.CleanKill(c, aggregator)
// Create a closure for tests we can launch in goroutines.
var wg sync.WaitGroup
checkInfo := func(id instance.Id, expectStatus string) {
defer wg.Done()
info, err := aggregator.instanceInfo(id)
c.Check(err, jc.ErrorIsNil)
c.Check(info.status.Message, gc.Equals, expectStatus)
}
// Launch and wait for these
wg.Add(2)
go checkInfo("foo2", "not foobar")
go checkInfo("foo3", "ok-ish")
// Unwind the testing clock to let our requests through.
waitAlarms(c, clock, 2)
clock.Advance(delay)
// Check we're still alive.
workertest.CheckAlive(c, aggregator)
// Wait until the tests pass.
wg.Wait()
// Ensure we kill the worker before looking at our testInstanceGetter to
// ensure there's no possibility of a race.
workertest.CleanKill(c, aggregator)
// Ensure we got our list back with the expected contents.
c.Assert(testGetter.ids, jc.SameContents, []instance.Id{"foo2", "foo3"})
// Ensure we called instances once and have no errors there.
c.Assert(testGetter.err, jc.ErrorIsNil)
c.Assert(testGetter.counter, gc.DeepEquals, int32(1))
}
示例6: TestConfigChangeWithAddrReordering
func (s *ManifoldSuite) TestConfigChangeWithAddrReordering(c *gc.C) {
s.agent.conf.setAddresses("1.1.1.1:1", "2.2.2.2:2")
w := s.startWorkerClean(c)
// Change API address ordering - worker should stay up.
s.agent.conf.setAddresses("2.2.2.2:2", "1.1.1.1:1")
s.agentConfigChanged.Set(0)
workertest.CheckAlive(c, w)
}
示例7: TestConfigChangeWithNoAddrChange
func (s *ManifoldSuite) TestConfigChangeWithNoAddrChange(c *gc.C) {
s.agent.conf.setAddresses("1.1.1.1:1")
w := s.startWorkerClean(c)
// Signal config change without changing API addresses - worker
// should continue running.
s.agentConfigChanged.Set(0)
workertest.CheckAlive(c, w)
}
示例8: TestClaimSuccess
func (s *FlagSuite) TestClaimSuccess(c *gc.C) {
fix := newFixture(c, nil, errors.New("should not happen"))
fix.Run(c, func(flag *singular.FlagWorker, clock *coretesting.Clock, unblock func()) {
<-clock.Alarms()
clock.Advance(29 * time.Second)
workertest.CheckAlive(c, flag)
})
fix.CheckClaims(c, 1)
}
示例9: TestAlreadyDeadTimeMissingWaits
func (s *UndertakerSuite) TestAlreadyDeadTimeMissingWaits(c *gc.C) {
s.fix.info.Result.Life = "dead"
stub := s.fix.run(c, func(w worker.Worker, clock *coretesting.Clock) {
waitAlarm(c, clock)
clock.Advance(RIPTime - time.Second)
workertest.CheckAlive(c, w)
})
stub.CheckCallNames(c, "ModelInfo", "Destroy")
}
示例10: TestWorkerNoErr
func (*WorkerSuite) TestWorkerNoErr(c *gc.C) {
stub := &testing.Stub{}
worker, err := machineactions.NewMachineActionsWorker(defaultConfig(stub))
c.Assert(err, jc.ErrorIsNil)
workertest.CheckAlive(c, worker)
workertest.CleanKill(c, worker)
stub.CheckCalls(c, getSuccessfulCalls(allCalls))
}
示例11: checkNonRunningPhase
func (s *Suite) checkNonRunningPhase(c *gc.C, phase migration.Phase) {
c.Logf("checking %s", phase)
s.stub.ResetCalls()
s.client.watcher.changes <- watcher.MigrationStatus{Phase: phase}
w, err := migrationminion.New(s.config)
c.Assert(err, jc.ErrorIsNil)
workertest.CheckAlive(c, w)
workertest.CleanKill(c, w)
s.stub.CheckCallNames(c, "Watch", "Unlock")
}
示例12: TestFlagUnlockError
func (*FlagSuite) TestFlagUnlockError(c *gc.C) {
lock := gate.NewLock()
worker, err := gate.NewFlag(lock)
c.Assert(err, jc.ErrorIsNil)
defer workertest.DirtyKill(c, worker)
workertest.CheckAlive(c, worker)
lock.Unlock()
err = workertest.CheckKilled(c, worker)
c.Check(err, gc.Equals, gate.ErrUnlocked)
}
示例13: TestRestartsErrorWorker
func (s *suite) TestRestartsErrorWorker(c *gc.C) {
s.runTest(c, func(w worker.Worker, backend *mockBackend) {
backend.sendModelChange("uuid")
workers := s.waitWorkers(c, 1)
workers[0].tomb.Kill(errors.New("blaf"))
s.assertStarts(c, "uuid")
workertest.CheckAlive(c, w)
})
}
示例14: TestWaitsToResume
func (*ResumerSuite) TestWaitsToResume(c *gc.C) {
fix := newFixture(nil, errors.New("unexpected"))
stub := fix.Run(c, func(clock *testing.Clock, worker *resumer.Resumer) {
waitAlarms(c, clock, 2)
clock.Advance(time.Hour - time.Nanosecond)
workertest.CheckAlive(c, worker)
workertest.CleanKill(c, worker)
})
stub.CheckCallNames(c, "ResumeTransactions")
}
示例15: TestKillWorkers
func (s *statePoolSuite) TestKillWorkers(c *gc.C) {
// Get some State instances via the pool and extract their
// internal workers.
st1, err := s.Pool.Get(s.ModelUUID1)
c.Assert(err, jc.ErrorIsNil)
w1 := state.GetInternalWorkers(st1)
workertest.CheckAlive(c, w1)
st2, err := s.Pool.Get(s.ModelUUID1)
c.Assert(err, jc.ErrorIsNil)
w2 := state.GetInternalWorkers(st2)
workertest.CheckAlive(c, w2)
// Now kill their workers.
s.Pool.KillWorkers()
// Ensure the internal workers for each State died.
c.Check(workertest.CheckKilled(c, w1), jc.ErrorIsNil)
c.Check(workertest.CheckKilled(c, w2), jc.ErrorIsNil)
}