X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/0d50e82dd2255104e60c0882045b54774e1be380..cf0c4c381a2b34130f072096038a430e3c6bbe55:/services/nodemanager/tests/integration_test.py diff --git a/services/nodemanager/tests/integration_test.py b/services/nodemanager/tests/integration_test.py index 1699b57390..1ba2957ee5 100755 --- a/services/nodemanager/tests/integration_test.py +++ b/services/nodemanager/tests/integration_test.py @@ -12,7 +12,7 @@ events or behaviors for each test. """ -import subprocess +import subprocess32 as subprocess import os import sys import re @@ -106,18 +106,6 @@ def node_paired(g): return 0 -def remaining_jobs(g): - update_script(os.path.join(fake_slurm, "sinfo"), "#!/bin/sh\n" + - "\n".join("echo '%s|alloc|(null)'" % (v) for k,v in compute_nodes.items())) - - for k,v in all_jobs.items(): - all_jobs[k] = "Running" - - set_squeue(g) - - return 0 - - def node_busy(g): update_script(os.path.join(fake_slurm, "sinfo"), "#!/bin/sh\n" + "\n".join("echo '%s|idle|(null)'" % (v) for k,v in compute_nodes.items())) @@ -125,8 +113,12 @@ def node_busy(g): def node_shutdown(g): global compute_nodes - del compute_nodes[g.group(1)] - return 0 + if g.group(1) in compute_nodes: + del compute_nodes[g.group(1)] + return 0 + else: + return 1 + def jobs_req(g): global all_jobs @@ -187,8 +179,8 @@ def run_test(name, actions, checks, driver_class, jobs, provider): driver_class=driver_class, ssh_key=os.path.join(fake_slurm, "id_rsa.pub"))) - # Tests must complete in less than 3 minutes. - timeout = time.time() + 180 + # Tests must complete in less than 30 seconds. + timeout = time.time() + 30 terminated = False # Now start node manager @@ -216,7 +208,7 @@ def run_test(name, actions, checks, driver_class, jobs, provider): if code != 0: detail.error("Check failed") if not terminated: - p.terminate() + p.kill() terminated = True if terminated: @@ -226,7 +218,7 @@ def run_test(name, actions, checks, driver_class, jobs, provider): detail.error("Exceeded timeout with actions remaining: %s", actions) code += 1 if not terminated: - p.terminate() + p.kill() terminated = True k, v = actions[0] @@ -237,11 +229,11 @@ def run_test(name, actions, checks, driver_class, jobs, provider): code += v(g) if code != 0: detail.error("Action failed") - p.terminate() + p.kill() terminated = True if not actions: - p.terminate() + p.kill() terminated = True except KeyboardInterrupt: p.kill() @@ -333,7 +325,6 @@ def main(): ], # Checks (things that shouldn't happen) { - r".*Suggesting shutdown because node state is \('down', .*\)": fail, r".*Cloud node (\S+) is now paired with Arvados node (\S+) with hostname (\S+)": partial(expect_count, 4), r".*Setting node quota.*": fail, }, @@ -353,13 +344,12 @@ def main(): (r".*Cloud node (\S+) is now paired with Arvados node (\S+) with hostname (\S+)", node_paired), (r".*Cloud node (\S+) is now paired with Arvados node (\S+) with hostname (\S+)", node_paired), (r".*ComputeNodeMonitorActor\..*\.([^[]*).*Not eligible for shut down because node state is \('busy', 'open', .*\)", node_busy), - (r".*ComputeNodeMonitorActor\..*\.([^[]*).*Suggesting shutdown because node state is \('idle', 'open', .*\)", remaining_jobs), + (r".*ComputeNodeMonitorActor\..*\.([^[]*).*Suggesting shutdown because node state is \('idle', 'open', .*\)", noop), (r".*ComputeNodeShutdownActor\..*\.([^[]*).*Shutdown success", node_shutdown), (r".*ComputeNodeShutdownActor\..*\.([^[]*).*Shutdown success", node_shutdown) ], # Checks (things that shouldn't happen) { - r".*Suggesting shutdown because node state is \('down', .*\)": fail, r".*Cloud node (\S+) is now paired with Arvados node (\S+) with hostname (\S+)": partial(expect_count, 2), r".*Sending create_node request.*": partial(expect_count, 5) }, @@ -379,7 +369,7 @@ def main(): (r".*Cloud node (\S+) is now paired with Arvados node (\S+) with hostname (\S+)", node_paired), (r".*Cloud node (\S+) is now paired with Arvados node (\S+) with hostname (\S+)", node_paired), (r".*ComputeNodeMonitorActor\..*\.([^[]*).*Not eligible for shut down because node state is \('busy', 'open', .*\)", node_busy), - (r".*ComputeNodeMonitorActor\..*\.([^[]*).*Suggesting shutdown because node state is \('idle', 'open', .*\)", remaining_jobs), + (r".*ComputeNodeMonitorActor\..*\.([^[]*).*Suggesting shutdown because node state is \('idle', 'open', .*\)", noop), (r".*ComputeNodeShutdownActor\..*\.([^[]*).*Shutdown success", node_shutdown), (r".*ComputeNodeShutdownActor\..*\.([^[]*).*Shutdown success", node_shutdown), (r".*sending request", jobs_req), @@ -396,7 +386,6 @@ def main(): ], # Checks (things that shouldn't happen) { - r".*Suggesting shutdown because node state is \('down', .*\)": fail, r".*Cloud node (\S+) is now paired with Arvados node (\S+) with hostname (\S+)": partial(expect_count, 6), r".*Sending create_node request.*": partial(expect_count, 9) }, @@ -433,8 +422,8 @@ def main(): # Actions (pattern -> action) [ (r".*Daemon started", set_squeue), - (r".*Rate limit exceeded - scheduling retry in 12 seconds", noop), (r".*Rate limit exceeded - scheduling retry in 2 seconds", noop), + (r".*Rate limit exceeded - scheduling retry in 1 seconds", noop), (r".*Cloud node (\S+) is now paired with Arvados node (\S+) with hostname (\S+)", noop), ], # Checks (things that shouldn't happen) @@ -456,7 +445,6 @@ def main(): ], # Checks (things that shouldn't happen) { - r".*Suggesting shutdown because node state is \('down', .*\)": fail, r".*Cloud node (\S+) is now paired with Arvados node (\S+) with hostname (\S+)": partial(expect_count, 1), r".*Setting node quota.*": fail, }, @@ -477,7 +465,6 @@ def main(): ], # Checks (things that shouldn't happen) { - r".*Suggesting shutdown because node state is \('down', .*\)": fail, r".*Cloud node (\S+) is now paired with Arvados node (\S+) with hostname (\S+)": partial(expect_count, 1), r".*Setting node quota.*": fail, },