mirror of
https://github.com/httpie/cli.git
synced 2025-01-10 07:38:35 +01:00
71adcd97d0
* Improve handling of responses without correct content-type charset * [skip ci] Minor tweaks in tests * [skip ci] Add documentation Co-authored-by: claudiatd <claudiatd@gmail.com> * Improve unknown encoding test [skip ci] * Review mime and options retrieval * Add full content-type example in help output * Simplify decoder * [skip ci] s/charset/encoding/ * Tweaks * [skip ci] Fix type annotation * [skip ci] s/charset/encoding/ * Tweaks * Fix type annoation * Improvement * Introduce `codec.encode()` * [skip ci] Tweak changelog Co-authored-by: claudiatd <claudiatd@gmail.com>
49 lines
1.5 KiB
Python
49 lines
1.5 KiB
Python
from unittest import mock
|
|
from pytest import raises
|
|
from requests import Request
|
|
from requests.exceptions import ConnectionError
|
|
|
|
from httpie.status import ExitStatus
|
|
from .utils import HTTP_OK, http
|
|
|
|
|
|
@mock.patch('httpie.core.program')
|
|
def test_error(program):
|
|
exc = ConnectionError('Connection aborted')
|
|
exc.request = Request(method='GET', url='http://www.google.com')
|
|
program.side_effect = exc
|
|
r = http('www.google.com', tolerate_error_exit_status=True)
|
|
assert r.exit_status == ExitStatus.ERROR
|
|
error_msg = (
|
|
'ConnectionError: '
|
|
'Connection aborted while doing a GET request to URL: '
|
|
'http://www.google.com'
|
|
)
|
|
assert error_msg in r.stderr
|
|
|
|
|
|
@mock.patch('httpie.core.program')
|
|
def test_error_traceback(program):
|
|
exc = ConnectionError('Connection aborted')
|
|
exc.request = Request(method='GET', url='http://www.google.com')
|
|
program.side_effect = exc
|
|
with raises(ConnectionError):
|
|
http('--traceback', 'www.google.com')
|
|
|
|
|
|
def test_max_headers_limit(httpbin_both):
|
|
with raises(ConnectionError) as e:
|
|
http('--max-headers=1', httpbin_both + '/get')
|
|
assert 'got more than 1 headers' in str(e.value)
|
|
|
|
|
|
def test_max_headers_no_limit(httpbin_both):
|
|
assert HTTP_OK in http('--max-headers=0', httpbin_both + '/get')
|
|
|
|
|
|
def test_charset_argument_unknown_encoding(httpbin_both):
|
|
with raises(LookupError) as e:
|
|
http('--response-as', 'charset=foobar',
|
|
'GET', httpbin_both + '/get')
|
|
assert 'unknown encoding: foobar' in str(e.value)
|