]>
git.madduck.net Git - etc/taskwarrior.git/blobdiff - tasklib/tests.py
madduck's git repository
Every one of the projects in this repository is available at the canonical
URL git://git.madduck.net/madduck/pub/<projectpath> — see
each project's metadata for the exact URL.
All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@ git. madduck. net .
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
SSH access, as well as push access can be individually
arranged .
If you use my repositories frequently, consider adding the following
snippet to ~/.gitconfig and using the third clone URL listed for each
project:
[url "git://git.madduck.net/madduck/"]
insteadOf = madduck:
import pytz
import six
import shutil
import pytz
import six
import shutil
import tempfile
import unittest
import tempfile
import unittest
+total_seconds_2_6 = lambda x: x.microseconds / 1e6 + x.seconds + x.days * 24 * 3600
+
+
class TasklibTest(unittest.TestCase):
def setUp(self):
class TasklibTest(unittest.TestCase):
def setUp(self):
self.assertRaises(Task.DeletedTask, t.done)
self.assertRaises(Task.DeletedTask, t.done)
- def test_start_completed_task(self):
- t = Task(self.tw, description="test task")
- t.save()
- t.done()
-
- self.assertRaises(Task.CompletedTask, t.start)
-
def test_starting_task(self):
t = Task(self.tw, description="test task")
now = t.datetime_normalizer(datetime.datetime.now())
def test_starting_task(self):
t = Task(self.tw, description="test task")
now = t.datetime_normalizer(datetime.datetime.now())
self.assertTrue(now.replace(microsecond=0) <= t['end'])
self.assertEqual(t['status'], 'deleted')
self.assertTrue(now.replace(microsecond=0) <= t['end'])
self.assertEqual(t['status'], 'deleted')
+ def test_started_task_active(self):
+ t = Task(self.tw, description="test task")
+ t.save()
+ t.start()
+ self.assertTrue(t.active)
+
+ def test_unstarted_task_inactive(self):
+ t = Task(self.tw, description="test task")
+ self.assertFalse(t.active)
+ t.save()
+ self.assertFalse(t.active)
+
def test_modify_simple_attribute_without_space(self):
t = Task(self.tw, description="test")
t.save()
def test_modify_simple_attribute_without_space(self):
t = Task(self.tw, description="test")
t.save()
now = local_zone.localize(datetime.datetime.now())
# Assert that both times are not more than 5 seconds apart
now = local_zone.localize(datetime.datetime.now())
# Assert that both times are not more than 5 seconds apart
- self.assertTrue((now - t['due']).total_seconds() < 5)
- self.assertTrue((t['due'] - now).total_seconds() < 5)
+ if sys.version_info < (2,7):
+ self.assertTrue(total_seconds_2_6(now - t['due']) < 5)
+ self.assertTrue(total_seconds_2_6(t['due'] - now) < 5)
+ else:
+ self.assertTrue((now - t['due']).total_seconds() < 5)
+ self.assertTrue((t['due'] - now).total_seconds() < 5)
def test_simple_eoy_conversion(self):
if self.tw.version < six.text_type('2.4.0'):
def test_simple_eoy_conversion(self):
if self.tw.version < six.text_type('2.4.0'):
now = local_zone.localize(datetime.datetime.now())
due_date = local_zone.localize(datetime.datetime(
year=now.year,
now = local_zone.localize(datetime.datetime.now())
due_date = local_zone.localize(datetime.datetime(
year=now.year,
- month=9 ,
- day=3,
- hour=0 ,
+ month=12 ,
+ day=31 ,
+ hour=23 ,
+ )) - datetime.timedelta(0,4 * 30 * 86400)
self.assertEqual(due_date, t['due'])
def test_filtering_with_string_datetime(self):
self.assertEqual(due_date, t['due'])
def test_filtering_with_string_datetime(self):
+ if self.tw.version < six.text_type('2.4.0'):
+ # Python2.6 does not support SkipTest. As a workaround
+ # mark the test as passed by exiting.
+ if getattr(unittest, 'SkipTest', None) is not None:
+ raise unittest.SkipTest()
+ else:
+ return
+
t = Task(self.tw, description="test task",
due=datetime.datetime.now() - datetime.timedelta(0,2))
t.save()
t = Task(self.tw, description="test task",
due=datetime.datetime.now() - datetime.timedelta(0,2))
t.save()
Task(self.tw, description="†åßk").save()
self.tw.tasks.get()
Task(self.tw, description="†åßk").save()
self.tw.tasks.get()
+ def test_filter_by_unicode_task(self):
+ Task(self.tw, description="†åßk").save()
+ tasks = self.tw.tasks.filter(description="†åßk")
+ self.assertEqual(len(tasks), 1)
+
def test_non_unicode_task(self):
Task(self.tw, description="test task").save()
self.tw.tasks.get()
def test_non_unicode_task(self):
Task(self.tw, description="test task").save()
self.tw.tasks.get()