aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorAldo Cortesi <aldo@corte.si>2018-05-12 10:37:16 +1200
committerAldo Cortesi <aldo@corte.si>2018-05-12 11:10:14 +1200
commit482043cdcfbcf48ecd7a0185a20c8678ce7deb0d (patch)
tree21c6e86256c861fb8abdc8eef42ceb058c690817 /test
parent6dff8c58adbcb9da9b7bdeb088148c3f0d364c02 (diff)
downloadmitmproxy-482043cdcfbcf48ecd7a0185a20c8678ce7deb0d.tar.gz
mitmproxy-482043cdcfbcf48ecd7a0185a20c8678ce7deb0d.tar.bz2
mitmproxy-482043cdcfbcf48ecd7a0185a20c8678ce7deb0d.zip
commands: handle type errors on startup
fixes #3088 fixes #2787
Diffstat (limited to 'test')
-rw-r--r--test/mitmproxy/test_command.py32
1 files changed, 29 insertions, 3 deletions
diff --git a/test/mitmproxy/test_command.py b/test/mitmproxy/test_command.py
index 22ebcc21..7c0dc06d 100644
--- a/test/mitmproxy/test_command.py
+++ b/test/mitmproxy/test_command.py
@@ -1,4 +1,5 @@
import typing
+import inspect
from mitmproxy import command
from mitmproxy import flow
from mitmproxy import exceptions
@@ -55,19 +56,34 @@ class TAddon:
pass
+class Unsupported:
+ pass
+
+
class TypeErrAddon:
@command.command("noret")
def noret(self):
pass
+ @command.command("invalidret")
+ def invalidret(self) -> Unsupported:
+ pass
+
+ @command.command("invalidarg")
+ def invalidarg(self, u: Unsupported):
+ pass
+
class TestCommand:
def test_typecheck(self):
with taddons.context(loadcore=False) as tctx:
cm = command.CommandManager(tctx.master)
a = TypeErrAddon()
- c = command.Command(cm, "noret", a.noret)
- print(c.signature_help())
+ command.Command(cm, "noret", a.noret)
+ with pytest.raises(exceptions.CommandError):
+ command.Command(cm, "invalidret", a.invalidret)
+ with pytest.raises(exceptions.CommandError):
+ command.Command(cm, "invalidarg", a.invalidarg)
def test_varargs(self):
with taddons.context() as tctx:
@@ -288,6 +304,11 @@ def test_typename():
assert command.typename(mitmproxy.types.Path) == "path"
assert command.typename(mitmproxy.types.Cmd) == "cmd"
+ with pytest.raises(exceptions.CommandError, match="missing type annotation"):
+ command.typename(inspect._empty)
+ with pytest.raises(exceptions.CommandError, match="unsupported type"):
+ command.typename(None)
+
class DummyConsole:
@command.command("view.resolve")
@@ -339,7 +360,8 @@ class TCmds(TAttr):
pass
-def test_collect_commands():
+@pytest.mark.asyncio
+async def test_collect_commands():
"""
This tests for the error thrown by hasattr()
"""
@@ -349,6 +371,10 @@ def test_collect_commands():
c.collect_commands(a)
assert "empty" in c.commands
+ a = TypeErrAddon()
+ c.collect_commands(a)
+ await tctx.master.await_log("Could not load")
+
def test_decorator():
with taddons.context() as tctx: