Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(20)

Unified Diff: tools/telemetry/third_party/gsutil/third_party/boto/tests/unit/s3/test_connection.py

Issue 1260493004: Revert "Add gsutil 4.13 to telemetry/third_party" (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: tools/telemetry/third_party/gsutil/third_party/boto/tests/unit/s3/test_connection.py
diff --git a/tools/telemetry/third_party/gsutil/third_party/boto/tests/unit/s3/test_connection.py b/tools/telemetry/third_party/gsutil/third_party/boto/tests/unit/s3/test_connection.py
deleted file mode 100644
index 5839a6a2d7eabb363f397c18377663c624def4dc..0000000000000000000000000000000000000000
--- a/tools/telemetry/third_party/gsutil/third_party/boto/tests/unit/s3/test_connection.py
+++ /dev/null
@@ -1,240 +0,0 @@
-# Copyright (c) 2013 Amazon.com, Inc. or its affiliates. All Rights Reserved
-#
-# Permission is hereby granted, free of charge, to any person obtaining a
-# copy of this software and associated documentation files (the
-# "Software"), to deal in the Software without restriction, including
-# without limitation the rights to use, copy, modify, merge, publish, dis-
-# tribute, sublicense, and/or sell copies of the Software, and to permit
-# persons to whom the Software is furnished to do so, subject to the fol-
-# lowing conditions:
-#
-# The above copyright notice and this permission notice shall be included
-# in all copies or substantial portions of the Software.
-#
-# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
-# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL-
-# ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
-# SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
-# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
-# IN THE SOFTWARE.
-#
-import time
-
-from tests.compat import mock, unittest
-from tests.unit import AWSMockServiceTestCase
-from tests.unit import MockServiceWithConfigTestCase
-
-from boto.s3.connection import S3Connection, HostRequiredError
-from boto.s3.connection import S3ResponseError, Bucket
-
-
-class TestSignatureAlteration(AWSMockServiceTestCase):
- connection_class = S3Connection
-
- def test_unchanged(self):
- self.assertEqual(
- self.service_connection._required_auth_capability(),
- ['s3']
- )
-
- def test_switched(self):
- conn = self.connection_class(
- aws_access_key_id='less',
- aws_secret_access_key='more',
- host='s3.cn-north-1.amazonaws.com.cn'
- )
- self.assertEqual(
- conn._required_auth_capability(),
- ['hmac-v4-s3']
- )
-
-
-class TestSigV4HostError(MockServiceWithConfigTestCase):
- connection_class = S3Connection
-
- def test_historical_behavior(self):
- self.assertEqual(
- self.service_connection._required_auth_capability(),
- ['s3']
- )
- self.assertEqual(self.service_connection.host, 's3.amazonaws.com')
-
- def test_sigv4_opt_in(self):
- # Switch it at the config, so we can check to see how the host is
- # handled.
- self.config = {
- 's3': {
- 'use-sigv4': True,
- }
- }
-
- with self.assertRaises(HostRequiredError):
- # No host+SigV4 == KABOOM
- self.connection_class(
- aws_access_key_id='less',
- aws_secret_access_key='more'
- )
-
- # Ensure passing a ``host`` still works.
- conn = self.connection_class(
- aws_access_key_id='less',
- aws_secret_access_key='more',
- host='s3.cn-north-1.amazonaws.com.cn'
- )
- self.assertEqual(
- conn._required_auth_capability(),
- ['hmac-v4-s3']
- )
- self.assertEqual(
- conn.host,
- 's3.cn-north-1.amazonaws.com.cn'
- )
-
-
-class TestSigV4Presigned(MockServiceWithConfigTestCase):
- connection_class = S3Connection
-
- def test_sigv4_presign(self):
- self.config = {
- 's3': {
- 'use-sigv4': True,
- }
- }
-
- conn = self.connection_class(
- aws_access_key_id='less',
- aws_secret_access_key='more',
- host='s3.amazonaws.com'
- )
-
- # Here we force an input iso_date to ensure we always get the
- # same signature.
- url = conn.generate_url_sigv4(86400, 'GET', bucket='examplebucket',
- key='test.txt', iso_date='20140625T000000Z')
-
- self.assertIn('a937f5fbc125d98ac8f04c49e0204ea1526a7b8ca058000a54c192457be05b7d', url)
-
- def test_sigv4_presign_optional_params(self):
- self.config = {
- 's3': {
- 'use-sigv4': True,
- }
- }
-
- conn = self.connection_class(
- aws_access_key_id='less',
- aws_secret_access_key='more',
- security_token='token',
- host='s3.amazonaws.com'
- )
-
- url = conn.generate_url_sigv4(86400, 'GET', bucket='examplebucket',
- key='test.txt', version_id=2)
-
- self.assertIn('VersionId=2', url)
- self.assertIn('X-Amz-Security-Token=token', url)
-
- def test_sigv4_presign_headers(self):
- self.config = {
- 's3': {
- 'use-sigv4': True,
- }
- }
-
- conn = self.connection_class(
- aws_access_key_id='less',
- aws_secret_access_key='more',
- host='s3.amazonaws.com'
- )
-
- headers = {'x-amz-meta-key': 'val'}
- url = conn.generate_url_sigv4(86400, 'GET', bucket='examplebucket',
- key='test.txt', headers=headers)
-
- self.assertIn('host', url)
- self.assertIn('x-amz-meta-key', url)
-
-
-class TestUnicodeCallingFormat(AWSMockServiceTestCase):
- connection_class = S3Connection
-
- def default_body(self):
- return """<?xml version="1.0" encoding="UTF-8"?>
-<ListAllMyBucketsResult xmlns="http://doc.s3.amazonaws.com/2006-03-01">
- <Owner>
- <ID>bcaf1ffd86f461ca5fb16fd081034f</ID>
- <DisplayName>webfile</DisplayName>
- </Owner>
- <Buckets>
- <Bucket>
- <Name>quotes</Name>
- <CreationDate>2006-02-03T16:45:09.000Z</CreationDate>
- </Bucket>
- <Bucket>
- <Name>samples</Name>
- <CreationDate>2006-02-03T16:41:58.000Z</CreationDate>
- </Bucket>
- </Buckets>
-</ListAllMyBucketsResult>"""
-
- def create_service_connection(self, **kwargs):
- kwargs['calling_format'] = u'boto.s3.connection.OrdinaryCallingFormat'
- return super(TestUnicodeCallingFormat,
- self).create_service_connection(**kwargs)
-
- def test_unicode_calling_format(self):
- self.set_http_response(status_code=200)
- self.service_connection.get_all_buckets()
-
-
-class TestHeadBucket(AWSMockServiceTestCase):
- connection_class = S3Connection
-
- def default_body(self):
- # HEAD requests always have an empty body.
- return ""
-
- def test_head_bucket_success(self):
- self.set_http_response(status_code=200)
- buck = self.service_connection.head_bucket('my-test-bucket')
- self.assertTrue(isinstance(buck, Bucket))
- self.assertEqual(buck.name, 'my-test-bucket')
-
- def test_head_bucket_forbidden(self):
- self.set_http_response(status_code=403)
-
- with self.assertRaises(S3ResponseError) as cm:
- self.service_connection.head_bucket('cant-touch-this')
-
- err = cm.exception
- self.assertEqual(err.status, 403)
- self.assertEqual(err.error_code, 'AccessDenied')
- self.assertEqual(err.message, 'Access Denied')
-
- def test_head_bucket_notfound(self):
- self.set_http_response(status_code=404)
-
- with self.assertRaises(S3ResponseError) as cm:
- self.service_connection.head_bucket('totally-doesnt-exist')
-
- err = cm.exception
- self.assertEqual(err.status, 404)
- self.assertEqual(err.error_code, 'NoSuchBucket')
- self.assertEqual(err.message, 'The specified bucket does not exist')
-
- def test_head_bucket_other(self):
- self.set_http_response(status_code=405)
-
- with self.assertRaises(S3ResponseError) as cm:
- self.service_connection.head_bucket('you-broke-it')
-
- err = cm.exception
- self.assertEqual(err.status, 405)
- # We don't have special-cases for this error status.
- self.assertEqual(err.error_code, None)
- self.assertEqual(err.message, '')
-
-
-if __name__ == "__main__":
- unittest.main()

Powered by Google App Engine
This is Rietveld 408576698