summaryrefslogtreecommitdiffstats
path: root/conductor
diff options
context:
space:
mode:
Diffstat (limited to 'conductor')
-rw-r--r--conductor/conductor/tests/unit/reservation/test_service.py105
1 files changed, 105 insertions, 0 deletions
diff --git a/conductor/conductor/tests/unit/reservation/test_service.py b/conductor/conductor/tests/unit/reservation/test_service.py
new file mode 100644
index 0000000..210d85a
--- /dev/null
+++ b/conductor/conductor/tests/unit/reservation/test_service.py
@@ -0,0 +1,105 @@
+#
+# -------------------------------------------------------------------------
+# Copyright (C) 2019 IBM.
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# -------------------------------------------------------------------------
+#
+
+"""Test class for reservation service"""
+
+import unittest
+from conductor.reservation.service import ReservationServiceLauncher as ReservationServiceLauncher
+from conductor.reservation.service import ReservationService
+from conductor.common.models import plan
+from conductor.common.music.model import base
+from oslo_config import cfg
+from conductor.common.music import api
+import uuid
+from mock import patch
+import json
+
+def plan_prepare(conf):
+ music = api.API()
+ music.keyspace_create(keyspace=conf.keyspace)
+ plan_tmp = base.create_dynamic_model(
+ keyspace=conf.keyspace, baseclass=plan.Plan, classname="Plan")
+ return plan_tmp
+
+
+CONF = cfg.CONF
+
+
+class TestReservationService(unittest.TestCase):
+
+ @patch('conductor.common.music.model.base.Base.table_create')
+ @patch('conductor.common.music.model.base.Base.insert')
+ @patch('conductor.reservation.service.ReservationService._reset_reserving_status')
+ def setUp(self, mock_reset, mock_insert, mock_table_create):
+
+ self.conf = cfg.CONF
+ self.Plan = plan_prepare(self.conf)
+ kwargs = self.Plan
+ name = str(uuid.uuid4())
+ timeout = 10000
+ recommend_max = 3
+ template = None
+ status = self.Plan.TEMPLATE
+ self.mock_plan = self.Plan(name, timeout, recommend_max, template,
+ status=status)
+ self.service = ReservationService(
+ worker_id=1, conf=self.conf, plan_class=kwargs)
+ self.service.music.keyspace_create(keyspace=self.conf.keyspace)
+
+ self.rl = ReservationServiceLauncher(self.conf)
+
+ def test_current_time_seconds(self):
+ self.assertIsInstance(self.service.current_time_seconds(), int)
+
+ def test_millisec_to_sec(self):
+ self.assertEqual(2, self.service.millisec_to_sec(2000))
+
+ def test_rollback_reservation(self):
+ reservation_list = list()
+ self.assertEqual(True, self.service.rollback_reservation(reservation_list))
+
+ @patch('conductor.common.music.model.base.Base.insert')
+ @patch('conductor.common.music.model.search.Query.get_plan_by_col')
+ @patch('conductor.common.music.model.base.Base.update')
+ def test_reset_reserving_status(self, mock_call, mock_update, mock_insert):
+ mock_plan = self.Plan(str(uuid.uuid4()),
+ 100000,
+ 3, None,
+ status=self.Plan.RESERVING)
+ mock_call.return_value = mock_plan
+ self.service._reset_reserving_status()
+ mock_update.assert_called_once()
+
+ @patch('conductor.reservation.service.ReservationService._gracefully_stop')
+ def test_terminate(self, mock_stop):
+ self.service.terminate()
+ mock_stop.assert_called_once()
+ self.assertFalse(self.service.running)
+
+ @patch('conductor.reservation.service.ReservationService._restart')
+ def test_reload(self, mock_restart):
+ self.service.reload()
+ mock_restart.assert_called_once()
+
+ def tearDown(self):
+ patch.stopall()
+
+
+if __name__ == '__main__':
+ unittest.main()