import collections import ci_site_config import subprocess import sys def get_node_name(host, interface): # This is the pattern we follow in SFS team cluster return "%s-%s" % (host, interface) def run_command(command): print(" ".join(command)) p = subprocess.Popen(command, stdout=subprocess.PIPE, text=True) print(p.returncode) while True: out = p.stdout.read(1) if (out == "" and p.poll() != None): break if (out != ""): sys.stdout.write(out) sys.stdout.flush() if (p.returncode != 0): print("exiting with " + str(p.poll())) sys.exit(p.returncode) Prov = collections.namedtuple('Prov', 'core util') prov_list = [ Prov("psm2", None), Prov("verbs", None), Prov("verbs", "rxd"), Prov("verbs", "rxm"), Prov("sockets", None), Prov("tcp", None), Prov("udp", None), Prov("udp", "rxd"), Prov("shm", None), ] enabled_prov_list = [ "psm2", "verbs", "tcp", "sockets", "udp", "shm" ] disabled_prov_list = [ 'usnic', 'psm', 'efa', 'perf', 'rstream', 'hook_debug', 'bgq' 'mrail' ]