import re
from unittest import mock
from flask import request
from routersploit.modules.exploits.cameras.mvpower.dvr_jaws_rce import Exploit
def apply_response(*args, **kwargs):
cmd = request.query_string
res = re.findall(b"echo%20(.+)", cmd)
if res:
return str(res[0], "utf-8"), 200
return "WRONG", 200
@mock.patch("routersploit.modules.exploits.cameras.mvpower.dvr_jaws_rce.shell")
def test_exploit_success(mocked_shell, target):
""" Test scenario - successful exploitation """
route_mock = target.get_route_mock("/shell", methods=["GET"])
route_mock.side_effect = apply_response
exploit = Exploit()
exploit.target = target.host
exploit.port = target.port
assert exploit.check()
assert exploit.run() is None