Skip to content

Commit 3244094

Browse files
author
Ulysses Souza
authored
Merge pull request #2292 from ulyssessouza/fix-config-proxy-mapping
Fix base_url to keep TCP protocol
2 parents 02e660d + b2175c9 commit 3244094

File tree

3 files changed

+12
-8
lines changed

3 files changed

+12
-8
lines changed

docker/utils/utils.py

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -352,9 +352,7 @@ def kwargs_from_env(ssl_version=None, assert_hostname=None, environment=None):
352352
params = {}
353353

354354
if host:
355-
params['base_url'] = (
356-
host.replace('tcp://', 'https://') if enable_tls else host
357-
)
355+
params['base_url'] = host
358356

359357
if not enable_tls:
360358
return params

tests/integration/api_container_test.py

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1080,7 +1080,6 @@ def test_kill_with_signal_integer(self):
10801080

10811081
class PortTest(BaseAPIIntegrationTest):
10821082
def test_port(self):
1083-
10841083
port_bindings = {
10851084
'1111': ('127.0.0.1', '4567'),
10861085
'2222': ('127.0.0.1', '4568'),
@@ -1268,6 +1267,9 @@ def test_attach_no_stream(self):
12681267
@pytest.mark.timeout(5)
12691268
@pytest.mark.skipif(os.environ.get('DOCKER_HOST', '').startswith('ssh://'),
12701269
reason='No cancellable streams over SSH')
1270+
@pytest.mark.xfail(condition=os.environ.get('DOCKER_TLS_VERIFY') or
1271+
os.environ.get('DOCKER_CERT_PATH'),
1272+
reason='Flaky test on TLS')
12711273
def test_attach_stream_and_cancel(self):
12721274
container = self.client.create_container(
12731275
BUSYBOX, 'sh -c "echo hello && sleep 60"',

tests/unit/utils_test.py

Lines changed: 8 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -11,6 +11,7 @@
1111

1212

1313
from docker.api.client import APIClient
14+
from docker.constants import IS_WINDOWS_PLATFORM
1415
from docker.errors import DockerException
1516
from docker.utils import (
1617
convert_filters, convert_volume_binds, decode_json_header, kwargs_from_env,
@@ -83,15 +84,17 @@ def test_kwargs_from_env_tls(self):
8384
DOCKER_CERT_PATH=TEST_CERT_DIR,
8485
DOCKER_TLS_VERIFY='1')
8586
kwargs = kwargs_from_env(assert_hostname=False)
86-
assert 'https://192.168.59.103:2376' == kwargs['base_url']
87+
assert 'tcp://192.168.59.103:2376' == kwargs['base_url']
8788
assert 'ca.pem' in kwargs['tls'].ca_cert
8889
assert 'cert.pem' in kwargs['tls'].cert[0]
8990
assert 'key.pem' in kwargs['tls'].cert[1]
9091
assert kwargs['tls'].assert_hostname is False
9192
assert kwargs['tls'].verify
93+
94+
parsed_host = parse_host(kwargs['base_url'], IS_WINDOWS_PLATFORM, True)
9295
try:
9396
client = APIClient(**kwargs)
94-
assert kwargs['base_url'] == client.base_url
97+
assert parsed_host == client.base_url
9598
assert kwargs['tls'].ca_cert == client.verify
9699
assert kwargs['tls'].cert == client.cert
97100
except TypeError as e:
@@ -102,15 +105,16 @@ def test_kwargs_from_env_tls_verify_false(self):
102105
DOCKER_CERT_PATH=TEST_CERT_DIR,
103106
DOCKER_TLS_VERIFY='')
104107
kwargs = kwargs_from_env(assert_hostname=True)
105-
assert 'https://192.168.59.103:2376' == kwargs['base_url']
108+
assert 'tcp://192.168.59.103:2376' == kwargs['base_url']
106109
assert 'ca.pem' in kwargs['tls'].ca_cert
107110
assert 'cert.pem' in kwargs['tls'].cert[0]
108111
assert 'key.pem' in kwargs['tls'].cert[1]
109112
assert kwargs['tls'].assert_hostname is True
110113
assert kwargs['tls'].verify is False
114+
parsed_host = parse_host(kwargs['base_url'], IS_WINDOWS_PLATFORM, True)
111115
try:
112116
client = APIClient(**kwargs)
113-
assert kwargs['base_url'] == client.base_url
117+
assert parsed_host == client.base_url
114118
assert kwargs['tls'].cert == client.cert
115119
assert not kwargs['tls'].verify
116120
except TypeError as e:

0 commit comments

Comments
 (0)