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