diff options
author | Maximilian Hils <git@maximilianhils.com> | 2015-09-12 17:57:21 +0200 |
---|---|---|
committer | Maximilian Hils <git@maximilianhils.com> | 2015-09-12 17:57:21 +0200 |
commit | 32b487109f2d555870a0e93026968fa6eacf9f11 (patch) | |
tree | 6aab46bceebb0520bd8f31fe7535ab4d0cadf170 /test/test_dump.py | |
parent | 4106e1961246616a33c6a1b9d7b8208000611e3d (diff) | |
parent | 5fe12a467f37bfba2f4f663274cacbc6ecc770f7 (diff) | |
download | mitmproxy-32b487109f2d555870a0e93026968fa6eacf9f11.tar.gz mitmproxy-32b487109f2d555870a0e93026968fa6eacf9f11.tar.bz2 mitmproxy-32b487109f2d555870a0e93026968fa6eacf9f11.zip |
Merge pull request #765 from mitmproxy/such-colors-very-wow
Improve Content Views
Diffstat (limited to 'test/test_dump.py')
-rw-r--r-- | test/test_dump.py | 57 |
1 files changed, 46 insertions, 11 deletions
diff --git a/test/test_dump.py b/test/test_dump.py index c76f555f..29931759 100644 --- a/test/test_dump.py +++ b/test/test_dump.py @@ -1,5 +1,6 @@ import os from cStringIO import StringIO +from libmproxy.exceptions import ContentViewException from libmproxy.models import HTTPResponse import netlib.tutils @@ -12,17 +13,51 @@ import mock def test_strfuncs(): - t = HTTPResponse.wrap(netlib.tutils.tresp()) - t.is_replay = True - dump.str_response(t) - - f = tutils.tflow() - f.client_conn = None - f.request.stickycookie = True - assert "stickycookie" in dump.str_request(f, False) - assert "stickycookie" in dump.str_request(f, True) - assert "replay" in dump.str_request(f, False) - assert "replay" in dump.str_request(f, True) + o = dump.Options() + m = dump.DumpMaster(None, o) + + m.outfile = StringIO() + m.o.flow_detail = 0 + m.echo_flow(tutils.tflow()) + assert not m.outfile.getvalue() + + m.o.flow_detail = 4 + m.echo_flow(tutils.tflow()) + assert m.outfile.getvalue() + + m.outfile = StringIO() + m.echo_flow(tutils.tflow(resp=True)) + assert "<<" in m.outfile.getvalue() + + m.outfile = StringIO() + m.echo_flow(tutils.tflow(err=True)) + assert "<<" in m.outfile.getvalue() + + flow = tutils.tflow() + flow.request = netlib.tutils.treq() + flow.request.stickycookie = True + flow.client_conn = mock.MagicMock() + flow.client_conn.address.host = "foo" + flow.response = netlib.tutils.tresp(content=CONTENT_MISSING) + flow.response.is_replay = True + flow.response.code = 300 + m.echo_flow(flow) + + + flow = tutils.tflow(resp=netlib.tutils.tresp("{")) + flow.response.headers["content-type"] = "application/json" + flow.response.code = 400 + m.echo_flow(flow) + + +@mock.patch("libmproxy.contentviews.get_content_view") +def test_contentview(get_content_view): + get_content_view.side_effect = ContentViewException(""), ("x", iter([])) + + o = dump.Options(flow_detail=4, verbosity=3) + m = dump.DumpMaster(None, o, StringIO()) + m.echo_flow(tutils.tflow()) + assert "Content viewer failed" in m.outfile.getvalue() class TestDumpMaster: |