# 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 timelinelib.calendar.gregorian.time import GregorianDelta
from timelinelib.calendar.gregorian.timetype import GregorianTimeType
from timelinelib.canvas.data import Event
from timelinelib.test.cases.unit import UnitTestCase
from timelinelib.test.utils import a_category_with
from timelinelib.test.utils import an_event
from timelinelib.test.utils import an_event_with
from timelinelib.test.utils import EVENT_MODIFIERS
from timelinelib.test.utils import gregorian_period
from timelinelib.test.utils import human_time_to_gregorian
[docs]class describe_event(UnitTestCase):
[docs] def test_can_get_values(self):
event = Event().update(
start_time=human_time_to_gregorian("11 Jul 2014"),
end_time=human_time_to_gregorian("12 Jul 2014"),
text="a day in my life"
)
self.assertEqual(event.get_id(), None)
self.assertEqual(event.get_time_period(),
gregorian_period("11 Jul 2014", "12 Jul 2014"))
self.assertEqual(event.get_text(), "a day in my life")
self.assertEqual(event.category, None)
self.assertEqual(event.get_fuzzy(), False)
self.assertEqual(event.get_locked(), False)
self.assertEqual(event.get_ends_today(), False)
self.assertEqual(event.get_description(), None)
self.assertEqual(event.get_icon(), None)
self.assertEqual(event.get_hyperlink(), None)
self.assertEqual(event.get_progress(), None)
self.assertEqual(event.get_default_color(), (200, 200, 200))
[docs] def test_can_set_values(self):
self.assertEqual(
an_event().set_id(15).get_id(),
15)
self.assertEqual(
an_event().set_time_period(gregorian_period("1 Jan 2014", "1 Jan 2015")).get_time_period(),
gregorian_period("1 Jan 2014", "1 Jan 2015"))
self.assertEqual(
an_event().set_text("cool").get_text(),
"cool")
a_parent_category = a_category_with(name="work")
self.assertEqual(
an_event().set_category(a_parent_category).category,
a_parent_category)
self.assertEqual(
an_event().set_fuzzy(True).get_fuzzy(),
True)
self.assertEqual(
an_event().set_locked(True).get_locked(),
True)
self.assertEqual(
an_event().set_ends_today(True).get_ends_today(),
True)
self.assertEqual(
an_event().set_description("cool").get_description(),
"cool")
an_icon = "really not an icon"
self.assertEqual(
an_event().set_icon(an_icon).get_icon(),
an_icon)
self.assertEqual(
an_event().set_hyperlink("http://google.com").get_hyperlink(),
"http://google.com")
self.assertEqual(
an_event().set_progress(88).get_progress(),
88)
self.assertEqual(
an_event().set_alert("2015-01-07 00:00:00;hoho").get_alert(),
"2015-01-07 00:00:00;hoho")
self.assertEqual(
an_event().set_default_color((255, 0, 0)).get_default_color(), (255, 0, 0))
[docs] def test_can_not_set_values(self):
self.assertEqual(
an_event_with(locked=True).set_ends_today(True).get_ends_today(),
False)
[docs] def test_ends_today_can_be_changed_with_update(self):
event = an_event_with(ends_today=False)
event.update(event.get_time_period().start_time, event.get_time_period().end_time, event.get_text(), ends_today=True)
self.assertTrue(event.get_ends_today())
[docs] def test_fuzzy_can_be_changed_with_update(self):
event = an_event_with(fuzzy=False)
event.update(event.get_time_period().start_time, event.get_time_period().end_time, event.get_text(), fuzzy=True)
self.assertTrue(event.get_fuzzy())
[docs] def test_locked_can_be_changed_with_update(self):
event = an_event_with(locked=False)
event.update(event.get_time_period().start_time, event.get_time_period().end_time, event.get_text(), locked=True)
self.assertTrue(event.get_locked())
[docs] def test_ends_today_can_not_be_set_with_update_on_locked_event(self):
event = an_event_with(ends_today=False, locked=True)
event.update(event.get_time_period().start_time, event.get_time_period().end_time, event.get_text(), ends_today=True)
self.assertFalse(event.get_ends_today())
[docs] def test_ends_today_can_not_be_unset_with_update_on_locked_event(self):
event = an_event_with(ends_today=True, locked=True)
event.update(event.get_time_period().start_time, event.get_time_period().end_time, event.get_text(), ends_today=False)
self.assertTrue(event.get_ends_today())
[docs] def test_can_be_compared(self):
self.assertEqNeImplementationIsCorrect(an_event, EVENT_MODIFIERS)
[docs] def test_point_event_has_a_label(self):
event = an_event_with(text="foo", time="11 Jul 2014 10:11")
self.assertEqual(
"foo (11 ⟪Jul⟫ 2014 10:11)",
event.get_label(GregorianTimeType())
)
[docs] def test_point_event_has_an_empty_duration_label(self):
event = an_event_with(text="foo", time="11 Jul 2014 10:11")
self.assertEqual("", event._get_duration_label(GregorianTimeType()))
[docs] def test_duration_label_for_period_events(self):
cases = (
("11 Jul 2014 10:11", "11 Jul 2014 10:12", "⟪Duration⟫: 1 ⟪minute⟫"),
("11 Jul 2014 10:11", "11 Jul 2014 11:11", "⟪Duration⟫: 1 ⟪hour⟫"),
("11 Jul 2014 10:11", "12 Jul 2014 10:11", "⟪Duration⟫: 1 ⟪day⟫"),
("11 Jul 2014 10:11", "11 Jul 2014 11:12", "⟪Duration⟫: 1 ⟪hour⟫ 1 ⟪minute⟫"),
("11 Jul 2014 10:11", "12 Jul 2014 10:12", "⟪Duration⟫: 1 ⟪day⟫ 1 ⟪minute⟫"),
("11 Jul 2014 10:11", "12 Jul 2014 11:11", "⟪Duration⟫: 1 ⟪day⟫ 1 ⟪hour⟫"),
("11 Jul 2014 10:11", "12 Jul 2014 11:12", "⟪Duration⟫: 1 ⟪day⟫ 1 ⟪hour⟫ 1 ⟪minute⟫"),
("11 Jul 2014 10:11", "11 Jul 2014 10:13", "⟪Duration⟫: 2 ⟪minutes⟫"),
("11 Jul 2014 10:11", "11 Jul 2014 12:11", "⟪Duration⟫: 2 ⟪hours⟫"),
("11 Jul 2014 10:11", "13 Jul 2014 10:11", "⟪Duration⟫: 2 ⟪days⟫"),
("11 Jul 2014 10:11", "11 Jul 2014 12:13", "⟪Duration⟫: 2 ⟪hours⟫ 2 ⟪minutes⟫"),
("11 Jul 2014 10:11", "13 Jul 2014 10:13", "⟪Duration⟫: 2 ⟪days⟫ 2 ⟪minutes⟫"),
("11 Jul 2014 10:11", "13 Jul 2014 12:11", "⟪Duration⟫: 2 ⟪days⟫ 2 ⟪hours⟫"),
("11 Jul 2014 10:11", "13 Jul 2014 12:13", "⟪Duration⟫: 2 ⟪days⟫ 2 ⟪hours⟫ 2 ⟪minutes⟫"),
("11 Jul 2014 10:11", "11 Jul 2014 11:13", "⟪Duration⟫: 1 ⟪hour⟫ 2 ⟪minutes⟫"),
("11 Jul 2014 10:11", "12 Jul 2014 10:13", "⟪Duration⟫: 1 ⟪day⟫ 2 ⟪minutes⟫"),
("11 Jul 2014 10:11", "12 Jul 2014 12:11", "⟪Duration⟫: 1 ⟪day⟫ 2 ⟪hours⟫"),
("11 Jul 2014 10:11", "12 Jul 2014 12:13", "⟪Duration⟫: 1 ⟪day⟫ 2 ⟪hours⟫ 2 ⟪minutes⟫"),
)
for start, end, label in cases:
event = an_event_with(human_start_time=start, human_end_time=end)
self.assertEqual(label, event._get_duration_label(GregorianTimeType()))
[docs] def test_data_property(self):
data = {
"description": "d",
"icon": "i",
"hyperlink": "h",
"alert": "a",
"progress": "p",
"default_color": "dc",
"labels": "foo bar",
}
event = an_event()
event.data = data
new_data = event.data
self.assertTrue(data is not new_data)
self.assertEqual(data, new_data)
[docs]class describe_event_construction(UnitTestCase):
[docs] def test_event_properties_defaults_to_false(self):
event = an_event()
self.assertEqual(False, event.get_fuzzy())
self.assertEqual(False, event.get_locked())
self.assertEqual(False, event.get_ends_today())
self.assertEqual(False, event.is_container())
self.assertEqual(False, event.is_subevent())
[docs] def test_event_property_fuzzy_can_be_set_at_construction(self):
event = an_event_with(fuzzy=True)
self.assertTrue(event.get_fuzzy())
[docs] def test_event_property_locked_can_be_set_at_construction(self):
event = an_event_with(locked=True)
self.assertTrue(event.get_locked())
[docs] def test_event_property_ends_today_can_be_set_at_construction(self):
event = an_event_with(ends_today=True)
self.assertTrue(event.get_ends_today())
[docs]class describe_event_functions(UnitTestCase):
[docs] def test_zero_time_span(self):
event = an_event()
self.assertEqual(GregorianDelta.from_seconds(0), event.time_span())
[docs]class describe_event_cloning(UnitTestCase):
[docs] def test_event_is_not_a_milestone(self):
event = an_event()
self.assertFalse(event.is_milestone())