From f063223e726367835d4f2a9a211bf5a835ca6dd2 Mon Sep 17 00:00:00 2001 From: davidplunkett Date: Thu, 28 Mar 2019 16:08:27 +0000 Subject: [PATCH] add force to rm and update bios in parallel Change-Id: I4f365676acd1eaf5c16b8a1f123cf9c5feec74ea Signed-off-by: davidplunkett --- scripts/update_bios_settings.py | 20 ++++++++++++++++---- tools/1prom-gen.sh | 2 +- 2 files changed, 17 insertions(+), 5 deletions(-) diff --git a/scripts/update_bios_settings.py b/scripts/update_bios_settings.py index 3b7f522..7fac2e7 100644 --- a/scripts/update_bios_settings.py +++ b/scripts/update_bios_settings.py @@ -1,3 +1,4 @@ + ############################################################################## # Copyright (c) 2018 AT&T Intellectual Property. All rights reserved. # # # @@ -24,10 +25,10 @@ def create_node_rcfile(nodes, defaults, j2template, rcfile_suffix): env = jinja2.Environment() env.trim_blocks = True env.lstrip_blocks = True - + with open(j2template) as fd: template = env.from_string(fd.read()) - + if type(nodes) is list: for node in nodes: newnode = dict( defaults.items() + node.items() ) @@ -50,8 +51,9 @@ def create_node_rcfile(nodes, defaults, j2template, rcfile_suffix): if newnode['vendor'] == "HP" or newnode['vendor'] == "HPE": command = '/opt/akraino/redfish/apply_hpejson.sh --rc {0} --template {1} --no-confirm'.format(rcfile, newnode["bios_template"]) if command: - print 'command: {0}'.format(command) - os.system(command) + p=subprocess.Popen(command.split(), stdout=subprocess.PIPE, stderr=subprocess.STDOUT, close_fds=True, preexec_fn=os.setsid) + print 'process: {} command: {}'.format(p.pid, command) + plist.append(p) ### MAIN ### if len(sys.argv) != 2: @@ -61,6 +63,9 @@ if len(sys.argv) != 2: with open(sys.argv[1]) as f: siteyaml = yaml.safe_load(f) +# list of background processes created +plist = [] + # create set of defaults based on top level ipmi_admin and hardware key/value pairs defaults = dict( siteyaml["ipmi_admin"].items() + siteyaml["hardware"].items() ) @@ -79,3 +84,10 @@ if 'masters' in siteyaml: if 'workers' in siteyaml: create_node_rcfile(siteyaml["workers"], defaults, "tools/j2/serverrc_raid.j2", "rc.raid") +# print output from background processes +for p in plist: + print "waiting for process {}".format(p.pid) + exitcode=p.wait() + print 'Process {0} ended with exit code {1}'.format(p.pid, p.returncode) + print p.communicate()[0] + diff --git a/tools/1prom-gen.sh b/tools/1prom-gen.sh index 68ab018..2040635 100755 --- a/tools/1prom-gen.sh +++ b/tools/1prom-gen.sh @@ -104,7 +104,7 @@ create_scripts() { } prepare_tar(){ - rm ./tars/promenade-bundle-$SITE.tar + rm -f ./tars/promenade-bundle-$SITE.tar tar cvf ./tars/promenade-bundle-$SITE.tar -C ./tars/$SITE . } -- 2.16.6