s3api: Allow lower-cased regions when making buckets

Related-Bug: 1888444
Change-Id: I5188b277e8d7fb2c9835e63b951fb944782b4819
This commit is contained in:
Tim Burke 2020-07-27 11:38:12 -07:00
parent 3a6e85d9ec
commit 94b90aa49c
2 changed files with 25 additions and 1 deletions

View File

@ -344,7 +344,8 @@ class BucketController(Controller):
self.logger.error(e) self.logger.error(e)
raise raise
if location != self.conf.location: if location not in (self.conf.location,
self.conf.location.lower()):
# s3api cannot support multiple regions currently. # s3api cannot support multiple regions currently.
raise InvalidLocationConstraint() raise InvalidLocationConstraint()

View File

@ -1220,6 +1220,29 @@ class TestS3ApiBucket(S3ApiTestCase):
# Even crazier: it doesn't seem to matter # Even crazier: it doesn't seem to matter
self._test_bucket_PUT_with_location('foo') self._test_bucket_PUT_with_location('foo')
def test_bucket_PUT_with_mixed_case_location(self):
self.s3api.conf.location = 'RegionOne'
elem = Element('CreateBucketConfiguration')
# We've observed some clients (like aws-sdk-net) shift regions
# to lower case
SubElement(elem, 'LocationConstraint').text = 'regionone'
headers = {
'Authorization': 'AWS4-HMAC-SHA256 ' + ', '.join([
'Credential=test:tester/%s/regionone/s3/aws4_request' %
self.get_v4_amz_date_header().split('T', 1)[0],
'SignedHeaders=host',
'Signature=X',
]),
'Date': self.get_date_header(),
'x-amz-content-sha256': 'UNSIGNED-PAYLOAD',
}
req = Request.blank('/bucket',
environ={'REQUEST_METHOD': 'PUT'},
headers=headers,
body=tostring(elem))
status, headers, body = self.call_s3api(req)
self.assertEqual(status.split()[0], '200', body)
def test_bucket_PUT_with_canned_acl(self): def test_bucket_PUT_with_canned_acl(self):
req = Request.blank('/bucket', req = Request.blank('/bucket',
environ={'REQUEST_METHOD': 'PUT'}, environ={'REQUEST_METHOD': 'PUT'},