本文整理匯總了Golang中github.com/juju/juju/worker/migrationflag.Manifold函數的典型用法代碼示例。如果您正苦於以下問題:Golang Manifold函數的具體用法?Golang Manifold怎麽用?Golang Manifold使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了Manifold函數的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: TestOutputBadTarget
func (*ManifoldSuite) TestOutputBadTarget(c *gc.C) {
manifold := migrationflag.Manifold(migrationflag.ManifoldConfig{})
in := &migrationflag.Worker{}
var out bool
err := manifold.Output(in, &out)
c.Check(err, gc.ErrorMatches, "expected out to be a \\*Flag; got a .*")
}
示例2: checkManifoldNotValid
// checkManifoldNotValid checks that the supplied ManifoldConfig creates
// a manifold that cannot be started.
func checkManifoldNotValid(c *gc.C, config migrationflag.ManifoldConfig, expect string) {
manifold := migrationflag.Manifold(config)
worker, err := manifold.Start(dt.StubContext(nil, nil))
c.Check(worker, gc.IsNil)
c.Check(err, gc.ErrorMatches, expect)
c.Check(err, jc.Satisfies, errors.IsNotValid)
}
示例3: TestOutputBadWorker
func (*ManifoldSuite) TestOutputBadWorker(c *gc.C) {
manifold := migrationflag.Manifold(migrationflag.ManifoldConfig{})
in := &struct{ worker.Worker }{}
var out util.Flag
err := manifold.Output(in, &out)
c.Check(err, gc.ErrorMatches, "expected in to implement Flag; got a .*")
}
示例4: TestOutputBadInput
func (*ManifoldSuite) TestOutputBadInput(c *gc.C) {
manifold := migrationflag.Manifold(migrationflag.ManifoldConfig{})
in := &migrationflag.Worker{}
var out util.Flag
err := manifold.Output(in, &out)
c.Check(err, jc.ErrorIsNil)
c.Check(out, gc.Equals, in)
}
示例5: TestStartMissingAPICaller
func (*ManifoldSuite) TestStartMissingAPICaller(c *gc.C) {
context := dt.StubContext(nil, map[string]interface{}{
"api-caller": dependency.ErrMissing,
})
manifold := migrationflag.Manifold(validManifoldConfig())
worker, err := manifold.Start(context)
c.Check(worker, gc.IsNil)
c.Check(errors.Cause(err), gc.Equals, dependency.ErrMissing)
}
示例6: TestStartNewFacadeError
func (*ManifoldSuite) TestStartNewFacadeError(c *gc.C) {
expectCaller := &stubCaller{}
context := dt.StubContext(nil, map[string]interface{}{
"api-caller": expectCaller,
})
config := validManifoldConfig()
config.NewFacade = func(caller base.APICaller) (migrationflag.Facade, error) {
c.Check(caller, gc.Equals, expectCaller)
return nil, errors.New("bort")
}
manifold := migrationflag.Manifold(config)
worker, err := manifold.Start(context)
c.Check(worker, gc.IsNil)
c.Check(err, gc.ErrorMatches, "bort")
}
示例7: TestStartSuccess
func (*ManifoldSuite) TestStartSuccess(c *gc.C) {
context := dt.StubContext(nil, map[string]interface{}{
"api-caller": &stubCaller{},
})
expectWorker := &struct{ worker.Worker }{}
config := validManifoldConfig()
config.NewFacade = func(base.APICaller) (migrationflag.Facade, error) {
return &struct{ migrationflag.Facade }{}, nil
}
config.NewWorker = func(migrationflag.Config) (worker.Worker, error) {
return expectWorker, nil
}
manifold := migrationflag.Manifold(config)
worker, err := manifold.Start(context)
c.Check(err, jc.ErrorIsNil)
c.Check(worker, gc.Equals, expectWorker)
}
示例8: TestStartNewWorkerError
func (*ManifoldSuite) TestStartNewWorkerError(c *gc.C) {
context := dt.StubContext(nil, map[string]interface{}{
"api-caller": &stubCaller{},
})
expectFacade := &struct{ migrationflag.Facade }{}
config := validManifoldConfig()
config.NewFacade = func(base.APICaller) (migrationflag.Facade, error) {
return expectFacade, nil
}
config.NewWorker = func(workerConfig migrationflag.Config) (worker.Worker, error) {
c.Check(workerConfig.Facade, gc.Equals, expectFacade)
c.Check(workerConfig.Model, gc.Equals, validUUID)
c.Check(workerConfig.Check, gc.NotNil) // uncomparable
return nil, errors.New("snerk")
}
manifold := migrationflag.Manifold(config)
worker, err := manifold.Start(context)
c.Check(worker, gc.IsNil)
c.Check(err, gc.ErrorMatches, "snerk")
}
示例9: TestFilterOther
func (*ManifoldSuite) TestFilterOther(c *gc.C) {
manifold := migrationflag.Manifold(migrationflag.ManifoldConfig{})
expect := errors.New("whatever")
actual := manifold.Filter(expect)
c.Check(actual, gc.Equals, expect)
}
示例10: TestFilterErrChanged
func (*ManifoldSuite) TestFilterErrChanged(c *gc.C) {
manifold := migrationflag.Manifold(migrationflag.ManifoldConfig{})
err := manifold.Filter(migrationflag.ErrChanged)
c.Check(err, gc.Equals, dependency.ErrBounce)
}
示例11: TestFilterNil
func (*ManifoldSuite) TestFilterNil(c *gc.C) {
manifold := migrationflag.Manifold(migrationflag.ManifoldConfig{})
err := manifold.Filter(nil)
c.Check(err, jc.ErrorIsNil)
}
示例12: TestInputs
func (*ManifoldSuite) TestInputs(c *gc.C) {
manifold := migrationflag.Manifold(validManifoldConfig())
c.Check(manifold.Inputs, jc.DeepEquals, []string{"api-caller"})
}
示例13: Manifolds
// Manifolds returns a set of co-configured manifolds covering the
// various responsibilities of a machine agent.
//
// Thou Shalt Not Use String Literals In This Function. Or Else.
func Manifolds(config ManifoldsConfig) dependency.Manifolds {
// connectFilter exists:
// 1) to let us retry api connections immediately on password change,
// rather than causing the dependency engine to wait for a while;
// 2) to ensure that certain connection failures correctly trigger
// complete agent removal. (It's not safe to let any agent other
// than the machine mess around with SetCanUninstall).
connectFilter := func(err error) error {
cause := errors.Cause(err)
if cause == apicaller.ErrConnectImpossible {
err2 := coreagent.SetCanUninstall(config.Agent)
if err2 != nil {
return errors.Trace(err2)
}
return worker.ErrTerminateAgent
} else if cause == apicaller.ErrChangedPassword {
return dependency.ErrBounce
}
return err
}
var externalUpdateProxyFunc func(proxy.Settings) error
if runtime.GOOS == "linux" {
externalUpdateProxyFunc = lxd.ConfigureLXDProxies
}
return dependency.Manifolds{
// The agent manifold references the enclosing agent, and is the
// foundation stone on which most other manifolds ultimately depend.
agentName: agent.Manifold(config.Agent),
// The termination worker returns ErrTerminateAgent if a
// termination signal is received by the process it's running
// in. It has no inputs and its only output is the error it
// returns. It depends on the uninstall file having been
// written *by the manual provider* at install time; it would
// be Very Wrong Indeed to use SetCanUninstall in conjunction
// with this code.
terminationName: terminationworker.Manifold(),
// The stateconfigwatcher manifold watches the machine agent's
// configuration and reports if state serving info is
// present. It will bounce itself if state serving info is
// added or removed. It is intended as a dependency just for
// the state manifold.
stateConfigWatcherName: stateconfigwatcher.Manifold(stateconfigwatcher.ManifoldConfig{
AgentName: agentName,
AgentConfigChanged: config.AgentConfigChanged,
}),
// The state manifold creates a *state.State and makes it
// available to other manifolds. It pings the mongodb session
// regularly and will die if pings fail.
stateName: workerstate.Manifold(workerstate.ManifoldConfig{
AgentName: agentName,
StateConfigWatcherName: stateConfigWatcherName,
OpenState: config.OpenState,
}),
// The stateworkers manifold starts workers which rely on a
// *state.State but which haven't been converted to run
// directly under the dependency engine yet. This manifold
// will be removed once all such workers have been converted;
// until then, the workers are expected to handle their own
// checks for upgrades etc, rather than blocking this whole
// worker on upgrade completion.
stateWorkersName: StateWorkersManifold(StateWorkersConfig{
StateName: stateName,
StartStateWorkers: config.StartStateWorkers,
}),
// The api-config-watcher manifold monitors the API server
// addresses in the agent config and bounces when they
// change. It's required as part of model migrations.
apiConfigWatcherName: apiconfigwatcher.Manifold(apiconfigwatcher.ManifoldConfig{
AgentName: agentName,
AgentConfigChanged: config.AgentConfigChanged,
}),
// The api caller is a thin concurrent wrapper around a connection
// to some API server. It's used by many other manifolds, which all
// select their own desired facades. It will be interesting to see
// how this works when we consolidate the agents; might be best to
// handle the auth changes server-side..?
apiCallerName: apicaller.Manifold(apicaller.ManifoldConfig{
AgentName: agentName,
APIConfigWatcherName: apiConfigWatcherName,
APIOpen: api.Open,
NewConnection: apicaller.ScaryConnect,
Filter: connectFilter,
}),
// The upgrade steps gate is used to coordinate workers which
// shouldn't do anything until the upgrade-steps worker has
// finished running any required upgrade steps. The flag of
// similar name is used to implement the isFullyUpgraded func
//.........這裏部分代碼省略.........