本文整理匯總了Golang中github.com/juju/juju/apiserver/common.DestroyModel函數的典型用法代碼示例。如果您正苦於以下問題:Golang DestroyModel函數的具體用法?Golang DestroyModel怎麽用?Golang DestroyModel使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了DestroyModel函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: TestCanDestroyNonBlockedModel
func (s *destroyTwoModelsSuite) TestCanDestroyNonBlockedModel(c *gc.C) {
bh := commontesting.NewBlockHelper(s.APIState)
defer bh.Close()
bh.BlockDestroyModel(c, "TestBlockDestroyDestroyModel")
err := common.DestroyModel(s.State, s.otherState.ModelTag())
c.Assert(err, jc.ErrorIsNil)
err = common.DestroyModel(s.State, s.State.ModelTag())
bh.AssertBlocked(c, err, "TestBlockDestroyDestroyModel")
}
示例2: TestBlockRemoveDestroyModel
func (s *destroyModelSuite) TestBlockRemoveDestroyModel(c *gc.C) {
// Setup model
s.setUpInstances(c)
s.BlockRemoveObject(c, "TestBlockRemoveDestroyModel")
err := common.DestroyModel(s.State, s.State.ModelTag())
s.AssertBlocked(c, err, "TestBlockRemoveDestroyModel")
}
示例3: DestroyModels
// DestroyModels will try to destroy the specified models.
// If there is a block on destruction, this method will return an error.
func (m *ModelManagerAPI) DestroyModels(args params.Entities) (params.ErrorResults, error) {
results := params.ErrorResults{
Results: make([]params.ErrorResult, len(args.Entities)),
}
destroyModel := func(tag names.ModelTag) error {
model, err := m.state.GetModel(tag)
if err != nil {
return errors.Trace(err)
}
if err := m.authCheck(model.Owner()); err != nil {
return errors.Trace(err)
}
return errors.Trace(common.DestroyModel(m.state, model.ModelTag()))
}
for i, arg := range args.Entities {
tag, err := names.ParseModelTag(arg.Tag)
if err != nil {
results.Results[i].Error = common.ServerError(err)
continue
}
if err := destroyModel(tag); err != nil {
results.Results[i].Error = common.ServerError(err)
continue
}
}
return results, nil
}
示例4: DestroyController
// DestroyController will attempt to destroy the controller. If the args
// specify the removal of blocks or the destruction of the models, this
// method will attempt to do so.
//
// If the controller has any non-Dead hosted models, then an error with
// the code params.CodeHasHostedModels will be transmitted, regardless of
// the value of the DestroyModels parameter. This is to inform the client
// that it should wait for hosted models to be completely cleaned up
// before proceeding.
func (s *ControllerAPI) DestroyController(args params.DestroyControllerArgs) error {
hasPermission, err := s.authorizer.HasPermission(permission.SuperuserAccess, s.state.ControllerTag())
if err != nil {
return errors.Trace(err)
}
if !hasPermission {
return errors.Trace(common.ErrPerm)
}
st := common.NewModelManagerBackend(s.state)
controllerModel, err := st.ControllerModel()
if err != nil {
return errors.Trace(err)
}
systemTag := controllerModel.ModelTag()
if err = s.ensureNotBlocked(args); err != nil {
return errors.Trace(err)
}
// If we are destroying models, we need to tolerate living
// models but set the controller to dying to prevent new
// models sneaking in. If we are not destroying hosted models,
// this will fail if any hosted models are found.
if args.DestroyModels {
return errors.Trace(common.DestroyModelIncludingHosted(st, systemTag))
}
if err := common.DestroyModel(st, systemTag); err != nil {
return errors.Trace(err)
}
return nil
}
示例5: TestBlockDestroyDestroyEnvironment
func (s *destroyModelSuite) TestBlockDestroyDestroyEnvironment(c *gc.C) {
// Setup environment
s.setUpInstances(c)
s.BlockDestroyModel(c, "TestBlockDestroyDestroyModel")
err := common.DestroyModel(s.State, s.State.ModelTag())
s.AssertBlocked(c, err, "TestBlockDestroyDestroyModel")
}
示例6: TestBlockChangesDestroyModel
func (s *destroyModelSuite) TestBlockChangesDestroyModel(c *gc.C) {
// Setup model
s.setUpInstances(c)
// lock model: can't destroy locked model
s.BlockAllChanges(c, "TestBlockChangesDestroyModel")
err := common.DestroyModel(s.State, s.State.ModelTag())
s.AssertBlocked(c, err, "TestBlockChangesDestroyModel")
}
示例7: DestroyModel
// DestroyModel will try to destroy the current model.
// If there is a block on destruction, this method will return an error.
func (c *Client) DestroyModel() (err error) {
if err := c.check.DestroyAllowed(); err != nil {
return errors.Trace(err)
}
modelTag := c.api.stateAccessor.ModelTag()
return errors.Trace(common.DestroyModel(c.api.state(), modelTag))
}
示例8: TestMetrics
func (s *destroyModelSuite) TestMetrics(c *gc.C) {
metricSender := &testMetricSender{}
s.PatchValue(common.SendMetrics, metricSender.SendMetrics)
err := common.DestroyModel(s.State, s.State.ModelTag())
c.Assert(err, jc.ErrorIsNil)
metricSender.CheckCalls(c, []jtesting.StubCall{{FuncName: "SendMetrics"}})
}
示例9: TestDestroyControllerNoHostedEnvs
func (s *destroyControllerSuite) TestDestroyControllerNoHostedEnvs(c *gc.C) {
err := common.DestroyModel(s.State, s.otherState.ModelTag())
c.Assert(err, jc.ErrorIsNil)
err = s.controller.DestroyController(params.DestroyControllerArgs{})
c.Assert(err, jc.ErrorIsNil)
env, err := s.State.Model()
c.Assert(err, jc.ErrorIsNil)
c.Assert(env.Life(), gc.Equals, state.Dying)
}
示例10: TestDestroyControllerAfterNonControllerIsDestroyed
func (s *destroyTwoModelsSuite) TestDestroyControllerAfterNonControllerIsDestroyed(c *gc.C) {
otherFactory := factory.NewFactory(s.otherState)
otherFactory.MakeMachine(c, nil)
m := otherFactory.MakeMachine(c, nil)
otherFactory.MakeMachineNested(c, m.Id(), nil)
err := common.DestroyModel(s.modelManager, s.State.ModelTag())
c.Assert(err, gc.ErrorMatches, "failed to destroy model: hosting 1 other models")
needsCleanup, err := s.State.NeedsCleanup()
c.Assert(err, jc.ErrorIsNil)
c.Assert(needsCleanup, jc.IsFalse)
err = common.DestroyModel(s.modelManager, s.otherState.ModelTag())
c.Assert(err, jc.ErrorIsNil)
// The hosted model is Dying, not Dead; we cannot destroy
// the controller model until all hosted models are Dead.
err = common.DestroyModel(s.modelManager, s.State.ModelTag())
c.Assert(err, gc.ErrorMatches, "failed to destroy model: hosting 1 other models")
// Continue to take the hosted model down so we can
// destroy the controller model.
runAllCleanups(c, s.otherState)
assertAllMachinesDeadAndRemove(c, s.otherState)
c.Assert(s.otherState.ProcessDyingModel(), jc.ErrorIsNil)
err = common.DestroyModel(s.modelManager, s.State.ModelTag())
c.Assert(err, jc.ErrorIsNil)
otherEnv, err := s.otherState.Model()
c.Assert(err, jc.ErrorIsNil)
c.Assert(otherEnv.Life(), gc.Equals, state.Dead)
env, err := s.State.Model()
c.Assert(err, jc.ErrorIsNil)
c.Assert(env.Life(), gc.Equals, state.Dying)
c.Assert(s.State.ProcessDyingModel(), jc.ErrorIsNil)
c.Assert(env.Refresh(), jc.ErrorIsNil)
c.Assert(env.Life(), gc.Equals, state.Dead)
}
示例11: TestDestroyControllerErrsOnNoHostedEnvsWithBlock
func (s *destroyControllerSuite) TestDestroyControllerErrsOnNoHostedEnvsWithBlock(c *gc.C) {
err := common.DestroyModel(s.State, s.otherState.ModelTag())
c.Assert(err, jc.ErrorIsNil)
s.BlockDestroyModel(c, "TestBlockDestroyModel")
s.BlockRemoveObject(c, "TestBlockRemoveObject")
err = s.controller.DestroyController(params.DestroyControllerArgs{})
c.Assert(err, gc.ErrorMatches, "found blocks in controller models")
env, err := s.State.Model()
c.Assert(err, jc.ErrorIsNil)
c.Assert(env.Life(), gc.Equals, state.Alive)
}
示例12: TestDestroyControllerNoHostedEnvsWithBlockFail
func (s *destroyControllerSuite) TestDestroyControllerNoHostedEnvsWithBlockFail(c *gc.C) {
err := common.DestroyModel(s.State, s.otherState.ModelTag())
c.Assert(err, jc.ErrorIsNil)
s.BlockDestroyModel(c, "TestBlockDestroyModel")
s.BlockRemoveObject(c, "TestBlockRemoveObject")
err = s.controller.DestroyController(params.DestroyControllerArgs{})
c.Assert(params.IsCodeOperationBlocked(err), jc.IsTrue)
numBlocks, err := s.State.AllBlocksForController()
c.Assert(err, jc.ErrorIsNil)
c.Assert(len(numBlocks), gc.Equals, 2)
}
示例13: TestDestroyModelManual
func (s *destroyModelSuite) TestDestroyModelManual(c *gc.C) {
_, nonManager := s.setUpManual(c)
// If there are any non-manager manual machines in state, DestroyModel will
// error. It will not set the Dying flag on the environment.
err := common.DestroyModel(s.State, s.State.ModelTag())
c.Assert(err, gc.ErrorMatches, fmt.Sprintf("failed to destroy model: manually provisioned machines must first be destroyed with `juju destroy-machine %s`", nonManager.Id()))
env, err := s.State.Model()
c.Assert(err, jc.ErrorIsNil)
c.Assert(env.Life(), gc.Equals, state.Alive)
// If we remove the non-manager machine, it should pass.
// Manager machines will remain.
err = nonManager.EnsureDead()
c.Assert(err, jc.ErrorIsNil)
err = nonManager.Remove()
c.Assert(err, jc.ErrorIsNil)
err = common.DestroyModel(s.State, s.State.ModelTag())
c.Assert(err, jc.ErrorIsNil)
err = env.Refresh()
c.Assert(err, jc.ErrorIsNil)
c.Assert(env.Life(), gc.Equals, state.Dying)
}
示例14: TestDestroyControllerAfterNonControllerIsDestroyed
func (s *destroyTwoModelsSuite) TestDestroyControllerAfterNonControllerIsDestroyed(c *gc.C) {
otherFactory := factory.NewFactory(s.otherState)
otherFactory.MakeMachine(c, nil)
m := otherFactory.MakeMachine(c, nil)
otherFactory.MakeMachineNested(c, m.Id(), nil)
err := common.DestroyModel(s.State, s.State.ModelTag())
c.Assert(err, gc.ErrorMatches, "failed to destroy model: hosting 1 other models")
needsCleanup, err := s.State.NeedsCleanup()
c.Assert(err, jc.ErrorIsNil)
c.Assert(needsCleanup, jc.IsFalse)
err = common.DestroyModel(s.State, s.otherState.ModelTag())
c.Assert(err, jc.ErrorIsNil)
err = common.DestroyModel(s.State, s.State.ModelTag())
c.Assert(err, jc.ErrorIsNil)
// Make sure we can continue to take the hosted model down while the
// controller environ is dying.
runAllCleanups(c, s.otherState)
assertAllMachinesDeadAndRemove(c, s.otherState)
c.Assert(s.otherState.ProcessDyingModel(), jc.ErrorIsNil)
otherEnv, err := s.otherState.Model()
c.Assert(err, jc.ErrorIsNil)
c.Assert(otherEnv.Life(), gc.Equals, state.Dead)
env, err := s.State.Model()
c.Assert(err, jc.ErrorIsNil)
c.Assert(env.Life(), gc.Equals, state.Dying)
c.Assert(s.State.ProcessDyingModel(), jc.ErrorIsNil)
c.Assert(env.Refresh(), jc.ErrorIsNil)
c.Assert(env.Life(), gc.Equals, state.Dead)
}
示例15: TestDestroyModel
func (s *destroyModelSuite) TestDestroyModel(c *gc.C) {
manager, nonManager, _ := s.setUpInstances(c)
managerId, _ := manager.InstanceId()
nonManagerId, _ := nonManager.InstanceId()
instances, err := s.Environ.Instances([]instance.Id{managerId, nonManagerId})
c.Assert(err, jc.ErrorIsNil)
for _, inst := range instances {
c.Assert(inst, gc.NotNil)
}
services, err := s.State.AllServices()
c.Assert(err, jc.ErrorIsNil)
err = common.DestroyModel(s.State, s.State.ModelTag())
c.Assert(err, jc.ErrorIsNil)
runAllCleanups(c, s.State)
// After DestroyModel returns and all cleanup jobs have run, we should have:
// - all non-manager machines dying
assertLife(c, manager, state.Alive)
// Note: we leave the machine in a dead state and rely on the provisioner
// to stop the backing instances, remove the dead machines and finally
// remove all environment docs from state.
assertLife(c, nonManager, state.Dead)
// - all services in state are Dying or Dead (or removed altogether),
// after running the state Cleanups.
for _, s := range services {
err = s.Refresh()
if err != nil {
c.Assert(err, jc.Satisfies, errors.IsNotFound)
} else {
c.Assert(s.Life(), gc.Not(gc.Equals), state.Alive)
}
}
// - environment is Dying or Dead.
env, err := s.State.Model()
c.Assert(err, jc.ErrorIsNil)
c.Assert(env.Life(), gc.Not(gc.Equals), state.Alive)
}