Raise more descriptive exceptions, DuplicateTag and InvalidTagSpec.

This commit is contained in:
William Grant
2011-03-12 12:24:55 +11:00
parent 160718f9b2
commit e74405d27a
2 changed files with 18 additions and 7 deletions
+6 -5
View File
@@ -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
View File
@@ -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