httpie-cli/tests/test_exit_status.py

75 lines
2.6 KiB
Python
Raw Permalink Normal View History

from unittest import mock
2019-09-16 13:26:18 +02:00
from httpie.status import ExitStatus
from .utils import MockEnvironment, http, HTTP_OK
2014-04-24 14:07:31 +02:00
def test_keyboard_interrupt_during_arg_parsing_exit_status(httpbin):
2019-08-31 15:17:10 +02:00
with mock.patch('httpie.cli.definition.parser.parse_args',
side_effect=KeyboardInterrupt()):
2024-03-04 18:12:18 +01:00
r = http('GET', httpbin + '/get', tolerate_error_exit_status=True)
assert r.exit_status == ExitStatus.ERROR_CTRL_C
def test_keyboard_interrupt_in_program_exit_status(httpbin):
with mock.patch('httpie.core.program',
side_effect=KeyboardInterrupt()):
2024-03-04 18:12:18 +01:00
r = http('GET', httpbin + '/get', tolerate_error_exit_status=True)
assert r.exit_status == ExitStatus.ERROR_CTRL_C
2016-03-03 11:47:12 +01:00
def test_ok_response_exits_0(httpbin):
2024-03-04 18:12:18 +01:00
r = http('GET', httpbin + '/get')
2016-03-03 11:47:12 +01:00
assert HTTP_OK in r
assert r.exit_status == ExitStatus.SUCCESS
2016-03-03 11:47:12 +01:00
def test_error_response_exits_0_without_check_status(httpbin):
2024-03-04 18:12:18 +01:00
r = http('GET', httpbin + '/status/500')
assert '500 INTERNAL SERVER ERROR' in r
assert r.exit_status == ExitStatus.SUCCESS
2016-03-03 11:47:12 +01:00
assert not r.stderr
def test_timeout_exit_status(httpbin):
2024-03-04 18:12:18 +01:00
r = http('--timeout=0.01', 'GET', httpbin + '/delay/0.5',
tolerate_error_exit_status=True)
2016-03-03 11:47:12 +01:00
assert r.exit_status == ExitStatus.ERROR_TIMEOUT
def test_3xx_check_status_exits_3_and_stderr_when_stdout_redirected(
httpbin):
env = MockEnvironment(stdout_isatty=False)
2016-03-03 11:47:12 +01:00
r = http('--check-status', '--headers',
2024-03-04 18:12:18 +01:00
'GET', httpbin + '/status/301',
env=env, tolerate_error_exit_status=True)
2016-03-03 11:47:12 +01:00
assert '301 MOVED PERMANENTLY' in r
assert r.exit_status == ExitStatus.ERROR_HTTP_3XX
assert '301 moved permanently' in r.stderr.lower()
def test_3xx_check_status_redirects_allowed_exits_0(httpbin):
r = http('--check-status', '--follow',
2024-03-04 18:12:18 +01:00
'GET', httpbin + '/status/301',
tolerate_error_exit_status=True)
2016-03-03 11:47:12 +01:00
# The redirect will be followed so 200 is expected.
assert HTTP_OK in r
assert r.exit_status == ExitStatus.SUCCESS
2016-03-03 11:47:12 +01:00
def test_4xx_check_status_exits_4(httpbin):
2024-03-04 18:12:18 +01:00
r = http('--check-status', 'GET', httpbin + '/status/401',
tolerate_error_exit_status=True)
2016-03-03 11:47:12 +01:00
assert '401 UNAUTHORIZED' in r
assert r.exit_status == ExitStatus.ERROR_HTTP_4XX
# Also stderr should be empty since stdout isn't redirected.
assert not r.stderr
def test_5xx_check_status_exits_5(httpbin):
2024-03-04 18:12:18 +01:00
r = http('--check-status', 'GET', httpbin + '/status/500',
tolerate_error_exit_status=True)
2016-03-03 11:47:12 +01:00
assert '500 INTERNAL SERVER ERROR' in r
assert r.exit_status == ExitStatus.ERROR_HTTP_5XX