7 from TestNode import TestNode
8 from TestUser import TestUser
9 from TestKey import TestKey
13 def __init__ (self,test_plc,site_spec):
14 self.test_plc=test_plc
15 self.site_spec=site_spec
18 return self.site_spec['site_fields']['login_base']
20 def create_site (self):
21 print self.test_plc.auth_root()
22 self.test_plc.server.AddSite(self.test_plc.auth_root(),
23 self.site_spec['site_fields'])
24 self.test_plc.server.AddSiteAddress(self.test_plc.auth_root(),self.name(),
25 self.site_spec['address_fields'])
27 def create_users (self):
28 for user_spec in self.site_spec['users']:
29 test_user=TestUser(self.test_plc,self,user_spec)
30 test_user.create_user()
33 def delete_site (self):
34 print self.test_plc.auth_root()
35 self.test_plc.server.DeleteSite(self.test_plc.auth_root(),self.name())
38 def delete_users(self):
39 for user_spec in self.site_spec['users']:
40 test_user=TestUser(self.test_plc,self,user_spec)
41 test_user.delete_user()
43 def locate_user (self,username):
44 for user in self.site_spec['users']:
45 if user['name'] == username:
47 if user['user_fields']['email'] == username:
49 raise Exception,"Cannot locate user %s"%username
51 def locate_node (self,nodename):
52 for node in self.site_spec['nodes']:
53 if node['node_fields']['hostname'] == nodename:
55 raise Exception,"Cannot locate node %s"%nodename
57 def start_nodes (self,options):
58 for node_spec in self.site_spec['nodes']:
59 TestNode(self.test_plc, self, node_spec).start_node(options)
62 def delete_known_hosts(self):
63 utils.header("Messing with known_hosts (cleaning hostnames starting with 'test[0-9]')")
64 sed_command="sed -i -e '/^test[0-9]/d' /root/.ssh/known_hosts"
65 utils.system(sed_command)
67 # xxx should be attached to TestPlc
68 def check_slices(self):
73 self.delete_known_hosts()
74 start_time = datetime.datetime.now()
75 dead_time=start_time + datetime.timedelta(minutes=3)##adding 3minutes
76 for slice_spec in self.test_plc.plc_spec['slices']:
77 for hostname in slice_spec['nodenames']:
78 slicename=slice_spec['slice_fields']['name']
79 # locate the first avail. key
81 for username in slice_spec['usernames']:
82 user_spec=self.locate_user(username)
83 for keyname in user_spec['keynames']:
84 key_spec=self.test_plc.locate_key(keyname)
85 publickey=TestKey(self.test_plc,key_spec).publicpath()
86 privatekey=TestKey(self.test_plc,key_spec).privatepath()
87 if os.path.isfile(publickey) and os.path.isfile(privatekey):
91 raise Exception,"Cannot find a valid key for slice %s"%slicename
94 utils.header('restarting nm on %s'%hostname)
95 access=utils.system('ssh -i /etc/planetlab/root_ssh_key.rsa root@%s service nm restart'%hostname )
97 utils.header('nm restarted on %s'%hostname)
99 utils.header('trying to connect to %s@%s'%(slicename,hostname))
100 ### should use saved keys instead of this hard-coded stuff
101 Date=utils.system('ssh -i %s %s@%s date'%(privatekey,slicename,hostname))
104 elif ( start_time <= dead_time ) :
105 start_time=datetime.datetime.now()+ datetime.timedelta(seconds=30)
110 utils.header('connected to %s@%s -->'%(slicename,hostname))
112 utils.header('%s@%s : last chance - restarting nm on %s'%(slicename,hostname,hostname))
113 access=utils.system('ssh -i /etc/planetlab/root_ssh_key.rsa root@%s service nm restart'%hostname)
115 utils.header('trying to connect (2) to %s@%s'%(slicename,hostname))
116 Date=utils.system('ssh -i ~/.ssh/slices.rsa %s@%s date'%(slicename,hostname))
118 utils.header('connected to %s@%s -->'%(slicename,hostname))
120 utils.header('giving up with to %s@%s -->'%(slicename,hostname))
123 utils.header('Last chance failed on %s@%s -->'%(slicename,hostname))
125 elif ( start_time <= dead_time ) :
126 start_time=datetime.datetime.now()+ datetime.timedelta(minutes=1)