- def add_slice(self):
- return self.test_plc.run_in_guest("sfi.py -d /root/.sfi/ add slice.xml")==0
-
- def create_slice(self):
- auth=self.test_plc.plc_spec['sfa']['SFA_REGISTRY_ROOT_AUTH']
- self.test_plc.run_in_guest("sfi.py -d /root/.sfi/ resources -o /root/.sfi/resources_in.rspec")
- self.test_plc.run_in_guest(
- "sfiListNodes.py -i /root/.sfi/resources_in.rspec -o /root/.sfi/all_nodes.txt")
- self.test_plc.run_in_guest(
- "sfiAddSliver.py -i /root/.sfi/resources_in.rspec -n /root/.sfi/all_nodes.txt -o /root/.sfi/resources_out.rspec")
- return self.test_plc.run_in_guest("sfi.py -d /root/.sfi/ create %s.main.fslc1 resources_out.rspec"%auth)==0
-
- def update_slice(self):
- auth=self.test_plc.plc_spec['sfa']['SFA_REGISTRY_ROOT_AUTH']
- self.test_plc.run_in_guest("sfi.py -d /root/.sfi/ resources -o /root/.sfi/resources_in.rspec")
- self.test_plc.run_in_guest(
- "sfiListNodes.py -i /root/.sfi/resources_in.rspec -o /root/.sfi/all_nodes.txt")
- self.test_plc.run_in_guest(
- "sfiAddSliver.py -i /root/.sfi/resources_in.rspec -n /root/.sfi/all_nodes.txt -o /root/.sfi/resources_out.rspec")
- return self.test_plc.run_in_guest("sfi.py -d /root/.sfi/ create %s.main.fslc1 resources_out.rspec"%auth)==0
-
- def delete_slice(self):
- auth=self.test_plc.plc_spec['sfa']['SFA_REGISTRY_ROOT_AUTH']
- self.test_plc.run_in_guest("sfi.py -d /root/.sfi/ delete %s.main.fslc1"%auth)
- return self.test_plc.run_in_guest("sfi.py -d /root/.sfi/ remove -t slice %s.main.fslc1"%auth)==0
-
- def check_slice_sfa(self,options,timeout_minutes=40,silent_minutes=30,period=15):
+ # dir_name is local and will be pushed later on by TestPlc
+ # by default set SFI_USER to the pi, we'll overload this
+ # on the command line when needed
+ def sfi_config (self,dir_name):
+ plc_spec=self.test_plc.plc_spec
+ sfa_spec=self.sfa_spec
+ sfa_slice_spec=self.sfa_slice_spec
+ # store private key for sfa pi user
+ file_name=dir_name + os.sep + self.qualified_hrn (self.piuser) + '.pkey'
+ fileconf=open(file_name,'w')
+ fileconf.write (plc_spec['keys'][0]['private'])
+ fileconf.close()
+ utils.header ("(Over)wrote %s"%file_name)
+ # store private key for sfa regular user
+ file_name=dir_name + os.sep + self.qualified_hrn(self.regularuser) + '.pkey'
+ fileconf=open(file_name,'w')
+ fileconf.write (plc_spec['keys'][1]['private'])
+ fileconf.close()
+ utils.header ("(Over)wrote %s"%file_name)
+ #
+ file_name=dir_name + os.sep + self.addpersonfile()
+ fileconf=open(file_name,'w')
+ fileconf.write(sfa_slice_spec['slice_person_xml'])
+ fileconf.write('\n')
+ fileconf.close()
+ utils.header ("(Over)wrote %s"%file_name)
+ #
+ file_name=dir_name + os.sep + 'sfi_config'
+ fileconf=open(file_name,'w')
+ SFI_AUTH="%s"%(self.site_hrn())
+ fileconf.write ("SFI_AUTH='%s'"%SFI_AUTH)
+ fileconf.write('\n')
+ SFI_USER=SFI_AUTH + '.' + self.piuser
+ fileconf.write ("SFI_USER='%s'"%SFI_USER)
+ fileconf.write('\n')
+ SFI_REGISTRY='http://' + sfa_spec['SFA_REGISTRY_HOST'] + ':12345/'
+ fileconf.write ("SFI_REGISTRY='%s'"%SFI_REGISTRY)
+ fileconf.write('\n')
+ SFI_SM='http://' + sfa_spec['SFA_SM_HOST'] + ':12347/'
+ fileconf.write ("SFI_SM='%s'"%SFI_SM)
+ fileconf.write('\n')
+ fileconf.close()
+ utils.header ("(Over)wrote %s"%file_name)
+ #
+ file_name=dir_name + os.sep + self.addslicefile()
+ fileconf=open(file_name,'w')
+ fileconf.write(sfa_slice_spec['slice_add_xml'])
+ fileconf.write('\n')
+ utils.header ("(Over)wrote %s"%file_name)
+ fileconf.close()
+
+ # user management
+ def sfa_add_user (self, options):
+ return TestUserSfa(self.test_plc, self.sfa_slice_spec, self).add_user()
+ def sfa_update_user (self, options):
+ return TestUserSfa(self.test_plc, self.sfa_slice_spec, self).update_user()
+ def sfa_delete_user (self, options):
+ return TestUserSfa(self.test_plc, self.sfa_slice_spec, self).delete_user()
+
+ # run as pi
+ def sfi_pi (self, command):
+ return "sfi.py -d %s -u %s %s"%(self.sfi_path(),self.qualified_hrn(self.piuser), command,)
+ # the sfi.py command line option to run as a regular user
+ def sfi_user (self, command):
+ return "sfi.py -d %s -u %s %s"%(self.sfi_path(),self.qualified_hrn(self.regularuser), command,)
+
+ # those are step names exposed as methods of TestPlc, hence the _sfa
+ def sfa_view (self, options):
+ "run (as regular user) sfi list and sfi show (both on Registry) and sfi slices (on SM)"
+ root_auth=self.test_plc.plc_spec['sfa']['SFA_REGISTRY_ROOT_AUTH']
+ return \
+ self.test_plc.run_in_guest(self.sfi_user("list %s"%(self.site_hrn())))==0 and \
+ self.test_plc.run_in_guest(self.sfi_user("show %s"%(self.site_hrn())))==0 and \
+ self.test_plc.run_in_guest(self.sfi_user("slices"))==0
+
+ # needs to be run as pi
+ def sfa_add_slice(self,options):
+ return self.test_plc.run_in_guest(self.sfi_pi("add %s"%(self.addslicefile())))==0
+
+ # run as user
+ def sfa_discover(self,options):
+ return self.test_plc.run_in_guest(self.sfi_user(\
+ "resources %s -o %s/%s"% (self.discover_option(),self.sfi_path(),self.adfile())))==0
+
+ # run sfi create as a regular user
+ def sfa_create_slice(self,options):
+ commands=[
+ "sfiListNodes.py -i %s/%s -o %s/%s"%(self.sfi_path(),self.adfile(),self.sfi_path(),self.nodefile()),
+ "sfiAddSliver.py -i %s/%s -n %s/%s -o %s/%s"%\
+ (self.sfi_path(),self.adfile(),self.sfi_path(),self.nodefile(),self.sfi_path(),self.reqfile()),
+ self.sfi_user("create %s %s"%(self.hrn(),self.reqfile())),
+ ]
+ for command in commands:
+ if self.test_plc.run_in_guest(command)!=0: return False
+ return True
+
+ # all local nodes in slice ?
+ def sfa_check_slice_plc (self,options):
+ slice_fields = self.sfa_slice_spec['slice_fields']
+ slice_name = slice_fields['name']
+ slice=self.test_plc.apiserver.GetSlices(self.test_plc.auth_root(), slice_name)[0]
+ nodes=self.test_plc.apiserver.GetNodes(self.test_plc.auth_root(), {'peer_id':None})
+ result=True
+ for node in nodes:
+ if node['node_id'] in slice['node_ids']:
+ utils.header("local node %s found in slice %s"%(node['hostname'],slice['name']))
+ else:
+ utils.header("ERROR - local node %s NOT FOUND in slice %s"%(node['hostname'],slice['name']))
+ result=False
+ return result
+
+ # actually the same for now
+ def sfa_update_slice(self,options):
+ return self.sfa_create_slice(options)
+
+ # run as pi
+ def sfa_delete_slice(self,options):
+ self.test_plc.run_in_guest(self.sfi_pi("delete %s"%(self.hrn(),)))
+ return self.test_plc.run_in_guest(self.sfi_pi("remove -t slice %s"%(self.hrn(),)))==0
+
+ # check the resulting sliver
+ def ssh_slice_sfa(self,options,timeout_minutes=40,silent_minutes=30,period=15):