+ ###
+ def sfa_configure(self):
+ "run sfa-config-tty"
+ tmpname=self.conffile("sfa-config-tty")
+ fileconf=open(tmpname,'w')
+ for var in [ 'SFA_REGISTRY_ROOT_AUTH',
+ 'SFA_INTERFACE_HRN',
+ 'SFA_REGISTRY_LEVEL1_AUTH',
+ 'SFA_REGISTRY_HOST',
+ 'SFA_AGGREGATE_HOST',
+ 'SFA_SM_HOST',
+ 'SFA_PLC_URL',
+ 'SFA_PLC_USER',
+ 'SFA_PLC_PASSWORD',
+ 'SFA_DB_HOST',
+ 'SFA_DB_USER',
+ 'SFA_DB_PASSWORD',
+ 'SFA_DB_NAME',
+ 'SFA_API_LOGLEVEL',
+ ]:
+ if self.plc_spec['sfa'].has_key(var):
+ fileconf.write ('e %s\n%s\n'%(var,self.plc_spec['sfa'][var]))
+ # the way plc_config handles booleans just sucks..
+ for var in []:
+ val='false'
+ if self.plc_spec['sfa'][var]: val='true'
+ fileconf.write ('e %s\n%s\n'%(var,val))
+ fileconf.write('w\n')
+ fileconf.write('R\n')
+ fileconf.write('q\n')
+ fileconf.close()
+ utils.system('cat %s'%tmpname)
+ self.run_in_guest_piped('cat %s'%tmpname,'sfa-config-tty')
+ return True
+
+ def aggregate_xml_line(self):
+ port=self.plc_spec['sfa']['neighbours-port']
+ return '<aggregate addr="%s" hrn="%s" port="%r"/>' % \
+ (self.vserverip,self.plc_spec['sfa']['SFA_REGISTRY_ROOT_AUTH'],port)
+
+ def registry_xml_line(self):
+ return '<registry addr="%s" hrn="%s" port="12345"/>' % \
+ (self.vserverip,self.plc_spec['sfa']['SFA_REGISTRY_ROOT_AUTH'])
+
+
+ # a cross step that takes all other plcs in argument
+ def cross_sfa_configure(self, other_plcs):
+ "writes aggregates.xml and registries.xml that point to all other PLCs in the test"
+ # of course with a single plc, other_plcs is an empty list
+ if not other_plcs:
+ return True
+ agg_fname=self.conffile("agg.xml")
+ file(agg_fname,"w").write("<aggregates>%s</aggregates>\n" % \
+ " ".join([ plc.aggregate_xml_line() for plc in other_plcs ]))
+ utils.header ("(Over)wrote %s"%agg_fname)
+ reg_fname=self.conffile("reg.xml")
+ file(reg_fname,"w").write("<registries>%s</registries>\n" % \
+ " ".join([ plc.registry_xml_line() for plc in other_plcs ]))
+ utils.header ("(Over)wrote %s"%reg_fname)
+ return self.test_ssh.copy_abs(agg_fname,'/vservers/%s/etc/sfa/aggregates.xml'%self.vservername)==0 \
+ and self.test_ssh.copy_abs(reg_fname,'/vservers/%s/etc/sfa/registries.xml'%self.vservername)==0
+
+ def sfa_import(self):
+ "sfa-import-plc"
+ auth=self.plc_spec['sfa']['SFA_REGISTRY_ROOT_AUTH']
+ return self.run_in_guest('sfa-import-plc.py')==0
+# not needed anymore
+# self.run_in_guest('cp /etc/sfa/authorities/%s/%s.pkey /etc/sfa/authorities/server.key'%(auth,auth))
+
+ def sfa_start(self):
+ "service sfa start"
+ return self.run_in_guest('service sfa start')==0
+
+ def sfi_configure(self):
+ "Create /root/sfi on the plc side for sfi client configuration"
+ if self.options.dry_run:
+ utils.header("DRY RUN - skipping step")
+ return True
+ sfa_spec=self.plc_spec['sfa']
+ # cannot use sfa_slice_mapper to pass dir_name
+ for slice_spec in self.plc_spec['sfa']['sfa_slice_specs']:
+ site_spec = self.locate_site (slice_spec['sitename'])
+ test_site = TestSite(self,site_spec)
+ test_slice=TestSliceSfa(self,test_site,slice_spec)
+ dir_name=self.confsubdir("dot-sfi/%s"%slice_spec['slicename'],clean=True,dry_run=self.options.dry_run)
+ test_slice.sfi_config(dir_name)
+ # push into the remote /root/sfi area
+ location = test_slice.sfi_path()
+ remote="/vservers/%s/%s"%(self.vservername,location)
+ self.test_ssh.mkdir(remote,abs=True)
+ # need to strip last level or remote otherwise we get an extra dir level
+ self.test_ssh.copy_abs(dir_name, os.path.dirname(remote), recursive=True)
+
+ return True
+
+ def sfi_clean (self):
+ "clean up /root/sfi on the plc side"
+ self.run_in_guest("rm -rf /root/sfi")
+ return True
+
+ @slice_sfa_mapper
+ def sfa_add_user(self):
+ "run sfi.py add"
+ pass
+
+ @slice_sfa_mapper
+ def sfa_update_user(self):
+ "run sfi.py update"
+
+ @slice_sfa_mapper
+ def sfa_add_slice(self):
+ "run sfi.py add (on Registry) from slice.xml"
+ pass
+
+ @slice_sfa_mapper
+ def sfa_discover(self):
+ "discover resources into resouces_in.rspec"
+ pass
+
+ @slice_sfa_mapper
+ def sfa_create_slice(self):
+ "run sfi.py create (on SM) - 1st time"
+ pass
+
+ @slice_sfa_mapper
+ def sfa_check_slice_plc(self):
+ "check sfa_create_slice at the plcs - all local nodes should be in slice"
+ pass
+
+ @slice_sfa_mapper
+ def sfa_update_slice(self):
+ "run sfi.py create (on SM) on existing object"
+ pass
+
+ @slice_sfa_mapper
+ def sfa_view(self):
+ "various registry-related calls"
+ pass
+
+ @slice_sfa_mapper
+ def ssh_slice_sfa(self):
+ "tries to ssh-enter the SFA slice"
+ pass
+
+ @slice_sfa_mapper
+ def sfa_delete_user(self):
+ "run sfi.py delete"
+ pass
+
+ @slice_sfa_mapper
+ def sfa_delete_slice(self):
+ "run sfi.py delete (on SM), sfi.py remove (on Registry) to clean slices"
+ pass
+
+ def sfa_stop(self):
+ "service sfa stop"
+ self.run_in_guest('service sfa stop')==0
+ return True
+
+ def populate (self):
+ "creates random entries in the PLCAPI"
+ # install the stress-test in the plc image
+ location = "/usr/share/plc_api/plcsh_stress_test.py"
+ remote="/vservers/%s/%s"%(self.vservername,location)
+ self.test_ssh.copy_abs("plcsh_stress_test.py",remote)
+ command = location
+ command += " -- --preserve --short-names"
+ local = (self.run_in_guest(command) == 0);
+ # second run with --foreign
+ command += ' --foreign'
+ remote = (self.run_in_guest(command) == 0);
+ return ( local and remote)