deb-python-gabbi/gabbi/tests/test_parse_url.py
Chris Dent e7b6b37c18 Fix failing tests
Tests in test_runner.py can intermittently fail because test_parse_url
was using case.BASE_TEST without first copying it. Therefore changes
that were made in test_parse_url could be reflected elsewhere. This
points to a generic problem in gabbi itself: There needs to be better
management of global config-like items.

test-limit.sh was failing because the test it uses to signal limiting
was moved from driver to suitemaker. The string used in a grep
had to be corrected.
2016-06-04 14:35:50 +01:00

165 lines
5.8 KiB
Python

#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
"""A place to put tests of URL parsing.
These verbosely cover the _parse_url method to make sure it
behaves.
"""
from collections import OrderedDict
import copy
import unittest
import uuid
from gabbi import case
class UrlParseTest(unittest.TestCase):
@staticmethod
def make_test_case(host, port=8000, prefix='', ssl=False, params=None):
# Attributes used are port, prefix and host and they must
# be set manually here, due to metaclass magics elsewhere.
# test_data must have a base value.
http_case = case.HTTPTestCase('test_request')
http_case.test_data = copy.copy(case.BASE_TEST)
http_case.host = host
http_case.port = port
http_case.prefix = prefix
http_case.test_data['ssl'] = ssl
http_case.test_data['query_parameters'] = params or {}
return http_case
def test_parse_url(self):
host = uuid.uuid4().hex
http_case = self.make_test_case(host)
parsed_url = http_case._parse_url('/foobar')
self.assertEqual('http://%s:8000/foobar' % host, parsed_url)
def test_parse_prefix(self):
host = uuid.uuid4().hex
http_case = self.make_test_case(host, prefix='/noise')
parsed_url = http_case._parse_url('/foobar')
self.assertEqual('http://%s:8000/noise/foobar' % host, parsed_url)
def test_parse_full(self):
host = uuid.uuid4().hex
http_case = self.make_test_case(host)
parsed_url = http_case._parse_url('http://example.com/house')
self.assertEqual('http://example.com/house', parsed_url)
def test_with_ssl(self):
host = uuid.uuid4().hex
http_case = self.make_test_case(host, ssl=True)
parsed_url = http_case._parse_url('/foobar')
self.assertEqual('https://%s:8000/foobar' % host, parsed_url)
def test_default_port_http(self):
host = uuid.uuid4().hex
http_case = self.make_test_case(host, port='80')
parsed_url = http_case._parse_url('/foobar')
self.assertEqual('http://%s/foobar' % host, parsed_url)
def test_default_port_int(self):
host = uuid.uuid4().hex
http_case = self.make_test_case(host, port=80)
parsed_url = http_case._parse_url('/foobar')
self.assertEqual('http://%s/foobar' % host, parsed_url)
def test_default_port_https(self):
host = uuid.uuid4().hex
http_case = self.make_test_case(host, port='443', ssl=True)
parsed_url = http_case._parse_url('/foobar')
self.assertEqual('https://%s/foobar' % host, parsed_url)
def test_default_port_https_no_ssl(self):
host = uuid.uuid4().hex
http_case = self.make_test_case(host, port='443')
parsed_url = http_case._parse_url('/foobar')
self.assertEqual('http://%s:443/foobar' % host, parsed_url)
def test_https_port_80_ssl(self):
host = uuid.uuid4().hex
http_case = self.make_test_case(host, port='80', ssl=True)
parsed_url = http_case._parse_url('/foobar')
self.assertEqual('https://%s:80/foobar' % host, parsed_url)
def test_ipv6_url(self):
host = '::1'
http_case = self.make_test_case(host, port='80', ssl=True)
parsed_url = http_case._parse_url('/foobar')
self.assertEqual('https://[%s]:80/foobar' % host, parsed_url)
def test_ipv6_full_url(self):
host = '::1'
http_case = self.make_test_case(host, port='80', ssl=True)
parsed_url = http_case._parse_url(
'http://[2001:4860:4860::8888]/foobar')
self.assertEqual('http://[2001:4860:4860::8888]/foobar', parsed_url)
def test_ipv6_no_double_colon_wacky_ssl(self):
host = 'FEDC:BA98:7654:3210:FEDC:BA98:7654:3210'
http_case = self.make_test_case(host, port='80', ssl=True)
parsed_url = http_case._parse_url('/foobar')
self.assertEqual(
'https://[FEDC:BA98:7654:3210:FEDC:BA98:7654:3210]:80/foobar',
parsed_url)
http_case = self.make_test_case(host, ssl=True)
parsed_url = http_case._parse_url('/foobar')
self.assertEqual(
'https://[FEDC:BA98:7654:3210:FEDC:BA98:7654:3210]:8000/foobar',
parsed_url)
def test_add_query_params(self):
host = uuid.uuid4().hex
# Use a sequence of tuples to ensure order.
query = OrderedDict([('x', 1), ('y', 2)])
http_case = self.make_test_case(host, params=query)
parsed_url = http_case._parse_url('/foobar')
self.assertEqual('http://%s:8000/foobar?x=1&y=2' % host, parsed_url)
def test_extend_query_params(self):
host = uuid.uuid4().hex
# Use a sequence of tuples to ensure order.
query = OrderedDict([('x', 1), ('y', 2)])
http_case = self.make_test_case(host, params=query)
parsed_url = http_case._parse_url('/foobar?alpha=beta')
self.assertEqual('http://%s:8000/foobar?alpha=beta&x=1&y=2'
% host, parsed_url)
def test_extend_query_params_full_url(self):
host = 'stub'
query = OrderedDict([('x', 1), ('y', 2)])
http_case = self.make_test_case(host, params=query)
parsed_url = http_case._parse_url(
'http://example.com/foobar?alpha=beta')
self.assertEqual('http://example.com/foobar?alpha=beta&x=1&y=2',
parsed_url)