* use new format of a runner section
the schemas of existing plugins are changed to not include "type"
* use "contexts" key instead of "context"
note: the database model still operates the word "context". hope it
will be fixed soon while extendind abilities of contexts
* use new format of a hook section
Change-Id: I2ef6ba7a24b542fb001bce378cadf8c83c774b01
70 lines
2.7 KiB
Python
70 lines
2.7 KiB
Python
# Copyright 2016: Mirantis Inc.
|
|
# All Rights Reserved.
|
|
#
|
|
# 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.
|
|
|
|
import ddt
|
|
import mock
|
|
|
|
from rally.plugins.common.hook.triggers import event
|
|
from rally.task import hook
|
|
from tests.unit import test
|
|
|
|
|
|
@ddt.ddt
|
|
class EventTriggerTestCase(test.TestCase):
|
|
|
|
def setUp(self):
|
|
super(EventTriggerTestCase, self).setUp()
|
|
self.hook_cls = mock.MagicMock(__name__="name")
|
|
self.trigger = event.EventTrigger(
|
|
{"trigger": ("event", {"unit": "iteration", "at": [1, 4, 5]}),
|
|
"action": ("foo", {})},
|
|
mock.MagicMock(), self.hook_cls)
|
|
|
|
@ddt.data((dict(unit="time", at=[0, 3, 5]), True),
|
|
(dict(unit="time", at=[2, 2]), False),
|
|
(dict(unit="time", at=[-1]), False),
|
|
(dict(unit="time", at=[1.5]), False),
|
|
(dict(unit="time", at=[]), False),
|
|
(dict(unit="time", wrong_prop=None), False),
|
|
(dict(unit="time"), False),
|
|
(dict(unit="iteration", at=[1, 5, 13]), True),
|
|
(dict(unit="iteration", at=[1, 1]), False),
|
|
(dict(unit="iteration", at=[0]), False),
|
|
(dict(unit="iteration", at=[-1]), False),
|
|
(dict(unit="iteration", at=[1.5]), False),
|
|
(dict(unit="iteration", at=[]), False),
|
|
(dict(unit="iteration", wrong_prop=None), False),
|
|
(dict(unit="iteration"), False),
|
|
(dict(unit="wrong-unit", at=[1, 2, 3]), False),
|
|
(dict(at=[1, 2, 3]), False))
|
|
@ddt.unpack
|
|
def test_validate(self, config, valid):
|
|
results = hook.HookTrigger.validate("event", None, None, config)
|
|
if valid:
|
|
self.assertEqual([], results)
|
|
else:
|
|
self.assertEqual(1, len(results))
|
|
|
|
def test_get_listening_event(self):
|
|
event_type = self.trigger.get_listening_event()
|
|
self.assertEqual("iteration", event_type)
|
|
|
|
@ddt.data((1, True), (4, True), (5, True),
|
|
(0, False), (2, False), (3, False), (6, False), (7, False))
|
|
@ddt.unpack
|
|
def test_on_event(self, value, should_call):
|
|
self.trigger.on_event("iteration", value)
|
|
self.assertEqual(should_call, self.hook_cls.called)
|