X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/9dae71315a83504493952f9039de958594e45f31..87c9678022eb027f8d7f02129c1ec052205387d8:/services/nodemanager/tests/test_jobqueue.py diff --git a/services/nodemanager/tests/test_jobqueue.py b/services/nodemanager/tests/test_jobqueue.py index c20313913b..554ff1eb79 100644 --- a/services/nodemanager/tests/test_jobqueue.py +++ b/services/nodemanager/tests/test_jobqueue.py @@ -62,7 +62,7 @@ class ServerCalculatorTestCase(unittest.TestCase): {'min_ram_mb_per_node': 256}, {'min_nodes': 6}, {'min_nodes': 12}, - {'min_scratch_mb_per_node': 200}) + {'min_scratch_mb_per_node': 300000}) self.assertEqual(6, len(servlist)) def test_ignore_too_expensive_jobs(self): @@ -150,17 +150,47 @@ class JobQueueMonitorActorTestCase(testutil.RemotePollLoopActorTestMixin, @mock.patch("subprocess.check_output") def test_squeue_server_list(self, mock_squeue): - mock_squeue.return_value = """1 0 0 Resources zzzzz-zzzzz-zzzzzzzzzzzzzzy -2 0 0 Resources zzzzz-zzzzz-zzzzzzzzzzzzzzz + mock_squeue.return_value = """1|1024|0|Resources|zzzzz-zzzzz-zzzzzzzzzzzzzzy +2|1024|0|Resources|zzzzz-zzzzz-zzzzzzzzzzzzzzz """ super(JobQueueMonitorActorTestCase, self).build_monitor(jobqueue.ServerCalculator( - [(testutil.MockSize(n), {'cores': n, 'ram': n, 'scratch': n}) for n in range(1, 3)])) + [(testutil.MockSize(n), {'cores': n, 'ram': n*1024, 'scratch': n}) for n in range(1, 3)])) self.monitor.subscribe(self.subscriber).get(self.TIMEOUT) self.stop_proxy(self.monitor) self.subscriber.assert_called_with([testutil.MockSize(1), testutil.MockSize(2)]) + @mock.patch("subprocess.check_output") + def test_squeue_server_list_suffix(self, mock_squeue): + mock_squeue.return_value = """1|1024M|0|ReqNodeNotAvail, UnavailableNod|zzzzz-zzzzz-zzzzzzzzzzzzzzy +1|2G|0|ReqNodeNotAvail, UnavailableNod|zzzzz-zzzzz-zzzzzzzzzzzzzzz +""" + + super(JobQueueMonitorActorTestCase, self).build_monitor(jobqueue.ServerCalculator( + [(testutil.MockSize(n), {'cores': n, 'ram': n*1024, 'scratch': n}) for n in range(1, 3)])) + self.monitor.subscribe(self.subscriber).get(self.TIMEOUT) + self.stop_proxy(self.monitor) + self.subscriber.assert_called_with([testutil.MockSize(1), + testutil.MockSize(2)]) + + def test_coerce_to_mb(self): + self.assertEqual(1, jobqueue.JobQueueMonitorActor.coerce_to_mb("1")) + self.assertEqual(512, jobqueue.JobQueueMonitorActor.coerce_to_mb("512")) + self.assertEqual(512, jobqueue.JobQueueMonitorActor.coerce_to_mb("512M")) + self.assertEqual(1024, jobqueue.JobQueueMonitorActor.coerce_to_mb("1024M")) + self.assertEqual(1024, jobqueue.JobQueueMonitorActor.coerce_to_mb("1G")) + self.assertEqual(1536, jobqueue.JobQueueMonitorActor.coerce_to_mb("1.5G")) + self.assertEqual(2048, jobqueue.JobQueueMonitorActor.coerce_to_mb("2G")) + self.assertEqual(1025, jobqueue.JobQueueMonitorActor.coerce_to_mb("1025M")) + self.assertEqual(1048576, jobqueue.JobQueueMonitorActor.coerce_to_mb("1T")) + self.assertEqual(1572864, jobqueue.JobQueueMonitorActor.coerce_to_mb("1.5T")) + self.assertEqual(1073741824, jobqueue.JobQueueMonitorActor.coerce_to_mb("1P")) + self.assertEqual(1610612736, jobqueue.JobQueueMonitorActor.coerce_to_mb("1.5P")) + self.assertEqual(0, jobqueue.JobQueueMonitorActor.coerce_to_mb("0")) + self.assertEqual(0, jobqueue.JobQueueMonitorActor.coerce_to_mb("0M")) + self.assertEqual(0, jobqueue.JobQueueMonitorActor.coerce_to_mb("0G")) + if __name__ == '__main__': unittest.main()