|
@@ -89,81 +89,78 @@ def gettestcases(include_onlymatching=False):
|
|
md5 = lambda s: hashlib.md5(s.encode('utf-8')).hexdigest()
|
|
md5 = lambda s: hashlib.md5(s.encode('utf-8')).hexdigest()
|
|
|
|
|
|
|
|
|
|
-def expect_dict(self, got_dict, expected_dict):
|
|
|
|
- for info_field, expected in expected_dict.items():
|
|
|
|
- if isinstance(expected, compat_str) and expected.startswith('re:'):
|
|
|
|
- got = got_dict.get(info_field)
|
|
|
|
- match_str = expected[len('re:'):]
|
|
|
|
- match_rex = re.compile(match_str)
|
|
|
|
-
|
|
|
|
- self.assertTrue(
|
|
|
|
- isinstance(got, compat_str),
|
|
|
|
- 'Expected a %s object, but got %s for field %s' % (
|
|
|
|
- compat_str.__name__, type(got).__name__, info_field))
|
|
|
|
- self.assertTrue(
|
|
|
|
- match_rex.match(got),
|
|
|
|
- 'field %s (value: %r) should match %r' % (info_field, got, match_str))
|
|
|
|
- elif isinstance(expected, compat_str) and expected.startswith('startswith:'):
|
|
|
|
- got = got_dict.get(info_field)
|
|
|
|
- start_str = expected[len('startswith:'):]
|
|
|
|
- self.assertTrue(
|
|
|
|
- isinstance(got, compat_str),
|
|
|
|
- 'Expected a %s object, but got %s for field %s' % (
|
|
|
|
- compat_str.__name__, type(got).__name__, info_field))
|
|
|
|
- self.assertTrue(
|
|
|
|
- got.startswith(start_str),
|
|
|
|
- 'field %s (value: %r) should start with %r' % (info_field, got, start_str))
|
|
|
|
- elif isinstance(expected, compat_str) and expected.startswith('contains:'):
|
|
|
|
- got = got_dict.get(info_field)
|
|
|
|
- contains_str = expected[len('contains:'):]
|
|
|
|
- self.assertTrue(
|
|
|
|
- isinstance(got, compat_str),
|
|
|
|
- 'Expected a %s object, but got %s for field %s' % (
|
|
|
|
- compat_str.__name__, type(got).__name__, info_field))
|
|
|
|
|
|
+def expect_value(self, got, expected, field):
|
|
|
|
+ if isinstance(expected, compat_str) and expected.startswith('re:'):
|
|
|
|
+ match_str = expected[len('re:'):]
|
|
|
|
+ match_rex = re.compile(match_str)
|
|
|
|
+
|
|
|
|
+ self.assertTrue(
|
|
|
|
+ isinstance(got, compat_str),
|
|
|
|
+ 'Expected a %s object, but got %s for field %s' % (
|
|
|
|
+ compat_str.__name__, type(got).__name__, field))
|
|
|
|
+ self.assertTrue(
|
|
|
|
+ match_rex.match(got),
|
|
|
|
+ 'field %s (value: %r) should match %r' % (field, got, match_str))
|
|
|
|
+ elif isinstance(expected, compat_str) and expected.startswith('startswith:'):
|
|
|
|
+ start_str = expected[len('startswith:'):]
|
|
|
|
+ self.assertTrue(
|
|
|
|
+ isinstance(got, compat_str),
|
|
|
|
+ 'Expected a %s object, but got %s for field %s' % (
|
|
|
|
+ compat_str.__name__, type(got).__name__, field))
|
|
|
|
+ self.assertTrue(
|
|
|
|
+ got.startswith(start_str),
|
|
|
|
+ 'field %s (value: %r) should start with %r' % (field, got, start_str))
|
|
|
|
+ elif isinstance(expected, compat_str) and expected.startswith('contains:'):
|
|
|
|
+ contains_str = expected[len('contains:'):]
|
|
|
|
+ self.assertTrue(
|
|
|
|
+ isinstance(got, compat_str),
|
|
|
|
+ 'Expected a %s object, but got %s for field %s' % (
|
|
|
|
+ compat_str.__name__, type(got).__name__, field))
|
|
|
|
+ self.assertTrue(
|
|
|
|
+ contains_str in got,
|
|
|
|
+ 'field %s (value: %r) should contain %r' % (field, got, contains_str))
|
|
|
|
+ elif isinstance(expected, type):
|
|
|
|
+ self.assertTrue(isinstance(got, expected),
|
|
|
|
+ 'Expected type %r for field %s, but got value %r of type %r' % (expected, field, got, type(got)))
|
|
|
|
+ elif isinstance(expected, dict) and isinstance(got, dict):
|
|
|
|
+ expect_dict(self, got, expected)
|
|
|
|
+ elif isinstance(expected, list) and isinstance(got, list):
|
|
|
|
+ self.assertEqual(len(expected), len(got),
|
|
|
|
+ 'Expect a list of length %d, but got a list of length %d' % (
|
|
|
|
+ len(expected), len(got)))
|
|
|
|
+ _id = 0
|
|
|
|
+ for i, j in zip(got, expected):
|
|
|
|
+ _type_i = type(i)
|
|
|
|
+ _type_j = type(j)
|
|
|
|
+ self.assertEqual(_type_j, _type_i,
|
|
|
|
+ 'Type doesn\'t match at element %d of the list in field %s, expect %s, got %s' % (
|
|
|
|
+ _id, field, _type_j, _type_i))
|
|
|
|
+ expect_value(self, i, j, field)
|
|
|
|
+ _id += 1
|
|
|
|
+ else:
|
|
|
|
+ if isinstance(expected, compat_str) and expected.startswith('md5:'):
|
|
|
|
+ got = 'md5:' + md5(got)
|
|
|
|
+ elif isinstance(expected, compat_str) and expected.startswith('mincount:'):
|
|
self.assertTrue(
|
|
self.assertTrue(
|
|
- contains_str in got,
|
|
|
|
- 'field %s (value: %r) should contain %r' % (info_field, got, contains_str))
|
|
|
|
- elif isinstance(expected, type):
|
|
|
|
- got = got_dict.get(info_field)
|
|
|
|
- self.assertTrue(isinstance(got, expected),
|
|
|
|
- 'Expected type %r for field %s, but got value %r of type %r' % (expected, info_field, got, type(got)))
|
|
|
|
- elif isinstance(expected, dict) and isinstance(got_dict.get(info_field, None), dict):
|
|
|
|
- expect_dict(self, got_dict.get(info_field), expected)
|
|
|
|
- elif isinstance(expected, list) and isinstance(got_dict.get(info_field, None), list):
|
|
|
|
- got = got_dict.get(info_field, None)
|
|
|
|
- self.assertEqual(len(expected), len(got),
|
|
|
|
- 'Expect a list of length %d, but got a list of length %d' % (
|
|
|
|
- len(expected), len(got)))
|
|
|
|
- _id = 0
|
|
|
|
- for i, j in zip(got, expected):
|
|
|
|
- _type_i = type(i)
|
|
|
|
- _type_j = type(j)
|
|
|
|
- self.assertEqual(_type_j, _type_i,
|
|
|
|
- 'Type doesn\'t match at element %d of the list in field %s, expect %s, got %s' % (
|
|
|
|
- _id, info_field, _type_j, _type_i))
|
|
|
|
- expect_dict(self, {'_': i}, {'_': j})
|
|
|
|
- _id += 1
|
|
|
|
- else:
|
|
|
|
- if isinstance(expected, compat_str) and expected.startswith('md5:'):
|
|
|
|
- got = 'md5:' + md5(got_dict.get(info_field))
|
|
|
|
- elif isinstance(expected, compat_str) and expected.startswith('mincount:'):
|
|
|
|
- got = got_dict.get(info_field)
|
|
|
|
- self.assertTrue(
|
|
|
|
- isinstance(got, (list, dict)),
|
|
|
|
- 'Expected field %s to be a list or a dict, but it is of type %s' % (
|
|
|
|
- info_field, type(got).__name__))
|
|
|
|
- expected_num = int(expected.partition(':')[2])
|
|
|
|
- assertGreaterEqual(
|
|
|
|
- self, len(got), expected_num,
|
|
|
|
- 'Expected %d items in field %s, but only got %d' % (
|
|
|
|
- expected_num, info_field, len(got)
|
|
|
|
- )
|
|
|
|
|
|
+ isinstance(got, (list, dict)),
|
|
|
|
+ 'Expected field %s to be a list or a dict, but it is of type %s' % (
|
|
|
|
+ field, type(got).__name__))
|
|
|
|
+ expected_num = int(expected.partition(':')[2])
|
|
|
|
+ assertGreaterEqual(
|
|
|
|
+ self, len(got), expected_num,
|
|
|
|
+ 'Expected %d items in field %s, but only got %d' % (
|
|
|
|
+ expected_num, field, len(got)
|
|
)
|
|
)
|
|
- continue
|
|
|
|
- else:
|
|
|
|
- got = got_dict.get(info_field)
|
|
|
|
- self.assertEqual(expected, got,
|
|
|
|
- 'invalid value for field %s, expected %r, got %r' % (info_field, expected, got))
|
|
|
|
|
|
+ )
|
|
|
|
+ return
|
|
|
|
+ self.assertEqual(expected, got,
|
|
|
|
+ 'invalid value for field %s, expected %r, got %r' % (field, expected, got))
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+def expect_dict(self, got_dict, expected_dict):
|
|
|
|
+ for info_field, expected in expected_dict.items():
|
|
|
|
+ got = got_dict.get(info_field)
|
|
|
|
+ expect_value(self, got, expected, info_field)
|
|
|
|
|
|
|
|
|
|
def expect_info_dict(self, got_dict, expected_dict):
|
|
def expect_info_dict(self, got_dict, expected_dict):
|