Merge "probe tests: Work when fronted by a TLS terminator"
This commit is contained in:
commit
948289151b
@ -14,6 +14,9 @@
|
||||
# limitations under the License.
|
||||
|
||||
|
||||
import eventlet
|
||||
eventlet.monkey_patch()
|
||||
|
||||
from test import get_config
|
||||
from swift.common.utils import config_true_value
|
||||
|
||||
@ -21,3 +24,8 @@ from swift.common.utils import config_true_value
|
||||
config = get_config('probe_test')
|
||||
CHECK_SERVER_TIMEOUT = int(config.get('check_server_timeout', 30))
|
||||
VALIDATE_RSYNC = config_true_value(config.get('validate_rsync', False))
|
||||
PROXY_BASE_URL = config.get('proxy_base_url')
|
||||
if PROXY_BASE_URL is None:
|
||||
# TODO: find and load an "appropriate" proxy-server.conf(.d), piece
|
||||
# something together from bind_ip, bind_port, and cert_file
|
||||
PROXY_BASE_URL = 'http://127.0.0.1:8080'
|
||||
|
@ -31,6 +31,7 @@ from swift.common.http import HTTP_NOT_FOUND
|
||||
|
||||
from swiftclient import client, get_auth, ClientException
|
||||
|
||||
from test.probe import PROXY_BASE_URL
|
||||
from test.probe.common import ENABLED_POLICIES
|
||||
|
||||
TIMEOUT = 60
|
||||
@ -340,7 +341,7 @@ def main():
|
||||
if cmd not in BrainSplitter.__commands__:
|
||||
parser.print_help()
|
||||
return 'ERROR: unknown command %s' % cmd
|
||||
url, token = get_auth('http://127.0.0.1:8080/auth/v1.0',
|
||||
url, token = get_auth(PROXY_BASE_URL + '/auth/v1.0',
|
||||
'test:tester', 'testing')
|
||||
if options.server_type == 'object' and not options.policy_name:
|
||||
options.policy_name = POLICIES.default.name
|
||||
|
@ -39,7 +39,7 @@ from swift.common.manager import Manager
|
||||
from swift.common.storage_policy import POLICIES, EC_POLICY, REPL_POLICY
|
||||
from swift.obj.diskfile import get_data_dir
|
||||
|
||||
from test.probe import CHECK_SERVER_TIMEOUT, VALIDATE_RSYNC
|
||||
from test.probe import CHECK_SERVER_TIMEOUT, VALIDATE_RSYNC, PROXY_BASE_URL
|
||||
|
||||
|
||||
ENABLED_POLICIES = [p for p in POLICIES if not p.is_deprecated]
|
||||
@ -80,8 +80,8 @@ def _check_storage(ipport, path):
|
||||
return resp
|
||||
|
||||
|
||||
def _check_proxy(ipport, user, key):
|
||||
url, token = get_auth('http://%s:%d/auth/v1.0' % ipport,
|
||||
def _check_proxy(user, key):
|
||||
url, token = get_auth(PROXY_BASE_URL + '/auth/v1.0',
|
||||
user, key)
|
||||
account = url.split('/')[-1]
|
||||
head_account(url, token)
|
||||
@ -118,7 +118,7 @@ def check_server(ipport, ipport2server):
|
||||
rv = _retry_timeout(_check_storage, args=(ipport, path))
|
||||
else:
|
||||
rv = _retry_timeout(_check_proxy, args=(
|
||||
ipport, 'test:tester', 'testing'))
|
||||
'test:tester', 'testing'))
|
||||
return rv
|
||||
|
||||
|
||||
@ -392,7 +392,7 @@ class ProbeTest(unittest.TestCase):
|
||||
'url': self.url, 'token': self.token, 'account': self.account}
|
||||
|
||||
rv = _retry_timeout(_check_proxy, args=(
|
||||
proxy_ipport, 'test2:tester2', 'testing2'))
|
||||
'test2:tester2', 'testing2'))
|
||||
self.account_2 = {
|
||||
k: v for (k, v) in zip(('url', 'token', 'account'), rv)}
|
||||
|
||||
|
@ -20,6 +20,7 @@ import unittest
|
||||
from six.moves import http_client
|
||||
from six.moves.urllib.parse import urlparse
|
||||
from swiftclient import get_auth
|
||||
from test.probe import PROXY_BASE_URL
|
||||
from test.probe.common import ReplProbeTest
|
||||
|
||||
|
||||
@ -28,7 +29,7 @@ class TestAccountGetFakeResponsesMatch(ReplProbeTest):
|
||||
def setUp(self):
|
||||
super(TestAccountGetFakeResponsesMatch, self).setUp()
|
||||
self.url, self.token = get_auth(
|
||||
'http://127.0.0.1:8080/auth/v1.0', 'admin:admin', 'admin')
|
||||
PROXY_BASE_URL + '/auth/v1.0', 'admin:admin', 'admin')
|
||||
|
||||
def _account_path(self, account):
|
||||
_, _, path, _, _, _ = urlparse(self.url)
|
||||
@ -46,10 +47,15 @@ class TestAccountGetFakeResponsesMatch(ReplProbeTest):
|
||||
headers['X-Auth-Token'] = self.token
|
||||
|
||||
scheme, netloc, path, _, _, _ = urlparse(self.url)
|
||||
host, port = netloc.split(':')
|
||||
host, port = netloc.partition(':')[::2]
|
||||
if not port:
|
||||
port = '443' if scheme == 'https' else '80'
|
||||
port = int(port)
|
||||
|
||||
conn = http_client.HTTPConnection(host, port)
|
||||
if scheme == 'https':
|
||||
conn = http_client.HTTPSConnection(host, port)
|
||||
else:
|
||||
conn = http_client.HTTPConnection(host, port)
|
||||
conn.request(method, self._account_path(account), headers=headers)
|
||||
resp = conn.getresponse()
|
||||
if resp.status // 100 != 2:
|
||||
|
@ -35,6 +35,7 @@ from swiftclient import client, get_auth, ClientException
|
||||
from swift.proxy.controllers.base import get_cache_key
|
||||
from swift.proxy.controllers.obj import num_container_updates
|
||||
from test import annotate_failure
|
||||
from test.probe import PROXY_BASE_URL
|
||||
from test.probe.brain import BrainSplitter
|
||||
from test.probe.common import ReplProbeTest, get_server_number, \
|
||||
wait_for_server_to_hangup
|
||||
@ -116,7 +117,7 @@ class BaseTestContainerSharding(ReplProbeTest):
|
||||
client.requests.logging.WARNING)
|
||||
super(BaseTestContainerSharding, self).setUp()
|
||||
_, self.admin_token = get_auth(
|
||||
'http://127.0.0.1:8080/auth/v1.0', 'admin:admin', 'admin')
|
||||
PROXY_BASE_URL + '/auth/v1.0', 'admin:admin', 'admin')
|
||||
self._setup_container_name()
|
||||
self.init_brain(self.container_name)
|
||||
self.sharders = Manager(['container-sharder'])
|
||||
|
@ -26,10 +26,12 @@ import time
|
||||
from uuid import uuid4
|
||||
|
||||
from six.moves import http_client as httplib
|
||||
from six.moves.urllib.parse import urlparse
|
||||
|
||||
from swift.common.ring import Ring
|
||||
from swift.common.manager import Manager
|
||||
|
||||
from test.probe import PROXY_BASE_URL
|
||||
from test.probe.common import resetswift, ReplProbeTest, client
|
||||
|
||||
|
||||
@ -109,7 +111,9 @@ class TestWSGIServerProcessHandling(ReplProbeTest):
|
||||
self.assertIn('Invalid path: blah', got_body)
|
||||
|
||||
def get_conn(self):
|
||||
ip, port = self.get_ip_port()
|
||||
scheme, ip, port = self.get_scheme_ip_port()
|
||||
if scheme == 'https':
|
||||
return httplib.HTTPSConnection('%s:%s' % (ip, port))
|
||||
return httplib.HTTPConnection('%s:%s' % (ip, port))
|
||||
|
||||
def _check_reload(self):
|
||||
@ -228,11 +232,11 @@ class TestObjectServerReloadBase(TestWSGIServerProcessHandling):
|
||||
SERVER_NAME = 'object'
|
||||
PID_TIMEOUT = 35
|
||||
|
||||
def get_ip_port(self):
|
||||
def get_scheme_ip_port(self):
|
||||
self.policy.load_ring('/etc/swift')
|
||||
self.ring_node = random.choice(
|
||||
self.policy.object_ring.get_part_nodes(1))
|
||||
return self.ring_node['ip'], self.ring_node['port']
|
||||
return 'http', self.ring_node['ip'], self.ring_node['port']
|
||||
|
||||
def start_write_req(self, conn, suffix):
|
||||
putrequest(conn, 'PUT', '/%s/123/%s/%s/blah-%s' % (
|
||||
@ -296,8 +300,12 @@ class TestProxyServerReloadBase(TestWSGIServerProcessHandling):
|
||||
def swap_configs(self):
|
||||
shutil.copy(self.new_swift_conf_path, self.swift_conf_path)
|
||||
|
||||
def get_ip_port(self):
|
||||
return 'localhost', 8080
|
||||
def get_scheme_ip_port(self):
|
||||
parsed = urlparse(PROXY_BASE_URL)
|
||||
host, port = parsed.netloc.partition(':')[::2]
|
||||
if not port:
|
||||
port = '443' if parsed.scheme == 'https' else '80'
|
||||
return parsed.scheme, host, int(port)
|
||||
|
||||
def assertMaxHeaderSize(self, resp, exp_max_header_size):
|
||||
self.assertEqual(resp.status // 100, 2)
|
||||
|
@ -101,6 +101,7 @@ fake_syslog = False
|
||||
[probe_test]
|
||||
# check_server_timeout = 30
|
||||
# validate_rsync = false
|
||||
# proxy_base_url = http://localhost:8080
|
||||
|
||||
[swift-constraints]
|
||||
# The functional test runner will try to use the constraint values provided in
|
||||
|
Loading…
x
Reference in New Issue
Block a user