# Copyright (c) 2014 OpenStack Foundation # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or # implied. # See the License for the specific language governing permissions and # limitations under the License. import unittest from swift.common.swob import Request from test.unit.common.middleware.s3api import S3ApiTestCase from swift.common.middleware.s3api.etree import fromstring class TestS3ApiLogging(S3ApiTestCase): def setUp(self): super(TestS3ApiLogging, self).setUp() def test_bucket_logging_GET(self): req = Request.blank('/bucket?logging', environ={'REQUEST_METHOD': 'GET'}, headers={'Authorization': 'AWS test:tester:hmac', 'Date': self.get_date_header()}) status, headers, body = self.call_s3api(req) xml = fromstring(body, 'BucketLoggingStatus') self.assertEqual(xml.keys(), []) self.assertEqual(status.split()[0], '200') def test_object_logging_GET_error(self): req = Request.blank('/bucket/object?logging', environ={'REQUEST_METHOD': 'GET'}, headers={'Authorization': 'AWS test:tester:hmac', 'Date': self.get_date_header()}) status, headers, body = self.call_s3api(req) self.assertEqual(self._get_error_code(body), 'NoLoggingStatusForKey') def test_bucket_logging_PUT(self): req = Request.blank('/bucket?logging', environ={'REQUEST_METHOD': 'PUT'}, headers={'Authorization': 'AWS test:tester:hmac', 'Date': self.get_date_header()}) status, headers, body = self.call_s3api(req) # FIXME: Support PUT logging # self.assertEqual(status, 201) self.assertEqual(self._get_error_code(body), 'NotImplemented') def test_object_logging_PUT_error(self): req = Request.blank('/bucket/object?logging', environ={'REQUEST_METHOD': 'PUT'}, headers={'Authorization': 'AWS test:tester:hmac', 'Date': self.get_date_header()}) status, headers, body = self.call_s3api(req) self.assertEqual(self._get_error_code(body), 'NoLoggingStatusForKey') if __name__ == '__main__': unittest.main()