Source code for unit.general.observer
# Copyright (C) 2009, 2010, 2011, 2012, 2013, 2014, 2015, 2016, 2017, 2018 Rickard Lindberg, Roger Lindberg
#
# This file is part of Timeline.
#
# Timeline is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Timeline is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Timeline. If not, see <http://www.gnu.org/licenses/>.
from unittest.mock import Mock
from timelinelib.general.observer import Listener
from timelinelib.general.observer import Observable
from timelinelib.test.cases.unit import UnitTestCase
[docs]class describe_observable(UnitTestCase):
[docs] def test_at_construction_there_area_zero_observers(self):
self.assertTrue(len(self.observable._observers) == 0)
[docs] def test_an_observer_can_be_registered(self):
self.registerObserver()
self.assertTrue(len(self.observable._observers) == 1)
[docs] def test_an_observer_can_be_unregistered(self):
self.registerObserver()
self.observable.unregister(self.observer.event_triggered)
self.assertTrue(len(self.observable._observers) == 0)
[docs] def test_an_observer_gets_notifications(self):
self.registerObserver()
self.observable._notify("bar")
self.observable._notify("foo")
self.assertTrue(len(self.observer.events) == 2)
self.assertTrue(self.observer.events[0] == "bar")
self.assertTrue(self.observer.events[1] == "foo")
[docs] def test_can_listen_for_specific_events(self):
observer = Observer()
self.observable.listen_for("bananas", observer.event_triggered2)
self.observable._notify("apples")
self.observable._notify("bananas")
self.assertEqual(len(observer.events), 1)
[docs] def test_can_listen_for_all_events(self):
observer = Observer()
self.observable.listen_for_any(observer.event_triggered2)
self.observable._notify()
self.observable._notify()
self.assertEqual(len(observer.events), 2)
[docs] def test_can_unlisten(self):
observer = Observer()
self.observable.listen_for_any(observer.event_triggered2)
self.observable._notify()
self.observable.unlisten(observer.event_triggered2)
self.observable._notify()
self.assertEqual(len(observer.events), 1)
[docs] def setUp(self):
self.observable = Observable()
[docs] def registerObserver(self):
self.observer = Observer()
self.observable.register(self.observer.event_triggered)
[docs]class describe_listener(UnitTestCase):
[docs] def test_does_not_call_callback_at_construction(self):
Listener(self.callback)
self.assertFalse(self.callback.called)
[docs] def test_calls_callback_when_observable_set(self):
Listener(self.callback).set_observable(self.observable)
self.callback.assert_called_with(self.observable)
[docs] def test_calls_callback_when_observable_changed(self):
Listener(self.callback).set_observable(self.observable)
self.callback.reset_mock()
self.observable._notify()
self.callback.assert_called_with(self.observable)
[docs] def test_unregisters_on_old_observer(self):
first_observable = Mock()
second_observable = Mock()
listener = Listener(self.callback)
listener.set_observable(first_observable)
listener.set_observable(second_observable)
self.assertTrue(first_observable.unlisten.called)
[docs] def setUp(self):
self.callback = Mock()
self.observable = Observable()
[docs]class Observer(object):
[docs] def __init__(self):
self.events = []
[docs] def event_triggered(self, evt):
self.events.append(evt)
[docs] def event_triggered2(self):
self.events.append(None)