2019-02-21 07:38:03 +00:00
|
|
|
try:
|
|
|
|
from urllib.parse import urlencode
|
|
|
|
except ImportError:
|
|
|
|
from urllib import urlencode
|
|
|
|
|
|
|
|
import ssl
|
|
|
|
|
2016-08-22 18:17:59 +00:00
|
|
|
import pytest
|
|
|
|
|
2019-02-21 07:38:03 +00:00
|
|
|
import kombu.utils.url
|
2016-08-22 18:17:59 +00:00
|
|
|
from kombu.utils.url import as_url, parse_url, maybe_sanitize_url
|
2020-02-02 15:08:38 +00:00
|
|
|
from kombu.utils.url import parse_ssl_cert_reqs
|
2016-08-22 18:17:59 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_parse_url():
|
|
|
|
assert parse_url('amqp://user:pass@localhost:5672/my/vhost') == {
|
|
|
|
'transport': 'amqp',
|
|
|
|
'userid': 'user',
|
|
|
|
'password': 'pass',
|
|
|
|
'hostname': 'localhost',
|
|
|
|
'port': 5672,
|
|
|
|
'virtual_host': 'my/vhost',
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('urltuple,expected', [
|
|
|
|
(('https',), 'https:///'),
|
|
|
|
(('https', 'e.com'), 'https://e.com/'),
|
|
|
|
(('https', 'e.com', 80), 'https://e.com:80/'),
|
|
|
|
(('https', 'e.com', 80, 'u'), 'https://u@e.com:80/'),
|
|
|
|
(('https', 'e.com', 80, 'u', 'p'), 'https://u:p@e.com:80/'),
|
|
|
|
(('https', 'e.com', 80, None, 'p'), 'https://:p@e.com:80/'),
|
|
|
|
(('https', 'e.com', 80, None, 'p', '/foo'), 'https://:p@e.com:80//foo'),
|
|
|
|
])
|
|
|
|
def test_as_url(urltuple, expected):
|
|
|
|
assert as_url(*urltuple) == expected
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('url,expected', [
|
|
|
|
('foo', 'foo'),
|
|
|
|
('http://u:p@e.com//foo', 'http://u:**@e.com//foo'),
|
|
|
|
])
|
|
|
|
def test_maybe_sanitize_url(url, expected):
|
|
|
|
assert maybe_sanitize_url(url) == expected
|
|
|
|
assert (maybe_sanitize_url('http://u:p@e.com//foo') ==
|
|
|
|
'http://u:**@e.com//foo')
|
2019-02-21 07:38:03 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_ssl_parameters():
|
|
|
|
url = 'rediss://user:password@host:6379/0?'
|
|
|
|
querystring = urlencode({
|
2020-02-02 15:08:38 +00:00
|
|
|
'ssl_cert_reqs': 'required',
|
2019-02-21 07:38:03 +00:00
|
|
|
'ssl_ca_certs': '/var/ssl/myca.pem',
|
|
|
|
'ssl_certfile': '/var/ssl/server-cert.pem',
|
|
|
|
'ssl_keyfile': '/var/ssl/priv/worker-key.pem',
|
|
|
|
})
|
|
|
|
kwargs = parse_url(url + querystring)
|
|
|
|
assert kwargs['transport'] == 'rediss'
|
|
|
|
assert kwargs['ssl']['ssl_cert_reqs'] == ssl.CERT_REQUIRED
|
|
|
|
assert kwargs['ssl']['ssl_ca_certs'] == '/var/ssl/myca.pem'
|
|
|
|
assert kwargs['ssl']['ssl_certfile'] == '/var/ssl/server-cert.pem'
|
|
|
|
assert kwargs['ssl']['ssl_keyfile'] == '/var/ssl/priv/worker-key.pem'
|
|
|
|
|
|
|
|
kombu.utils.url.ssl_available = False
|
|
|
|
|
|
|
|
kwargs = parse_url(url + querystring)
|
|
|
|
assert kwargs['ssl']['ssl_cert_reqs'] is None
|
|
|
|
|
|
|
|
kombu.utils.url.ssl_available = True
|
2020-02-02 15:08:38 +00:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('query_param,ssl_available,expected', [
|
|
|
|
('CERT_REQUIRED', True, ssl.CERT_REQUIRED),
|
|
|
|
('CERT_OPTIONAL', True, ssl.CERT_OPTIONAL),
|
|
|
|
('CERT_NONE', True, ssl.CERT_NONE),
|
|
|
|
('required', True, ssl.CERT_REQUIRED),
|
|
|
|
('optional', True, ssl.CERT_OPTIONAL),
|
|
|
|
('none', True, ssl.CERT_NONE),
|
|
|
|
('CERT_REQUIRED', None, None),
|
|
|
|
])
|
|
|
|
def test_parse_ssl_cert_reqs(query_param, ssl_available, expected):
|
|
|
|
kombu.utils.url.ssl_available = ssl_available
|
|
|
|
result = parse_ssl_cert_reqs(query_param)
|
|
|
|
kombu.utils.url.ssl_available = True
|
|
|
|
assert result == expected
|
|
|
|
|
|
|
|
|
|
|
|
def test_parse_ssl_cert_reqs_bad_value():
|
|
|
|
with pytest.raises(KeyError):
|
|
|
|
parse_ssl_cert_reqs('badvalue')
|