5 from dha import DeploymentHardwareAdapter
6 from dea import DeploymentEnvironmentAdapter
8 SUPPORTED_RELEASE = 'Juno on CentOS 6.5'
9 N = {'id': 0, 'status': 1, 'name': 2, 'cluster': 3, 'ip': 4, 'mac': 5,
10 'roles': 6, 'pending_roles': 7, 'online': 8}
11 E = {'id': 0, 'status': 1, 'name': 2, 'mode': 3, 'release_id': 4,
12 'changes': 5, 'pending_release_id': 6}
13 R = {'id': 0, 'name': 1, 'state': 2, 'operating_system': 3, 'version': 4}
14 RO = {'name': 0, 'conflicts': 1}
17 process = subprocess.Popen(cmd,
18 stdout=subprocess.PIPE,
19 stderr=subprocess.STDOUT,
21 return process.communicate()[0]
25 lines = printout.splitlines()
27 parsed = [e.strip() for e in l.split('|')]
28 parsed_list.append(parsed)
31 def err(error_message):
32 sys.stderr.write(error_message)
40 self.supported_release = None
42 def get_id_list(self, list):
43 return [l[0] for l in list]
45 def cleanup_fuel_environments(self, env_list):
48 id_list = self.get_id_list(env_list)
50 exec_cmd('fuel env --env %s --delete' % id)
51 for i in range(WAIT_LOOP):
52 if id in self.get_id_list(parse(exec_cmd('fuel env list'))):
53 time.sleep(SLEEP_TIME)
57 def cleanup_fuel_nodes(self, node_list):
58 for node in node_list:
59 if node[N['status']] == 'discover':
60 exec_cmd('fuel node --node-id %s --delete-from-db'
62 exec_cmd('dockerctl shell cobbler cobbler system remove '
63 '--name node-%s' % node[N['id']])
65 def check_previous_installation(self):
66 env_list = parse(exec_cmd('fuel env list'))
68 self.cleanup_fuel_environments(env_list)
69 node_list = parse(exec_cmd('fuel node list'))
71 self.cleanup_fuel_nodes(node_list)
73 def check_supported_release(self):
74 release_list= parse(exec_cmd('fuel release -l'))
75 for release in release_list:
76 if release[R['name']] == SUPPORTED_RELEASE:
77 self.supported_release = release
79 if not self.supported_release:
80 err("This Fuel doesn't contain the following "
81 "release: %s\n" % SUPPORTED_RELEASE)
83 def check_role_definitions(self):
84 role_list= parse(exec_cmd('fuel role --release %s'
85 % self.supported_release[R['id']]))
86 roles = [role[RO['name']] for role in role_list]
87 if 'compute' not in roles:
88 err("Role compute does not exist in release %"
89 % self.supported_release[R['name']])
90 if 'controller' not in roles:
91 err("Role controller does not exist in release %"
92 % self.supported_release[R['name']])
94 def check_prerequisites(self):
95 self.check_supported_release()
96 self.check_role_definitions()
97 self.check_previous_installation()
99 def count_discovered_nodes(self, node_list):
101 for node in node_list:
102 if node[N['status']] == 'discover':
103 discovered_nodes += 1
104 return discovered_nodes
106 def wait_for_discovered_blades(self, no_of_blades):
109 all_discovered = False
110 node_list = parse(exec_cmd('fuel node list'))
111 for i in range(WAIT_LOOP):
112 if (self.count_discovered_nodes(node_list) < no_of_blades):
113 time.sleep(SLEEP_TIME)
114 node_list = parse(exec_cmd('fuel node list'))
116 all_discovered = True
118 if not all_discovered:
119 err("There are %s blades defined, but not all of "
120 "them have been discovered\n" % no_of_blades)
122 def assign_cluster_node_ids(self, dha, dea, controllers, compute_hosts):
123 node_list= parse(exec_cmd('fuel node list'))
124 for shelf_id in dea.get_shelf_ids():
125 for blade_id in dea.get_blade_ids(shelf_id):
126 blade_mac_list = dha.get_blade_mac_addresses(
130 for node in node_list:
131 if (node[N['mac']] in blade_mac_list and
132 node[N['status']] == 'discover'):
136 if dea.is_controller(shelf_id, blade_id):
137 controllers.append(node[N['id']])
138 if dea.is_compute_host(shelf_id, blade_id):
139 compute_hosts.append(node[N['id']])
141 err("Could not find the Node ID for blade "
142 "with MACs %s or blade is not in "
143 "discover status\n" % blade_mac_list)
145 def env_exists(self, env_name):
146 env_list = parse(exec_cmd('fuel env --list'))
148 if env[E['name']] == env_name and env[E['status']] == 'new':
152 def configure_environment(self, dea):
153 env_name = dea.get_environment_name()
154 exec_cmd('fuel env -c --name %s --release %s --mode ha --net neutron '
155 '--nst vlan' % (env_name, self.supported_release[R['id']]))
157 if not self.env_exists(env_name):
158 err("Failed to create environment %s" % env_name)
164 yaml_path = exec_cmd('pwd').strip() + '/dea.yaml'
167 dea = DeploymentEnvironmentAdapter()
169 if not os.path.isfile(yaml_path):
170 sys.stderr.write("ERROR: File %s not found\n" % yaml_path)
173 dea.parse_yaml(yaml_path)
175 dha = DeploymentHardwareAdapter(dea.get_server_type())
177 deploy.check_prerequisites()
179 dha.power_off_blades()
181 dha.configure_networking()
183 dha.reset_to_factory_defaults()
187 dha.power_on_blades()
189 dha.get_blade_mac_addresses()
191 deploy.wait_for_discovered_blades(dea.get_no_of_blades())
195 deploy.assign_cluster_node_ids(dha, dea, controllers, compute_hosts)
197 deploy.configure_environment(dea)
201 if __name__ == '__main__':