Add sanity checks to strip_*meta_prefix functions

Change-Id: I05742ce34c28c3020cd241603965a60cbe2caf78
This commit is contained in:
Tim Burke 2016-06-30 14:26:15 -07:00
parent 9045f33869
commit 3fa742f4b7
2 changed files with 25 additions and 1 deletions

View File

@ -200,6 +200,8 @@ def strip_user_meta_prefix(server_type, key):
:param key: header key
:returns: stripped header key
"""
if not is_user_meta(server_type, key):
raise ValueError('Key is not user meta')
return key[len(get_user_meta_prefix(server_type)):]
@ -212,6 +214,8 @@ def strip_sys_meta_prefix(server_type, key):
:param key: header key
:returns: stripped header key
"""
if not is_sys_meta(server_type, key):
raise ValueError('Key is not sysmeta')
return key[len(get_sys_meta_prefix(server_type)):]
@ -223,6 +227,8 @@ def strip_object_transient_sysmeta_prefix(key):
:param key: header key
:returns: stripped header key
"""
if not is_object_transient_sysmeta(key):
raise ValueError('Key is not object transient sysmeta')
return key[len(OBJECT_TRANSIENT_SYSMETA_PREFIX):]

View File

@ -22,7 +22,8 @@ from swift.common.request_helpers import is_sys_meta, is_user_meta, \
is_sys_or_user_meta, strip_sys_meta_prefix, strip_user_meta_prefix, \
remove_items, copy_header_subset, get_name_and_placement, \
http_response_to_document_iters, is_object_transient_sysmeta, \
update_etag_is_at_header, resolve_etag_is_at_header
update_etag_is_at_header, resolve_etag_is_at_header, \
strip_object_transient_sysmeta_prefix
from test.unit import patch_policies
from test.unit.common.test_utils import FakeResponse
@ -62,12 +63,20 @@ class TestRequestHelpers(unittest.TestCase):
for st in server_types:
self.assertEqual(strip_sys_meta_prefix(st, 'x-%s-%s-a'
% (st, mt)), 'a')
mt = 'not-sysmeta'
for st in server_types:
with self.assertRaises(ValueError):
strip_sys_meta_prefix(st, 'x-%s-%s-a' % (st, mt))
def test_strip_user_meta_prefix(self):
mt = 'meta'
for st in server_types:
self.assertEqual(strip_user_meta_prefix(st, 'x-%s-%s-a'
% (st, mt)), 'a')
mt = 'not-meta'
for st in server_types:
with self.assertRaises(ValueError):
strip_sys_meta_prefix(st, 'x-%s-%s-a' % (st, mt))
def test_is_object_transient_sysmeta(self):
self.assertTrue(is_object_transient_sysmeta(
@ -77,6 +86,15 @@ class TestRequestHelpers(unittest.TestCase):
self.assertFalse(is_object_transient_sysmeta(
'x-object-meatmeta-foo'))
def test_strip_object_transient_sysmeta_prefix(self):
mt = 'object-transient-sysmeta'
self.assertEqual(strip_object_transient_sysmeta_prefix('x-%s-a' % mt),
'a')
mt = 'object-sysmeta-transient'
with self.assertRaises(ValueError):
strip_object_transient_sysmeta_prefix('x-%s-a' % mt)
def test_remove_items(self):
src = {'a': 'b',
'c': 'd'}