From 6b3a20f1c5dcddf74491e28e8960f174d0e1c642 Mon Sep 17 00:00:00 2001 From: Markus Holtermann Date: Fri, 25 Jan 2013 21:58:58 +0100 Subject: Take care of the seconds --- bvggrabber/api/__init__.py | 25 ++++++++--- tests/test_api.py | 105 ++++++++++++++++++++++++++------------------- 2 files changed, 80 insertions(+), 50 deletions(-) diff --git a/bvggrabber/api/__init__.py b/bvggrabber/api/__init__.py index dbffe6c..81c4980 100644 --- a/bvggrabber/api/__init__.py +++ b/bvggrabber/api/__init__.py @@ -1,12 +1,13 @@ # -*- coding: utf-8 -*- +import datetime import json import re -from datetime import datetime +from math import ceil, floor from dateutil.parser import parse -fullformat = lambda dt: dt.strftime('%Y-%m-%d %H:%M') +fullformat = lambda dt: dt.strftime('%Y-%m-%d %H:%M:%S') hourformat = lambda dt: dt.strftime('%H:%M') @@ -22,19 +23,22 @@ class QueryApi(object): class Departure(object): - def __init__(self, start, end, when, line): + def __init__(self, start, end, when, line, since=None): + if since is None: + self.now = datetime.datetime.now() + else: + self.now = since self.start = start self.end = end self.line = line - self.now = datetime.now() if isinstance(when, (int, float)): # We assume to get a UNIX / POSIX timestamp - self.when = datetime.fromtimestamp(when) + self.when = datetime.datetime.fromtimestamp(when) elif isinstance(when, str): self.when = parse(re.sub('[\s*]$', '', when)) #if (self.when - self.now).total_seconds() < -60: # self.when = self.when + timedelta(days=1) - elif isinstance(when, datetime): + elif isinstance(when, datetime.datetime): self.when = when else: ValueError("when must be a valid datetime, timestamp or string!") @@ -46,7 +50,14 @@ class Departure(object): @property def remaining(self): - return self.when - self.now + td = self.when - self.now + seconds = (td / 60).total_seconds() + if td < datetime.timedelta(seconds=0): + return datetime.timedelta(minutes=floor(seconds)) + elif td > datetime.timedelta(seconds=0): + return datetime.timedelta(minutes=ceil(seconds)) + else: + return datetime.timedelta(seconds=0) def to_json(self): return json.dumps({'start': self.start.decode('iso-8859-1'), diff --git a/tests/test_api.py b/tests/test_api.py index 8493524..bd8e0ca 100644 --- a/tests/test_api.py +++ b/tests/test_api.py @@ -1,10 +1,9 @@ # -*- coding: utf-8 -*- -import time import unittest -from datetime import datetime, timedelta +import datetime -from bvggrabber.api import QueryApi, Departure +from bvggrabber.api import QueryApi, Departure, fullformat class TestQueryApi(unittest.TestCase): @@ -17,73 +16,93 @@ class TestQueryApi(unittest.TestCase): class TestDeparture(unittest.TestCase): def setUp(self): - self.td = timedelta(minutes=10) + self.since = datetime.datetime(2013, 1, 2, 3, 4, 0) + self.delta1 = datetime.timedelta(seconds=60) + self.delta2 = datetime.timedelta(seconds=80) def test_timestamp_futur(self): - when = time.time() + 10 * 60 - dep = Departure("from", "to", when, "line") + when = self.since + self.delta1 + dep = Departure("from", "to", when, "line", since=self.since) diff = dep.remaining.total_seconds() - self.assertLessEqual(diff, 600) - self.assertGreaterEqual(diff, 590) + self.assertEqual(diff, 60) + + when = self.since + self.delta2 + dep = Departure("from", "to", when, "line", since=self.since) + diff = dep.remaining.total_seconds() + self.assertEqual(diff, 120) def test_timestamp_now(self): - when = time.time() - dep = Departure("from", "to", when, "line") + when = self.since + dep = Departure("from", "to", when, "line", since=self.since) diff = dep.remaining.total_seconds() - self.assertLessEqual(diff, 5) - self.assertGreaterEqual(diff, -5) + self.assertEqual(diff, 0) def test_timestamp_past(self): - when = time.time() - 10 * 60 - dep = Departure("from", "to", when, "line") + when = self.since - self.delta1 + dep = Departure("from", "to", when, "line", since=self.since) + diff = dep.remaining.total_seconds() + self.assertEqual(diff, -60) + + when = self.since - self.delta2 + dep = Departure("from", "to", when, "line", since=self.since) diff = dep.remaining.total_seconds() - self.assertLessEqual(diff, -600) - self.assertGreaterEqual(diff, -610) + self.assertEqual(diff, -120) def test_string_futur(self): - when = datetime.now() + self.td - when = when.strftime('%Y-%m-%d %H:%M:%S') - dep = Departure("from", "to", when, "line") + when = fullformat(self.since + self.delta1) + dep = Departure("from", "to", when, "line", since=self.since) + diff = dep.remaining.total_seconds() + self.assertEqual(diff, 60) + + when = fullformat(self.since + self.delta2) + dep = Departure("from", "to", when, "line", since=self.since) diff = dep.remaining.total_seconds() - self.assertLessEqual(diff, 600) - self.assertGreaterEqual(diff, 590) + self.assertEqual(diff, 120) def test_string_now(self): - when = datetime.now() - when = when.strftime('%Y-%m-%d %H:%M:%S') - dep = Departure("from", "to", when, "line") + when = fullformat(self.since) + dep = Departure("from", "to", when, "line", since=self.since) diff = dep.remaining.total_seconds() - self.assertLessEqual(diff, 5) - self.assertGreaterEqual(diff, -5) + self.assertEqual(diff, 0) def test_string_past(self): - when = datetime.now() - self.td - when = when.strftime('%Y-%m-%d %H:%M:%S') - dep = Departure("from", "to", when, "line") + when = fullformat(self.since - self.delta1) + dep = Departure("from", "to", when, "line", since=self.since) diff = dep.remaining.total_seconds() - self.assertLessEqual(diff, -600) - self.assertGreaterEqual(diff, -610) + self.assertEqual(diff, -60) + + when = fullformat(self.since - self.delta2) + dep = Departure("from", "to", when, "line", since=self.since) + diff = dep.remaining.total_seconds() + self.assertEqual(diff, -120) def test_datetime_futur(self): - when = datetime.now() + self.td - dep = Departure("from", "to", when, "line") + when = self.since + self.delta1 + dep = Departure("from", "to", when, "line", since=self.since) + diff = dep.remaining.total_seconds() + self.assertEqual(diff, 60) + + when = self.since + self.delta2 + dep = Departure("from", "to", when, "line", since=self.since) diff = dep.remaining.total_seconds() - self.assertLessEqual(diff, 600) - self.assertGreaterEqual(diff, 590) + self.assertEqual(diff, 120) def test_datetime_now(self): - when = datetime.now() - dep = Departure("from", "to", when, "line") + when = self.since + dep = Departure("from", "to", when, "line", since=self.since) diff = dep.remaining.total_seconds() - self.assertLessEqual(diff, 5) - self.assertGreaterEqual(diff, -5) + self.assertEqual(diff, 0) def test_datetime_past(self): - when = datetime.now() - self.td - dep = Departure("from", "to", when, "line") + when = self.since - self.delta1 + dep = Departure("from", "to", when, "line", since=self.since) + diff = dep.remaining.total_seconds() + self.assertEqual(diff, -60) + + when = self.since - self.delta2 + dep = Departure("from", "to", when, "line", since=self.since) diff = dep.remaining.total_seconds() - self.assertLessEqual(diff, -600) - self.assertGreaterEqual(diff, -610) + self.assertEqual(diff, -120) def test_error(self): self.assertRaises(ValueError, Departure, "from", "to", "foo", "line") -- cgit v1.2.3