]>
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())
t.save()
self.assertEqual(len(self.tw.tasks.pending()), 2)
t.save()
self.assertEqual(len(self.tw.tasks.pending()), 2)
+ def test_modify_number_of_tasks_at_once(self):
+ for i in range(1, 100):
+ Task(self.tw, description="test task %d" % i, tags=['test']).save()
+
+ self.tw.execute_command(['+test', 'mod', 'unified', 'description'])
+
+
class TaskFromHookTest(TasklibTest):
input_add_data = six.StringIO(
class TaskFromHookTest(TasklibTest):
input_add_data = six.StringIO(
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()