本文整理匯總了Python中cloudinstall.placement.controller.PlacementController.load方法的典型用法代碼示例。如果您正苦於以下問題:Python PlacementController.load方法的具體用法?Python PlacementController.load怎麽用?Python PlacementController.load使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類cloudinstall.placement.controller.PlacementController
的用法示例。
在下文中一共展示了PlacementController.load方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_load_error_mismatch_charm_name
# 需要導入模塊: from cloudinstall.placement.controller import PlacementController [as 別名]
# 或者: from cloudinstall.placement.controller.PlacementController import load [as 別名]
def test_load_error_mismatch_charm_name(self):
"""Should safely ignore (and log) a charm name in a placement file
that can't be matched to a loaded charm class."""
singlepc = PlacementController(None, self.conf)
fake_assignments = {
'fake_iid': {
'constraints': {},
'assignments': {'KVM':
['non-existent']}},
'fake_iid_2': {
'constraints': {'cpu': 8},
'assignments':
{'BareMetal': ['nova-compute']}}}
with TemporaryFile(mode='w+', encoding='utf-8') as tempf:
yaml.dump(fake_assignments, tempf)
tempf.seek(0)
singlepc.load(tempf)
self.assertEqual(set([m.instance_id for m in
singlepc.machines_pending()]),
set(['fake_iid_2']))
m2 = next((m for m in singlepc.machines_pending()
if m.instance_id == 'fake_iid_2'))
self.assertEqual(m2.constraints, {'cpu': 8})
示例2: test_load_machines_single
# 需要導入模塊: from cloudinstall.placement.controller import PlacementController [as 別名]
# 或者: from cloudinstall.placement.controller.PlacementController import load [as 別名]
def test_load_machines_single(self):
with NamedTemporaryFile(mode='w+', encoding='utf-8') as tempf:
utils.spew(tempf.name, yaml.dump(dict()))
conf = Config({}, tempf.name)
fake_assignments = {
'fake_iid': {'constraints': {},
'assignments': {'KVM':
['nova-compute']}},
'fake_iid_2': {'constraints': {'cpu': 8},
'assignments':
{'BareMetal': ['nova-compute']}}}
singlepc = PlacementController(
None, conf)
with TemporaryFile(mode='w+', encoding='utf-8') as tempf:
yaml.dump(fake_assignments, tempf)
tempf.seek(0)
singlepc.load(tempf)
self.assertEqual(set([m.instance_id for m in
singlepc.machines_pending()]),
set(['fake_iid', 'fake_iid_2']))
m2 = next((m for m in singlepc.machines_pending()
if m.instance_id == 'fake_iid_2'))
self.assertEqual(m2.constraints, {'cpu': 8})
示例3: test_load_machines_single
# 需要導入模塊: from cloudinstall.placement.controller import PlacementController [as 別名]
# 或者: from cloudinstall.placement.controller.PlacementController import load [as 別名]
def test_load_machines_single(self):
singlepc = PlacementController(None, self.mock_opts)
fake_assignments = {'fake_iid': {'constraints': {},
'assignments': {'KVM':
['nova-compute']}},
'fake_iid_2': {'constraints': {'cpu': 8},
'assignments':
{'BareMetal': ['nova-compute']}}}
with TemporaryFile(mode='w+', encoding='utf-8') as tempf:
yaml.dump(fake_assignments, tempf)
tempf.seek(0)
singlepc.load(tempf)
self.assertEqual(set([m.instance_id for m in
singlepc.machines_used()]),
set(['fake_iid', 'fake_iid_2']))
m2 = next((m for m in singlepc.machines_used()
if m.instance_id == 'fake_iid_2'))
self.assertEqual(m2.constraints, {'cpu': 8})
示例4: test_persistence
# 需要導入模塊: from cloudinstall.placement.controller import PlacementController [as 別名]
# 或者: from cloudinstall.placement.controller.PlacementController import load [as 別名]
def test_persistence(self):
self.pc.assign(self.mock_machine, CharmNovaCompute, AssignmentType.LXC)
self.pc.assign(self.mock_machine_2, CharmKeystone, AssignmentType.KVM)
cons1 = PropertyMock(return_value={})
type(self.mock_machine).constraints = cons1
cons2 = PropertyMock(return_value={'cpu': 8})
type(self.mock_machine_2).constraints = cons2
with TemporaryFile(mode='w+', encoding='utf-8') as tempf:
self.pc.save(tempf)
tempf.seek(0)
newpc = PlacementController(self.mock_maas_state, self.mock_opts)
newpc.load(tempf)
self.assertEqual(self.pc.assignments, newpc.assignments)
self.assertEqual(self.pc.machines_used(), newpc.machines_used())
self.assertEqual(self.pc.placed_charm_classes(),
newpc.placed_charm_classes())
m2 = next((m for m in newpc.machines_used()
if m.instance_id == 'fake-instance-id-2'))
self.assertEqual(m2.constraints, {'cpu': 8})
示例5: __init__
# 需要導入模塊: from cloudinstall.placement.controller import PlacementController [as 別名]
# 或者: from cloudinstall.placement.controller.PlacementController import load [as 別名]
class Controller:
""" Controller for Juju deployments and Maas machine init """
def __init__(self, ui, config, loop):
self.ui = ui
self.ui.controller = self
self.config = config
self.loop = loop
self.juju_state = None
self.juju = None
self.maas = None
self.maas_state = None
self.nodes = []
self.juju_m_idmap = None # for single, {instance_id: machine id}
self.deployed_charm_classes = []
self.placement_controller = None
self.config.setopt('current_state', ControllerState.INSTALL_WAIT.value)
def update(self, *args, **kwargs):
"""Render UI according to current state and reset timer
PegasusGUI only.
"""
interval = 1
current_state = self.config.getopt('current_state')
if current_state == ControllerState.PLACEMENT:
self.ui.render_placement_view(self.loop,
self.config,
self.commit_placement)
elif current_state == ControllerState.INSTALL_WAIT:
self.ui.render_node_install_wait(message="Waiting...")
interval = self.config.node_install_wait_interval
elif current_state == ControllerState.ADD_SERVICES:
self.ui.render_add_services_dialog(self.deploy_new_services,
self.cancel_add_services)
elif current_state == ControllerState.SERVICES:
self.update_node_states()
else:
raise Exception("Internal error, unexpected display "
"state '{}'".format(current_state))
self.loop.redraw_screen()
self.loop.set_alarm_in(interval, self.update)
def update_node_states(self):
""" Updating node states
PegasusGUI only
"""
if not self.juju_state:
return
deployed_services = sorted(self.juju_state.services,
key=attrgetter('service_name'))
deployed_service_names = [s.service_name for s in deployed_services]
charm_classes = sorted(
[m.__charm_class__ for m in
utils.load_charms(self.config.getopt('charm_plugin_dir'))
if m.__charm_class__.charm_name in
deployed_service_names],
key=attrgetter('charm_name'))
self.nodes = list(zip(charm_classes, deployed_services))
for n in deployed_services:
for u in n.units:
if u.is_horizon and u.agent_state == "started":
self.ui.set_dashboard_url(
u.public_address, 'ubuntu',
self.config.getopt('openstack_password'))
if u.is_jujugui and u.agent_state == "started":
self.ui.set_jujugui_url(u.public_address)
if len(self.nodes) == 0:
return
else:
self.ui.render_services_view(self.nodes, self.juju_state,
self.maas_state, self.config)
def authenticate_juju(self):
if not len(self.config.juju_env['state-servers']) > 0:
state_server = 'localhost:17070'
else:
state_server = self.config.juju_env['state-servers'][0]
self.juju = JujuClient(
url=path.join('wss://', state_server),
password=self.config.juju_api_password)
self.juju.login()
self.juju_state = JujuState(self.juju)
log.debug('Authenticated against juju api.')
def initialize(self):
"""Authenticates against juju/maas and sets up placement controller."""
if getenv("FAKE_API_DATA"):
self.juju_state = FakeJujuState()
self.maas_state = FakeMaasState()
else:
self.authenticate_juju()
#.........這裏部分代碼省略.........
示例6: __init__
# 需要導入模塊: from cloudinstall.placement.controller import PlacementController [as 別名]
# 或者: from cloudinstall.placement.controller.PlacementController import load [as 別名]
class Controller:
""" Controller for Juju deployments and Maas machine init """
def __init__(self, ui, config, loop):
self.ui = ui
self.ui.controller = self
self.config = config
self.loop = loop
self.juju_state = None
self.juju = None
self.maas = None
self.maas_state = None
self.nodes = []
self.juju_m_idmap = None # for single, {instance_id: machine id}
self.deployed_charm_classes = []
self.placement_controller = None
if not self.config.getopt('current_state'):
self.config.setopt('current_state',
ControllerState.INSTALL_WAIT.value)
def update(self, *args, **kwargs):
"""Render UI according to current state and reset timer
PegasusGUI only.
"""
interval = 1
current_state = self.config.getopt('current_state')
if current_state == ControllerState.PLACEMENT:
self.ui.render_placement_view(self.loop,
self.config,
self.commit_placement)
elif current_state == ControllerState.INSTALL_WAIT:
if self.ui.node_install_wait_view is None:
self.ui.render_node_install_wait(
message="Installer is initializing nodes. Please wait.")
else:
self.ui.node_install_wait_view.redraw_kitt()
interval = self.config.node_install_wait_interval
elif current_state == ControllerState.ADD_SERVICES:
def submit_deploy():
async.submit(self.deploy_new_services,
self.ui.show_exception_message)
self.ui.render_add_services_dialog(
submit_deploy, self.cancel_add_services)
elif current_state == ControllerState.SERVICES:
self.update_node_states()
else:
raise Exception("Internal error, unexpected display "
"state '{}'".format(current_state))
self.loop.redraw_screen()
AlarmMonitor.add_alarm(self.loop.set_alarm_in(interval, self.update),
"core-controller-update")
def update_node_states(self):
""" Updating node states
PegasusGUI only
"""
if not self.juju_state:
return
deployed_services = sorted(self.juju_state.services,
key=attrgetter('service_name'))
deployed_service_names = [s.service_name for s in deployed_services]
charm_classes = sorted(
[m.__charm_class__ for m in
utils.load_charms(self.config.getopt('charm_plugin_dir'))
if m.__charm_class__.charm_name in
deployed_service_names],
key=attrgetter('charm_name'))
self.nodes = list(zip(charm_classes, deployed_services))
if len(self.nodes) == 0:
return
else:
if not self.ui.services_view:
self.ui.render_services_view(
self.nodes, self.juju_state,
self.maas_state, self.config)
else:
self.ui.refresh_services_view(self.nodes, self.config)
def authenticate_juju(self):
uuid = self.config.juju_env['environ-uuid']
if not len(self.config.juju_env['state-servers']) > 0:
state_server = 'localhost:17070'
else:
state_server = self.config.juju_env['state-servers'][0]
url = path.join('wss://', state_server, 'environment', uuid, 'api')
self.juju = JujuClient(
url=url,
password=self.config.juju_api_password)
self.juju.login()
self.juju_state = JujuState(self.juju)
#.........這裏部分代碼省略.........
示例7: __init__
# 需要導入模塊: from cloudinstall.placement.controller import PlacementController [as 別名]
# 或者: from cloudinstall.placement.controller.PlacementController import load [as 別名]
class DisplayController:
""" Controller for displaying juju and maas state."""
def __init__(self, ui=None, opts=None):
self.ui = ui
self.opts = opts
self.config = Config()
self.juju_state = None
self.juju = None
self.maas = None
self.maas_state = None
self.nodes = None
self.placement_controller = None
self.current_state = ControllerState.INSTALL_WAIT
def authenticate_juju(self):
if not len(self.config.juju_env['state-servers']) > 0:
state_server = 'localhost:17070'
else:
state_server = self.config.juju_env['state-servers'][0]
self.juju = JujuClient(
url=path.join('wss://', state_server),
password=self.config.juju_api_password)
self.juju.login()
self.juju_state = JujuState(self.juju)
log.debug('Authenticated against juju api.')
def initialize(self):
"""Authenticates against juju/maas and sets up placement controller."""
if getenv("FAKE_API_DATA"):
self.juju_state = FakeJujuState()
self.maas_state = FakeMaasState()
else:
self.authenticate_juju()
if self.config.is_multi:
creds = self.config.maas_creds
self.maas, self.maas_state = connect_to_maas(creds)
self.placement_controller = PlacementController(
self.maas_state, self.opts)
if path.exists(self.config.placements_filename):
with open(self.config.placements_filename, 'r') as pf:
self.placement_controller.load(pf)
self.info_message("Loaded placements from file.")
else:
if self.config.is_multi:
def_assignments = self.placement_controller.gen_defaults()
else:
def_assignments = self.placement_controller.gen_single()
self.placement_controller.set_all_assignments(def_assignments)
pfn = self.config.placements_filename
self.placement_controller.set_autosave_filename(pfn)
self.placement_controller.do_autosave()
if self.config.is_single:
self.begin_deployment_async()
return
if self.opts.edit_placement or \
not self.placement_controller.can_deploy():
self.current_state = ControllerState.PLACEMENT
else:
self.begin_deployment_async()
def begin_deployment_async(self):
"""To be overridden in subclasses."""
pass
def begin_deployment(self):
"""To be overridden in subclasses."""
pass
# overlays
def step_info(self, message):
with dialog_context(self):
self.ui.show_step_info(message)
def show_password_input(self, title, cb):
with dialog_context(self):
self.ui.show_password_input(title, cb)
def show_maas_input(self, title, cb):
with dialog_context(self):
self.ui.show_maas_input(title, cb)
def show_landscape_input(self, title, cb):
with dialog_context(self):
self.ui.show_landscape_input(title, cb)
def show_selector_info(self, title, opts, cb):
with dialog_context(self):
self.ui.show_selector_info(title, opts, cb)
def show_selector_with_desc(self, title, install_types, cb):
#.........這裏部分代碼省略.........