From baa4fa5d659f55243b7425f877e94f6b3eedbfe6 Mon Sep 17 00:00:00 2001 From: Tim Burke Date: Mon, 26 Mar 2018 14:30:07 -0700 Subject: [PATCH] swob.Match: Optional whitespace is optional https://tools.ietf.org/html/rfc7232#section-3 defines the form for If-Match and If-None-Match as If-Match = "*" / 1#entity-tag If-None-Match = "*" / 1#entity-tag https://tools.ietf.org/html/rfc7230#section-7 in turn defines the 1# syntax as 1#element => element *( OWS "," OWS element ) where OWS is *optional* whitespace. Our swob.Match object should respect that optionality. Change-Id: I6ee1c6674e0e9c156149319022fd289504bd3722 --- swift/common/swob.py | 5 ++++- test/unit/common/test_swob.py | 14 ++++++++++++++ 2 files changed, 18 insertions(+), 1 deletion(-) diff --git a/swift/common/swob.py b/swift/common/swob.py index 9b4842d63d..88da97ddf2 100644 --- a/swift/common/swob.py +++ b/swift/common/swob.py @@ -622,7 +622,10 @@ class Match(object): """ def __init__(self, headerval): self.tags = set() - for tag in headerval.split(', '): + for tag in headerval.split(','): + tag = tag.strip() + if not tag: + continue if tag.startswith('"') and tag.endswith('"'): self.tags.add(tag[1:-1]) else: diff --git a/test/unit/common/test_swob.py b/test/unit/common/test_swob.py index 81b8eb4c63..d8fd5da7a0 100644 --- a/test/unit/common/test_swob.py +++ b/test/unit/common/test_swob.py @@ -285,6 +285,20 @@ class TestMatch(unittest.TestCase): self.assertIn('b', match) self.assertNotIn('c', match) + def test_match_no_optional_white_space(self): + match = swift.common.swob.Match('"a","b"') + self.assertEqual(match.tags, set(('a', 'b'))) + self.assertIn('a', match) + self.assertIn('b', match) + self.assertNotIn('c', match) + + def test_match_lots_of_optional_white_space(self): + match = swift.common.swob.Match('"a" , , "b" ') + self.assertEqual(match.tags, set(('a', 'b'))) + self.assertIn('a', match) + self.assertIn('b', match) + self.assertNotIn('c', match) + class TestTransferEncoding(unittest.TestCase): def test_is_chunked(self):