forked from TrueCloudLab/s3-tests
refactor out _make_request and _make_bucket_request, with a common _make_raw_request; ready for s3website testing.
Signed-off-by: Robin H. Johnson <robbat2@gentoo.org>
This commit is contained in:
parent
3cf86161d0
commit
a48a8983b7
2 changed files with 89 additions and 54 deletions
|
@ -8,6 +8,8 @@ import itertools
|
||||||
import os
|
import os
|
||||||
import random
|
import random
|
||||||
import string
|
import string
|
||||||
|
from httplib import HTTPConnection, HTTPSConnection
|
||||||
|
from urlparse import urlparse
|
||||||
|
|
||||||
from .utils import region_sync_meta
|
from .utils import region_sync_meta
|
||||||
|
|
||||||
|
@ -312,6 +314,10 @@ def setup():
|
||||||
'user_id',
|
'user_id',
|
||||||
'display_name',
|
'display_name',
|
||||||
'email',
|
'email',
|
||||||
|
's3website_domain',
|
||||||
|
'host',
|
||||||
|
'port',
|
||||||
|
'is_secure',
|
||||||
]:
|
]:
|
||||||
try:
|
try:
|
||||||
config[name][var] = cfg.get(section, var)
|
config[name][var] = cfg.get(section, var)
|
||||||
|
@ -394,3 +400,84 @@ def get_new_bucket(target=None, name=None, headers=None):
|
||||||
# ignore that as astronomically unlikely
|
# ignore that as astronomically unlikely
|
||||||
bucket = connection.create_bucket(name, location=target.conf.api_name, headers=headers)
|
bucket = connection.create_bucket(name, location=target.conf.api_name, headers=headers)
|
||||||
return bucket
|
return bucket
|
||||||
|
|
||||||
|
def _make_request(method, bucket, key, body=None, authenticated=False, response_headers=None, request_headers=None, expires_in=100000, path_style=True):
|
||||||
|
"""
|
||||||
|
issue a request for a specified method, on a specified <bucket,key>,
|
||||||
|
with a specified (optional) body (encrypted per the connection), and
|
||||||
|
return the response (status, reason)
|
||||||
|
"""
|
||||||
|
if response_headers is None:
|
||||||
|
response_headers = {}
|
||||||
|
if request_headers is None:
|
||||||
|
request_headers = {}
|
||||||
|
if not path_style:
|
||||||
|
conn = bucket.connection
|
||||||
|
request_headers['Host'] = conn.calling_format.build_host(conn.server_name(), bucket.name)
|
||||||
|
|
||||||
|
if authenticated:
|
||||||
|
url = key.generate_url(expires_in, method=method, response_headers=response_headers, headers=request_headers)
|
||||||
|
o = urlparse(url)
|
||||||
|
path = o.path + '?' + o.query
|
||||||
|
else:
|
||||||
|
if path_style:
|
||||||
|
path = '/{bucket}/{obj}'.format(bucket=key.bucket.name, obj=key.name)
|
||||||
|
else:
|
||||||
|
path = '/{obj}'.format(bucket=key.bucket.name, obj=key.name)
|
||||||
|
|
||||||
|
return _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)
|
||||||
|
|
||||||
|
def _make_bucket_request(method, bucket, body=None, authenticated=False, response_headers=None, request_headers=None, expires_in=100000, path_style=True):
|
||||||
|
"""
|
||||||
|
issue a request for a specified method, on a specified <bucket,key>,
|
||||||
|
with a specified (optional) body (encrypted per the connection), and
|
||||||
|
return the response (status, reason)
|
||||||
|
"""
|
||||||
|
if response_headers is None:
|
||||||
|
response_headers = {}
|
||||||
|
if request_headers is None:
|
||||||
|
request_headers = {}
|
||||||
|
if not path_style:
|
||||||
|
conn = bucket.connection
|
||||||
|
request_headers['Host'] = conn.calling_format.build_host(conn.server_name(), bucket.name)
|
||||||
|
|
||||||
|
if authenticated:
|
||||||
|
url = bucket.generate_url(expires_in, method=method, response_headers=response_headers, headers=request_headers)
|
||||||
|
o = urlparse(url)
|
||||||
|
path = o.path + '?' + o.query
|
||||||
|
else:
|
||||||
|
if path_style:
|
||||||
|
path = '/{bucket}'.format(bucket=bucket.name)
|
||||||
|
else:
|
||||||
|
path = '/'
|
||||||
|
|
||||||
|
return _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)
|
||||||
|
|
||||||
|
def _make_raw_request(host, port, method, path, body=None, request_headers=None, secure=False):
|
||||||
|
if secure:
|
||||||
|
class_ = HTTPSConnection
|
||||||
|
else:
|
||||||
|
class_ = HTTPConnection
|
||||||
|
|
||||||
|
if request_headers is None:
|
||||||
|
request_headers = {}
|
||||||
|
|
||||||
|
skip_host=('Host' in request_headers)
|
||||||
|
skip_accept_encoding = False
|
||||||
|
c = class_(host, port, strict=True)
|
||||||
|
|
||||||
|
# We do the request manually, so we can muck with headers
|
||||||
|
#c.request(method, path, body=body, headers=request_headers)
|
||||||
|
c.connect()
|
||||||
|
c.putrequest(method, path, skip_host, skip_accept_encoding)
|
||||||
|
for k,v in request_headers.items():
|
||||||
|
c.putheader(k,v)
|
||||||
|
c.endheaders(message_body=body)
|
||||||
|
|
||||||
|
res = c.getresponse()
|
||||||
|
#c.close()
|
||||||
|
|
||||||
|
print(res.status, res.reason)
|
||||||
|
return res
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -27,9 +27,6 @@ import re
|
||||||
|
|
||||||
import xml.etree.ElementTree as ET
|
import xml.etree.ElementTree as ET
|
||||||
|
|
||||||
from httplib import HTTPConnection, HTTPSConnection
|
|
||||||
from urlparse import urlparse
|
|
||||||
|
|
||||||
from nose.tools import eq_ as eq
|
from nose.tools import eq_ as eq
|
||||||
from nose.plugins.attrib import attr
|
from nose.plugins.attrib import attr
|
||||||
from nose.plugins.skip import SkipTest
|
from nose.plugins.skip import SkipTest
|
||||||
|
@ -53,6 +50,8 @@ from . import (
|
||||||
config,
|
config,
|
||||||
get_prefix,
|
get_prefix,
|
||||||
is_slow_backend,
|
is_slow_backend,
|
||||||
|
_make_request,
|
||||||
|
_make_bucket_request,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@ -2455,57 +2454,6 @@ def _setup_bucket_request(bucket_acl=None):
|
||||||
|
|
||||||
return bucket
|
return bucket
|
||||||
|
|
||||||
def _make_request(method, bucket, key, body=None, authenticated=False, response_headers=None, expires_in=100000):
|
|
||||||
"""
|
|
||||||
issue a request for a specified method, on a specified <bucket,key>,
|
|
||||||
with a specified (optional) body (encrypted per the connection), and
|
|
||||||
return the response (status, reason)
|
|
||||||
"""
|
|
||||||
if authenticated:
|
|
||||||
url = key.generate_url(expires_in, method=method, response_headers=response_headers)
|
|
||||||
o = urlparse(url)
|
|
||||||
path = o.path + '?' + o.query
|
|
||||||
else:
|
|
||||||
path = '/{bucket}/{obj}'.format(bucket=key.bucket.name, obj=key.name)
|
|
||||||
|
|
||||||
if s3.main.is_secure:
|
|
||||||
class_ = HTTPSConnection
|
|
||||||
else:
|
|
||||||
class_ = HTTPConnection
|
|
||||||
|
|
||||||
c = class_(s3.main.host, s3.main.port, strict=True)
|
|
||||||
c.request(method, path, body=body)
|
|
||||||
res = c.getresponse()
|
|
||||||
|
|
||||||
print res.status, res.reason
|
|
||||||
return res
|
|
||||||
|
|
||||||
def _make_bucket_request(method, bucket, body=None, authenticated=False, expires_in=100000):
|
|
||||||
"""
|
|
||||||
issue a request for a specified method, on a specified <bucket,key>,
|
|
||||||
with a specified (optional) body (encrypted per the connection), and
|
|
||||||
return the response (status, reason)
|
|
||||||
"""
|
|
||||||
if authenticated:
|
|
||||||
url = bucket.generate_url(expires_in, method=method)
|
|
||||||
o = urlparse(url)
|
|
||||||
path = o.path + '?' + o.query
|
|
||||||
else:
|
|
||||||
path = '/{bucket}'.format(bucket=bucket.name)
|
|
||||||
|
|
||||||
if s3.main.is_secure:
|
|
||||||
class_ = HTTPSConnection
|
|
||||||
else:
|
|
||||||
class_ = HTTPConnection
|
|
||||||
|
|
||||||
c = class_(s3.main.host, s3.main.port, strict=True)
|
|
||||||
c.request(method, path, body=body)
|
|
||||||
res = c.getresponse()
|
|
||||||
|
|
||||||
print res.status, res.reason
|
|
||||||
return res
|
|
||||||
|
|
||||||
|
|
||||||
@attr(resource='object')
|
@attr(resource='object')
|
||||||
@attr(method='get')
|
@attr(method='get')
|
||||||
@attr(operation='publically readable bucket')
|
@attr(operation='publically readable bucket')
|
||||||
|
|
Loading…
Reference in a new issue