X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/6d8a27a40903f0dc61876947cecc9401edd3a32c..ba534230bcc23aaea69e5f256693b9e143200b63:/services/nodemanager/tests/test_jobqueue.py diff --git a/services/nodemanager/tests/test_jobqueue.py b/services/nodemanager/tests/test_jobqueue.py index 3814ba4610..d4dc42f139 100644 --- a/services/nodemanager/tests/test_jobqueue.py +++ b/services/nodemanager/tests/test_jobqueue.py @@ -14,7 +14,9 @@ class ServerCalculatorTestCase(unittest.TestCase): def calculate(self, servcalc, *constraints): return servcalc.servers_for_queue( - [{'runtime_constraints': cdict} for cdict in constraints]) + [{'uuid': 'zzzzz-jjjjj-{:015x}'.format(index), + 'runtime_constraints': cdict} + for index, cdict in enumerate(constraints)]) def test_empty_queue_needs_no_servers(self): servcalc = self.make_calculator([1]) @@ -46,6 +48,64 @@ class ServerCalculatorTestCase(unittest.TestCase): {'min_scratch_mb_per_node': 200}) self.assertEqual(6, len(servlist)) + def test_ignore_too_expensive_jobs(self): + servcalc = self.make_calculator([1, 2], max_nodes=12, max_price=6) + servlist = self.calculate(servcalc, + {'min_cores_per_node': 1, 'min_nodes': 6}) + self.assertEqual(6, len(servlist)) + + servlist = self.calculate(servcalc, + {'min_cores_per_node': 2, 'min_nodes': 6}) + self.assertEqual(0, len(servlist)) + + def test_job_requesting_max_nodes_accepted(self): + servcalc = self.make_calculator([1], max_nodes=4) + servlist = self.calculate(servcalc, {'min_nodes': 4}) + self.assertEqual(4, len(servlist)) + + def test_cheapest_size(self): + servcalc = self.make_calculator([2, 4, 1, 3]) + self.assertEqual(testutil.MockSize(1), servcalc.cheapest_size()) + + def test_next_biggest(self): + servcalc = self.make_calculator([1, 2, 4, 8]) + servlist = self.calculate(servcalc, + {'min_cores_per_node': 3}, + {'min_cores_per_node': 6}) + self.assertEqual([servcalc.cloud_sizes[2].id, + servcalc.cloud_sizes[3].id], + [s.id for s in servlist]) + + def test_multiple_sizes(self): + servcalc = self.make_calculator([1, 2]) + servlist = self.calculate(servcalc, + {'min_cores_per_node': 2}, + {'min_cores_per_node': 1}, + {'min_cores_per_node': 1}) + self.assertEqual([servcalc.cloud_sizes[1].id, + servcalc.cloud_sizes[0].id, + servcalc.cloud_sizes[0].id], + [s.id for s in servlist]) + + servlist = self.calculate(servcalc, + {'min_cores_per_node': 1}, + {'min_cores_per_node': 2}, + {'min_cores_per_node': 1}) + self.assertEqual([servcalc.cloud_sizes[0].id, + servcalc.cloud_sizes[1].id, + servcalc.cloud_sizes[0].id], + [s.id for s in servlist]) + + servlist = self.calculate(servcalc, + {'min_cores_per_node': 1}, + {'min_cores_per_node': 1}, + {'min_cores_per_node': 2}) + self.assertEqual([servcalc.cloud_sizes[0].id, + servcalc.cloud_sizes[0].id, + servcalc.cloud_sizes[1].id], + [s.id for s in servlist]) + + class JobQueueMonitorActorTestCase(testutil.RemotePollLoopActorTestMixin, unittest.TestCase): @@ -63,12 +123,11 @@ class JobQueueMonitorActorTestCase(testutil.RemotePollLoopActorTestMixin, def test_subscribers_get_server_lists(self): self.build_monitor([{'items': [1, 2]}], self.MockCalculator()) - self.monitor.subscribe(self.subscriber) - self.wait_for_call(self.subscriber) + self.monitor.subscribe(self.subscriber).get(self.TIMEOUT) + self.stop_proxy(self.monitor) self.subscriber.assert_called_with([testutil.MockSize(1), testutil.MockSize(2)]) if __name__ == '__main__': unittest.main() -