rgw: aws4: fix test_object_create_missing_signed_custom_header_aws4

Signed-off-by: Javier M. Mellid <jmunhoz@igalia.com>
This commit is contained in:
Javier M. Mellid 2016-06-02 20:33:40 +00:00
parent 45a4b336cc
commit ff9fb2d8ea

View file

@ -13,6 +13,8 @@ import socket
import ssl import ssl
import os import os
from urlparse import urlparse
from boto.s3.connection import S3Connection from boto.s3.connection import S3Connection
from nose.tools import eq_ as eq from nose.tools import eq_ as eq
@ -25,6 +27,7 @@ import AnonymousAuth
from email.header import decode_header from email.header import decode_header
from . import ( from . import (
_make_raw_request,
nuke_prefixed_buckets, nuke_prefixed_buckets,
get_new_bucket, get_new_bucket,
s3, s3,
@ -1381,12 +1384,27 @@ def test_object_create_bad_amz_date_after_end_aws4():
@nose.with_setup(teardown=_clear_custom_headers) @nose.with_setup(teardown=_clear_custom_headers)
def test_object_create_missing_signed_custom_header_aws4(): def test_object_create_missing_signed_custom_header_aws4():
check_aws4_support() check_aws4_support()
key = _setup_bad_object({'x-zoo': 'zoo'}) method='PUT'
_add_custom_non_auth_headers(remove=('x-zoo',)) expires_in='100000'
e = assert_raises(boto.exception.S3ResponseError, key.set_contents_from_string, 'bar') bucket = get_new_bucket()
eq(e.status, 403) key = bucket.new_key('foo')
eq(e.reason, 'Forbidden') body='zoo'
eq(e.error_code, 'SignatureDoesNotMatch')
# compute the signature with 'x-amz-foo=bar' in the headers...
request_headers = {'x-amz-foo':'bar'}
url = key.generate_url(expires_in, method=method, headers=request_headers)
o = urlparse(url)
path = o.path + '?' + o.query
# avoid sending 'x-amz-foo=bar' in the headers
request_headers.pop('x-amz-foo')
res =_make_raw_request(host=s3.main.host, port=s3.main.port, method=method, path=path,
body=body, request_headers=request_headers, secure=s3.main.is_secure)
eq(res.status, 403)
eq(res.reason, 'Forbidden')
@tag('auth_aws4') @tag('auth_aws4')