1
|
|
|
import datetime |
2
|
|
|
|
3
|
|
|
from st2tests.base import BaseActionTestCase |
4
|
|
|
|
5
|
|
|
from lib.utils import dt_to_timestamp |
6
|
|
|
from parse_date_string import ParseDateStringAction |
7
|
|
|
|
8
|
|
|
|
9
|
|
|
class ParseDateStringActionTestCase(BaseActionTestCase): |
10
|
|
|
action_cls = ParseDateStringAction |
11
|
|
|
|
12
|
|
|
def test_run_success(self): |
13
|
|
|
action = self.get_action_instance() |
14
|
|
|
|
15
|
|
|
result = action.run(date_string='now') |
16
|
|
|
expected = datetime.datetime.utcnow() |
17
|
|
|
expected = dt_to_timestamp(expected) |
18
|
|
|
self.assertTimestampMatchesWithDrift(result, expected) |
19
|
|
|
|
20
|
|
|
result = action.run(date_string='1 hour ago') |
21
|
|
|
expected = (datetime.datetime.utcnow() - datetime.timedelta(hours=1)) |
22
|
|
|
expected = dt_to_timestamp(expected) |
23
|
|
|
self.assertTimestampMatchesWithDrift(result, expected) |
24
|
|
|
|
25
|
|
|
result = action.run(date_string='3 days ago') |
26
|
|
|
expected = (datetime.datetime.utcnow() - datetime.timedelta(days=3)) |
27
|
|
|
expected = dt_to_timestamp(expected) |
28
|
|
|
self.assertTimestampMatchesWithDrift(result, expected) |
29
|
|
|
|
30
|
|
|
# TODO: Uupstream library is broke, fix it |
31
|
|
|
#result = action.run(date_string='2013-05-12') |
32
|
|
|
#expected = datetime.datetime(2013, 5, 12) |
33
|
|
|
#expected = dt_to_timestamp(expected) |
34
|
|
|
#self.assertTimestampMatchesWithDrift(result, expected) |
35
|
|
|
|
36
|
|
|
def test_run_invalid_date_string(self): |
37
|
|
|
action = self.get_action_instance() |
38
|
|
|
self.assertRaises(ValueError, action.run, date_string='some invalid string') |
39
|
|
|
|
40
|
|
|
def assertTimestampMatches(self, actual_ts, expected_ts): |
41
|
|
|
""" |
42
|
|
|
Custom function which asserts that the provided two timestamp match. |
43
|
|
|
""" |
44
|
|
|
actual_ts = datetime.datetime.fromtimestamp(actual_ts) |
45
|
|
|
expected_ts = datetime.datetime.fromtimestamp(expected_ts) |
46
|
|
|
|
47
|
|
|
self.assertEqual(actual_ts, expected_ts) |
48
|
|
|
|
49
|
|
|
def assertTimestampMatchesWithDrift(self, actual_ts, expected_ts): |
50
|
|
|
""" |
51
|
|
|
Custom assert function which allows actual result to drift from the expected one |
52
|
|
|
for +/- 1 second (this is to account for the time between the function runs). |
53
|
|
|
|
54
|
|
|
In addition to that, microseconds are stripped as well. |
55
|
|
|
""" |
56
|
|
|
expected_timestamps = [expected_ts, (expected_ts + 1), (expected_ts - 1)] |
57
|
|
|
self.assertTrue(actual_ts in expected_timestamps) |
58
|
|
|
|