aboutsummaryrefslogtreecommitdiffstats
path: root/test/mitmproxy/tools/test_dump.py
blob: f303c808888692b99450946d0b63ed193b20400c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
import pytest
from unittest import mock

from mitmproxy import log
from mitmproxy import controller
from mitmproxy import options
from mitmproxy.tools import dump

from .. import tservers


class TestDumpMaster(tservers.MasterTest):
    def mkmaster(self, flt, **opts):
        o = options.Options(view_filter=flt, verbosity='error', **opts)
        m = dump.DumpMaster(o, with_termlog=False, with_dumper=False)
        return m

    def test_has_error(self):
        m = self.mkmaster(None)
        ent = log.LogEntry("foo", "error")
        ent.reply = controller.DummyReply()
        m.addons.trigger("log", ent)
        assert m.errorcheck.has_errored

    @pytest.mark.parametrize("termlog", [False, True])
    def test_addons_termlog(self, termlog):
        with mock.patch('sys.stdout'):
            o = options.Options()
            m = dump.DumpMaster(o, with_termlog=termlog)
            assert (m.addons.get('termlog') is not None) == termlog

    @pytest.mark.parametrize("dumper", [False, True])
    def test_addons_dumper(self, dumper):
        with mock.patch('sys.stdout'):
            o = options.Options()
            m = dump.DumpMaster(o, with_dumper=dumper)
            assert (m.addons.get('dumper') is not None) == dumper