'key': public_key}}
]
-def initscripts(options,index):
- initscripts= [ { 'initscript_fields' :
- { 'enabled' : True,
- 'name':'script1',
- 'script' : """#! /bin/sh
-(echo Starting test initscript: script1; date) >> /tmp/script1.stamp
-# expected to be 'start'
-command=$1; shift
-# get slice name
-slicename=$1; shift
-echo "This is the stdout of the sliver $slicename initscript $command (exp. start) pid=$$"
-echo "This is the stderr of the sliver $slicename initscript $command (exp. start) pid=$$" 1>&2
-""",
- }},
- { 'initscript_fields' :
- { 'enabled' : True,
- 'name':'script2',
- 'script' : """#! /bin/sh
-(echo Starting loop-forever test initscript: script2; date) >> /tmp/script2.stamp
-# expected to be 'start'
+
+############################## initscripts
+initscript_by_name="""#! /bin/sh
command=$1; shift
-# get slice name
slicename=$1; shift
-while true; do
-echo "This is the stdout of the loop-for-ever sliver initscript $slicename $command (exp. start) $$"
-echo "This is the stderr of the loop-for-ever sliver initscript $slicename $command (exp. start) $$" 1>&2
-sleep 10
-done
-""",
- }},
- ]
- return initscripts
+stamp="the_script_name"
+stampfile=/tmp/$stamp.stamp
+
+echo "Running initscript with command=$command and slicename=$slicename"
+function start () {
+ (echo Starting test initscript: $stamp on slicename $slicename ; date) >> $stampfile
+ echo "This is the stdout of the sliver $slicename initscript $command (exp. start) pid=$$"
+ echo "This is the stderr of the sliver $slicename initscript $command (exp. start) pid=$$" 1>&2
+}
+function stop () {
+ echo "Removing stamp $stampfile"
+ rm -f $stampfile
+}
+function restart () {
+ stop
+ start
+}
+case $command in
+start) start ;;
+stop) stop ;;
+restart) restart ;;
+*) echo "Unknown command in initscript $command" ;;
+esac
+"""
+
+initscript_by_body=initscript_by_name.replace("the_script_name","the_script_body")
+
+# one single initscript in the InitScripts table
+def initscripts(options,index):
+ return [ { 'initscript_fields' : { 'enabled' : True,
+ 'name':'the_script_name',
+ 'script' : initscript_by_name,
+ }},
+ ]
+
+# always return 2 slices
+# one has an initscript body, the other one an initscript name
def slices (options,index):
- return [ { 'slice_fields': {'name':'%s_pslc%d'%(login_base(index),i),
- 'instantiation':'plc-instantiated',
- 'url':'http://foo.com',
- 'description':'testslice number %d'%i,
- 'max_nodes':2,
- },
- 'usernames' : [ 'pi','tech','techuser' ],
- 'nodenames' : all_nodenames(options,index),
- 'initscriptname' : 'script%d'%(((i-1)%2)+1),
- 'sitename' : login_base(index),
- 'owner' : 'pi',
- } for i in range (2*index-1,2*index+1) ]
+ def theslice (i):
+ slice_spec = { 'slice_fields': {'name':'%s_pslc%d'%(login_base(index),i),
+ 'instantiation':'plc-instantiated',
+ 'url':'http://foo%d.com'%index,
+ 'description':'testslice number %d'%i,
+ 'max_nodes':2,
+ },
+ 'usernames' : [ 'pi','tech','techuser' ],
+ 'nodenames' : all_nodenames(options,index),
+ 'sitename' : login_base(index),
+ 'owner' : 'pi',
+ }
+ # odd one has an initscript_body
+ if i%2==1:
+ slice_spec['initscriptbody']=initscript_by_body
+ slice_spec['initscriptstamp']='the_script_body'
+ # even one has an initscript (name)
+ else:
+ slice_spec['initscriptname']='the_script_name'
+ slice_spec['initscriptstamp']='the_script_name'
+ return slice_spec
+ return [ theslice(i) for i in range (2*index-1,2*index+1) ]
def all_slicenames (options,index):
return [ slice['slice_fields']['name'] for slice in slices(options,index)]
elif index == 2:
return [
# remote test
- { 'server_node': 'node1',
- 'server_slice' : '%s_pslc1'%login_base(index),
+ { 'server_node': 'node2',
+ 'server_slice' : '%s_pslc3'%login_base(index),
'client_node' : 'node2',
- 'client_slice' : '%s_pslc2'%login_base(index),
+ 'client_slice' : '%s_pslc4'%login_base(index),
'port' : 4000,
},
]
'PLC_SLICE_PREFIX' : 'auto',
'PLC_SHORTNAME' : 'Rlab',
'PLC_MAIL_ENABLED':'false',
- 'PLC_MAIL_SUPPORT_ADDRESS' : 'thierry.parmentelat@sophia.inria.fr',
+ 'PLC_MAIL_SUPPORT_ADDRESS' : 'thierry.parmentelat@inria.fr',
'PLC_DB_HOST' : 'deferred-myplc-hostname',
'PLC_DB_PASSWORD' : 'mnbvcxzlkjhgfdsapoiuytrewq',
'PLC_API_HOST' : 'deferred-myplc-hostname',
'PLC_NET_DNS1' : 'deferred-dns-1',
'PLC_NET_DNS2' : 'deferred-dns-2',
'PLC_RESERVATION_GRANULARITY':1800,
- 'PLC_OMF_ENABLED' : 'false',
+ # minimal config so the omf plugins actually trigger
+ 'PLC_OMF_ENABLED' : 'true',
+ 'PLC_OMF_XMPP_SERVER': 'deferred-myplc-hostname',
'sites' : sites(options,index),
'keys' : keys(options,index),
'initscripts': initscripts(options,index),
'SFA_PLC_DB_USER' : 'pgsqluser',
'SFA_PLC_DB_PASSWORD' : 'mnbvcxzlkjhgfdsapoiuytrewq',
'SFA_PLC_URL' : 'deferred-myplc-api-url',
+ 'SFA_API_DEBUG': True,
'sfa_slice_specs' : sfa_slice_specs(options,index,slicename,regularuser),
'sfa_slice_xml' : sfa_slice_xml(options,index,piuser,slicename),
'sfa_person_xml' : sfa_person_xml(options,index,regularuser),