X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/bb91f86ea02e3535e3953ee0916dd6877bf585f7..59a972c831bc8f7cd4e896ed8e1c71277b97f04e:/services/nodemanager/tests/test_status.py diff --git a/services/nodemanager/tests/test_status.py b/services/nodemanager/tests/test_status.py index a236e4f0ee..2a1c0fc589 100644 --- a/services/nodemanager/tests/test_status.py +++ b/services/nodemanager/tests/test_status.py @@ -7,6 +7,8 @@ from __future__ import absolute_import, print_function from future import standard_library import json +import mock +import random import requests import unittest @@ -56,6 +58,45 @@ class StatusServerUpdates(unittest.TestCase): resp = r.json() self.assertEqual(n, resp['nodes_'+str(n)]) self.assertEqual(1, resp['nodes_1']) + self.assertIn('Version', resp) + self.assertIn('config_max_nodes', resp) + + def test_counters(self): + with TestServer() as srv: + resp = srv.get_status() + # Test counters existance + for counter in ['list_nodes_errors', 'create_node_errors', + 'destroy_node_errors', 'boot_failures', 'actor_exceptions']: + self.assertIn(counter, resp) + # Test counter increment + for count in range(1, 3): + status.tracker.counter_add('a_counter') + resp = srv.get_status() + self.assertEqual(count, resp['a_counter']) + + @mock.patch('time.time') + def test_idle_times(self, time_mock): + with TestServer() as srv: + resp = srv.get_status() + node_name = 'idle_compute{}'.format(random.randint(1, 1024)) + self.assertIn('idle_times', resp) + # Test add an idle node + time_mock.return_value = 10 + status.tracker.idle_in(node_name) + time_mock.return_value += 10 + resp = srv.get_status() + self.assertEqual(10, resp['idle_times'][node_name]) + # Test adding the same idle node a 2nd time + time_mock.return_value += 10 + status.tracker.idle_in(node_name) + time_mock.return_value += 10 + resp = srv.get_status() + # Idle timestamp doesn't get reset if already exists + self.assertEqual(30, resp['idle_times'][node_name]) + # Test remove idle node + status.tracker.idle_out(node_name) + resp = srv.get_status() + self.assertNotIn(node_name, resp['idle_times']) class StatusServerDisabled(unittest.TestCase):