Raise more descriptive exceptions, DuplicateTag and InvalidTagSpec.
This commit is contained in:
@@ -3,7 +3,8 @@ import unittest
|
|||||||
|
|
||||||
import dkim
|
import dkim
|
||||||
from dkim.util import (
|
from dkim.util import (
|
||||||
InvalidTagValueList,
|
DuplicateTag,
|
||||||
|
InvalidTagSpec,
|
||||||
parse_tag_value,
|
parse_tag_value,
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -83,13 +84,13 @@ class TestParseTagValue(unittest.TestCase):
|
|||||||
parse_tag_value(' foo \t= bar;\tbaz= f oo=bar '))
|
parse_tag_value(' foo \t= bar;\tbaz= f oo=bar '))
|
||||||
|
|
||||||
def test_missing_value_is_an_error(self):
|
def test_missing_value_is_an_error(self):
|
||||||
self.assertRaises(
|
self.assertRaisesRegexp(
|
||||||
InvalidTagValueList,
|
InvalidTagSpec, 'baz',
|
||||||
parse_tag_value, 'foo=bar;baz')
|
parse_tag_value, 'foo=bar;baz')
|
||||||
|
|
||||||
def test_duplicate_tag_is_an_error(self):
|
def test_duplicate_tag_is_an_error(self):
|
||||||
self.assertRaises(
|
self.assertRaisesRegexp(
|
||||||
InvalidTagValueList,
|
DuplicateTag, 'foo',
|
||||||
parse_tag_value, 'foo=bar;foo=baz')
|
parse_tag_value, 'foo=bar;foo=baz')
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
+12
-2
@@ -17,6 +17,8 @@
|
|||||||
# Copyright (c) 2011 William Grant <me@williamgrant.id.au>
|
# Copyright (c) 2011 William Grant <me@williamgrant.id.au>
|
||||||
|
|
||||||
__all__ = [
|
__all__ = [
|
||||||
|
'DuplicateTag',
|
||||||
|
'InvalidTagSpec',
|
||||||
'InvalidTagValueList',
|
'InvalidTagValueList',
|
||||||
'parse_tag_value',
|
'parse_tag_value',
|
||||||
]
|
]
|
||||||
@@ -26,6 +28,14 @@ class InvalidTagValueList(Exception):
|
|||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
class DuplicateTag(InvalidTagValueList):
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
class InvalidTagSpec(InvalidTagValueList):
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
def parse_tag_value(tag_list):
|
def parse_tag_value(tag_list):
|
||||||
"""Parse a DKIM Tag=Value list.
|
"""Parse a DKIM Tag=Value list.
|
||||||
|
|
||||||
@@ -43,8 +53,8 @@ def parse_tag_value(tag_list):
|
|||||||
try:
|
try:
|
||||||
key, value = tag_spec.split('=', 1)
|
key, value = tag_spec.split('=', 1)
|
||||||
except ValueError:
|
except ValueError:
|
||||||
raise InvalidTagValueList()
|
raise InvalidTagSpec(tag_spec)
|
||||||
if key.strip() in tags:
|
if key.strip() in tags:
|
||||||
raise InvalidTagValueList()
|
raise DuplicateTag(key.strip())
|
||||||
tags[key.strip()] = value.strip()
|
tags[key.strip()] = value.strip()
|
||||||
return tags
|
return tags
|
||||||
|
|||||||
Reference in New Issue
Block a user