You've already forked httpie-cli
mirror of
https://github.com/httpie/cli.git
synced 2025-08-10 22:42:05 +02:00
Fix --offline --chunked
, add more tests
This commit is contained in:
@@ -183,63 +183,3 @@ def test_json_input_preserve_order(httpbin_both):
|
||||
assert HTTP_OK in r
|
||||
assert r.json['data'] == \
|
||||
'{"order": {"map": {"1": "first", "2": "second"}}}'
|
||||
|
||||
|
||||
def test_offline():
|
||||
r = http(
|
||||
'--offline',
|
||||
'https://this-should.never-resolve/foo',
|
||||
)
|
||||
assert 'GET /foo' in r
|
||||
|
||||
|
||||
def test_offline_form():
|
||||
r = http(
|
||||
'--offline',
|
||||
'--form',
|
||||
'https://this-should.never-resolve/foo',
|
||||
'foo=bar'
|
||||
)
|
||||
assert 'POST /foo' in r
|
||||
assert 'foo=bar' in r
|
||||
|
||||
|
||||
def test_offline_json():
|
||||
r = http(
|
||||
'--offline',
|
||||
'https://this-should.never-resolve/foo',
|
||||
'foo=bar'
|
||||
)
|
||||
assert 'POST /foo' in r
|
||||
assert r.json == {'foo': 'bar'}
|
||||
|
||||
|
||||
def test_offline_multipart():
|
||||
r = http(
|
||||
'--offline',
|
||||
'--multipart',
|
||||
'https://this-should.never-resolve/foo',
|
||||
'foo=bar'
|
||||
)
|
||||
assert 'POST /foo' in r
|
||||
assert 'name="foo"' in r
|
||||
|
||||
|
||||
def test_offline_from_file():
|
||||
r = http(
|
||||
'--offline',
|
||||
'https://this-should.never-resolve/foo',
|
||||
f'@{FILE_PATH_ARG}'
|
||||
)
|
||||
assert 'POST /foo' in r
|
||||
assert FILE_CONTENT in r
|
||||
|
||||
|
||||
def test_offline_download():
|
||||
"""Absence of response should be handled gracefully with --download"""
|
||||
r = http(
|
||||
'--offline',
|
||||
'--download',
|
||||
'https://this-should.never-resolve/foo',
|
||||
)
|
||||
assert 'GET /foo' in r
|
||||
|
75
tests/test_offline.py
Normal file
75
tests/test_offline.py
Normal file
@@ -0,0 +1,75 @@
|
||||
from fixtures import FILE_CONTENT, FILE_PATH_ARG
|
||||
from utils import http
|
||||
|
||||
|
||||
def test_offline():
|
||||
r = http(
|
||||
'--offline',
|
||||
'https://this-should.never-resolve/foo',
|
||||
)
|
||||
assert 'GET /foo' in r
|
||||
|
||||
|
||||
def test_offline_form():
|
||||
r = http(
|
||||
'--offline',
|
||||
'--form',
|
||||
'https://this-should.never-resolve/foo',
|
||||
'foo=bar'
|
||||
)
|
||||
assert 'POST /foo' in r
|
||||
assert 'foo=bar' in r
|
||||
|
||||
|
||||
def test_offline_json():
|
||||
r = http(
|
||||
'--offline',
|
||||
'https://this-should.never-resolve/foo',
|
||||
'foo=bar'
|
||||
)
|
||||
assert 'POST /foo' in r
|
||||
assert r.json == {'foo': 'bar'}
|
||||
|
||||
|
||||
def test_offline_multipart():
|
||||
r = http(
|
||||
'--offline',
|
||||
'--multipart',
|
||||
'https://this-should.never-resolve/foo',
|
||||
'foo=bar'
|
||||
)
|
||||
assert 'POST /foo' in r
|
||||
assert 'name="foo"' in r
|
||||
|
||||
|
||||
def test_offline_from_file():
|
||||
r = http(
|
||||
'--offline',
|
||||
'https://this-should.never-resolve/foo',
|
||||
f'@{FILE_PATH_ARG}'
|
||||
)
|
||||
assert 'POST /foo' in r
|
||||
assert FILE_CONTENT in r
|
||||
|
||||
|
||||
def test_offline_chunked():
|
||||
r = http(
|
||||
'--offline',
|
||||
'--chunked',
|
||||
'--form',
|
||||
'https://this-should.never-resolve/foo',
|
||||
'hello=world'
|
||||
)
|
||||
assert 'POST /foo' in r
|
||||
assert 'Transfer-Encoding: chunked' in r, r
|
||||
assert 'hello=world' in r
|
||||
|
||||
|
||||
def test_offline_download():
|
||||
"""Absence of response should be handled gracefully with --download"""
|
||||
r = http(
|
||||
'--offline',
|
||||
'--download',
|
||||
'https://this-should.never-resolve/foo',
|
||||
)
|
||||
assert 'GET /foo' in r
|
Reference in New Issue
Block a user