Merge "s3api: fix test_service with pre-existing buckets"
This commit is contained in:
@@ -21,12 +21,12 @@
|
|||||||
value: example.com
|
value: example.com
|
||||||
become: true
|
become: true
|
||||||
|
|
||||||
- name: Turn on s3_acl_tests_disabled in test.conf (for Keystone tests)
|
- name: Turn off s3_acl_tests_enabled in test.conf (for Keystone tests)
|
||||||
ini_file:
|
ini_file:
|
||||||
path: /etc/swift/test.conf
|
path: /etc/swift/test.conf
|
||||||
section: s3api_test
|
section: s3api_test
|
||||||
option: s3_acl_tests_disabled
|
option: s3_acl_tests_enabled
|
||||||
value: true
|
value: false
|
||||||
become: true
|
become: true
|
||||||
|
|
||||||
- name: Set storage_domain in test/sample.conf (for tempauth tests)
|
- name: Set storage_domain in test/sample.conf (for tempauth tests)
|
||||||
@@ -37,12 +37,12 @@
|
|||||||
value: example.com
|
value: example.com
|
||||||
become: true
|
become: true
|
||||||
|
|
||||||
- name: Turn on s3_acl_tests_disabled in test/sample.conf (for tempauth tests)
|
- name: Turn off s3_acl_tests_enabled in test/sample.conf (for tempauth tests)
|
||||||
ini_file:
|
ini_file:
|
||||||
path: "{{ ansible_env.HOME }}/{{ zuul.project.src_dir }}/../swift/test/sample.conf"
|
path: "{{ ansible_env.HOME }}/{{ zuul.project.src_dir }}/../swift/test/sample.conf"
|
||||||
section: s3api_test
|
section: s3api_test
|
||||||
option: s3_acl_tests_disabled
|
option: s3_acl_tests_enabled
|
||||||
value: true
|
value: false
|
||||||
become: true
|
become: true
|
||||||
|
|
||||||
- name: Enable object versioning
|
- name: Enable object versioning
|
||||||
|
@@ -144,11 +144,20 @@ def get_s3_client(user=1, signature_version='s3v4', addressing_style='path'):
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def is_s3_acl_tests_enabled():
|
||||||
|
explicit_opt = get_opt('s3_acl_tests_enabled', None)
|
||||||
|
if explicit_opt is not None:
|
||||||
|
return config_true_value(explicit_opt)
|
||||||
|
else:
|
||||||
|
legacy_opt = get_opt('s3_acl_tests_disabled', 'false')
|
||||||
|
return not config_true_value(legacy_opt)
|
||||||
|
|
||||||
|
|
||||||
def skip_if_s3_acl_tests_disabled(func):
|
def skip_if_s3_acl_tests_disabled(func):
|
||||||
@functools.wraps(func)
|
@functools.wraps(func)
|
||||||
def wrapper(*args, **kwargs):
|
def wrapper(*args, **kwargs):
|
||||||
if config_true_value(get_opt('s3_acl_tests_disabled', 'false')):
|
if not is_s3_acl_tests_enabled():
|
||||||
raise unittest.SkipTest('s3_acl_tests_disabled is true')
|
raise unittest.SkipTest('s3_acl_tests_enabled is false')
|
||||||
return func(*args, **kwargs)
|
return func(*args, **kwargs)
|
||||||
return wrapper
|
return wrapper
|
||||||
|
|
||||||
|
@@ -14,44 +14,84 @@
|
|||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
import unittest
|
import unittest
|
||||||
|
from collections import defaultdict
|
||||||
|
import botocore.exceptions
|
||||||
|
|
||||||
from test.s3api import BaseS3TestCase, ConfigError, \
|
from test.s3api import BaseS3TestCase, ConfigError, \
|
||||||
skip_if_s3_acl_tests_disabled
|
skip_if_s3_acl_tests_disabled, is_s3_acl_tests_enabled
|
||||||
|
|
||||||
|
|
||||||
class TestGetServiceSigV4(BaseS3TestCase):
|
class TestGetServiceSigV4(BaseS3TestCase):
|
||||||
def _do_test_empty_service(self, client):
|
def setUp(self):
|
||||||
|
super().setUp()
|
||||||
|
# Capture existing buckets before running tests
|
||||||
|
self.existing_buckets = defaultdict(list)
|
||||||
|
self.existing_buckets[1] = self._get_buckets(1)
|
||||||
|
if is_s3_acl_tests_enabled():
|
||||||
|
# client2 seems to be always able to list buckets
|
||||||
|
try:
|
||||||
|
self.get_s3_client(2)
|
||||||
|
except ConfigError:
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
self.existing_buckets[2] = self._get_buckets(2)
|
||||||
|
# client3 gets AccessDenied unless s3_acl = True
|
||||||
|
try:
|
||||||
|
self.get_s3_client(3)
|
||||||
|
except ConfigError:
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
try:
|
||||||
|
self.existing_buckets[3] = self._get_buckets(3)
|
||||||
|
except botocore.exceptions.ClientError as e:
|
||||||
|
# but the lack of the existing_buckets doesn't really
|
||||||
|
# matter to most tests
|
||||||
|
if e.response['Error']['Code'] == 'AccessDenied':
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
raise
|
||||||
|
|
||||||
|
def _get_buckets(self, client_num):
|
||||||
|
client = self.get_s3_client(client_num)
|
||||||
|
resp = client.list_buckets()
|
||||||
|
return [bucket['Name'] for bucket in resp['Buckets']]
|
||||||
|
|
||||||
|
def _do_test_existing_service(self, client_num):
|
||||||
|
client = self.get_s3_client(client_num)
|
||||||
resp = client.list_buckets()
|
resp = client.list_buckets()
|
||||||
self.assertEqual(200, resp['ResponseMetadata']['HTTPStatusCode'])
|
self.assertEqual(200, resp['ResponseMetadata']['HTTPStatusCode'])
|
||||||
self.assertEqual([], resp['Buckets'])
|
found_buckets = [bucket['Name'] for bucket in resp['Buckets']]
|
||||||
|
self.assertEqual(self.existing_buckets[client_num], found_buckets)
|
||||||
self.assertIn('x-amz-request-id',
|
self.assertIn('x-amz-request-id',
|
||||||
resp['ResponseMetadata']['HTTPHeaders'])
|
resp['ResponseMetadata']['HTTPHeaders'])
|
||||||
self.check_owner(resp['Owner'])
|
self.check_owner(resp['Owner'])
|
||||||
self.assertIn('ID', resp['Owner'])
|
self.assertIn('ID', resp['Owner'])
|
||||||
|
|
||||||
def test_empty_service(self):
|
def test_existing_service(self):
|
||||||
client1 = self.get_s3_client(1)
|
self._do_test_existing_service(1)
|
||||||
self._do_test_empty_service(client1)
|
|
||||||
|
|
||||||
@skip_if_s3_acl_tests_disabled
|
@skip_if_s3_acl_tests_disabled
|
||||||
def test_empty_service_client3(self):
|
def test_existing_service_client3(self):
|
||||||
try:
|
try:
|
||||||
client3 = self.get_s3_client(3)
|
self.get_s3_client(3)
|
||||||
except ConfigError as err:
|
except ConfigError as err:
|
||||||
raise unittest.SkipTest(str(err))
|
raise unittest.SkipTest(str(err))
|
||||||
else:
|
else:
|
||||||
self._do_test_empty_service(client3)
|
self._do_test_existing_service(3)
|
||||||
|
|
||||||
def _create_buckets(self, client):
|
def _create_buckets(self, client_num):
|
||||||
|
client = self.get_s3_client(client_num)
|
||||||
buckets = [self.create_name('bucket%s' % i) for i in range(5)]
|
buckets = [self.create_name('bucket%s' % i) for i in range(5)]
|
||||||
for bucket in buckets:
|
for bucket in buckets:
|
||||||
client.create_bucket(Bucket=bucket)
|
client.create_bucket(Bucket=bucket)
|
||||||
return buckets
|
return buckets
|
||||||
|
|
||||||
def _do_test_service_with_buckets(self, client, buckets):
|
def _do_test_service_with_buckets(self, client_num, buckets):
|
||||||
|
client = self.get_s3_client(client_num)
|
||||||
resp = client.list_buckets()
|
resp = client.list_buckets()
|
||||||
self.assertEqual(200, resp['ResponseMetadata']['HTTPStatusCode'])
|
self.assertEqual(200, resp['ResponseMetadata']['HTTPStatusCode'])
|
||||||
self.assertEqual(sorted(buckets), [
|
expected_buckets = buckets + self.existing_buckets[client_num]
|
||||||
|
self.assertEqual(sorted(expected_buckets), [
|
||||||
bucket['Name'] for bucket in resp['Buckets']])
|
bucket['Name'] for bucket in resp['Buckets']])
|
||||||
self.assertTrue(all('CreationDate' in bucket
|
self.assertTrue(all('CreationDate' in bucket
|
||||||
for bucket in resp['Buckets']))
|
for bucket in resp['Buckets']))
|
||||||
@@ -60,9 +100,9 @@ class TestGetServiceSigV4(BaseS3TestCase):
|
|||||||
self.check_owner(resp['Owner'])
|
self.check_owner(resp['Owner'])
|
||||||
|
|
||||||
def test_service_with_buckets(self):
|
def test_service_with_buckets(self):
|
||||||
client = self.get_s3_client(1)
|
client_num = 1
|
||||||
buckets = self._create_buckets(client)
|
buckets = self._create_buckets(client_num)
|
||||||
self._do_test_service_with_buckets(client, buckets)
|
self._do_test_service_with_buckets(client_num, buckets)
|
||||||
|
|
||||||
@skip_if_s3_acl_tests_disabled
|
@skip_if_s3_acl_tests_disabled
|
||||||
def test_service_with_buckets_client2(self):
|
def test_service_with_buckets_client2(self):
|
||||||
@@ -71,22 +111,25 @@ class TestGetServiceSigV4(BaseS3TestCase):
|
|||||||
client2 = self.get_s3_client(2)
|
client2 = self.get_s3_client(2)
|
||||||
except ConfigError as err:
|
except ConfigError as err:
|
||||||
raise unittest.SkipTest(str(err))
|
raise unittest.SkipTest(str(err))
|
||||||
client1 = self.get_s3_client(1)
|
self._create_buckets(1)
|
||||||
self._create_buckets(client1)
|
buckets2 = self._create_buckets(2)
|
||||||
buckets2 = self._create_buckets(client2)
|
expected_buckets = buckets2 + self.existing_buckets[2]
|
||||||
self.assertEqual(sorted(buckets2), [
|
resp = client2.list_buckets()
|
||||||
bucket['Name'] for bucket in client2.list_buckets()['Buckets']])
|
found_buckets = [bucket['Name'] for bucket in resp['Buckets']]
|
||||||
|
self.assertEqual(sorted(expected_buckets), found_buckets)
|
||||||
|
|
||||||
@skip_if_s3_acl_tests_disabled
|
@skip_if_s3_acl_tests_disabled
|
||||||
def test_service_with_buckets_client3(self):
|
def test_service_with_buckets_client3(self):
|
||||||
# Unprivileged user can't see anything
|
# Unprivileged user can only see its own buckets
|
||||||
|
# (which should be empty)
|
||||||
try:
|
try:
|
||||||
client3 = self.get_s3_client(3)
|
client3 = self.get_s3_client(3)
|
||||||
except ConfigError as err:
|
except ConfigError as err:
|
||||||
raise unittest.SkipTest(str(err))
|
raise unittest.SkipTest(str(err))
|
||||||
client1 = self.get_s3_client(1)
|
self._create_buckets(1)
|
||||||
self._create_buckets(client1)
|
resp = client3.list_buckets()
|
||||||
self.assertEqual([], client3.list_buckets()['Buckets'])
|
found_buckets = [bucket['Name'] for bucket in resp['Buckets']]
|
||||||
|
self.assertEqual(self.existing_buckets[3], found_buckets)
|
||||||
|
|
||||||
|
|
||||||
class TestGetServiceSigV2(TestGetServiceSigV4):
|
class TestGetServiceSigV2(TestGetServiceSigV4):
|
||||||
|
@@ -15,8 +15,8 @@ secret_key3 = testing3
|
|||||||
# following non-default options to the s3api section of your proxy-server.conf
|
# following non-default options to the s3api section of your proxy-server.conf
|
||||||
# s3_acl = True
|
# s3_acl = True
|
||||||
# check_bucket_owner = True
|
# check_bucket_owner = True
|
||||||
# Alternatively, skip those tests by setting this option to True
|
# Alternatively, skip those tests by setting this option to False
|
||||||
s3_acl_tests_disabled = False
|
s3_acl_tests_enabled = True
|
||||||
|
|
||||||
[func_test]
|
[func_test]
|
||||||
# Sample config for Swift with tempauth
|
# Sample config for Swift with tempauth
|
||||||
|
Reference in New Issue
Block a user