test_n750_rce.py 699 Bytes
from unittest import mock
from flask import request
from routersploit.modules.exploits.routers.belkin.n750_rce import Exploit


def apply_response(*args, **kwargs):
    jump = request.form['jump']
    return (
        "TEST" + jump + "TEST"
    ), 200


@mock.patch("routersploit.modules.exploits.routers.belkin.n750_rce.shell")
def test_exploit_success(mocked_shell, target):
    """ Test scenario - successful exploitation """

    route_mock = target.get_route_mock("/login.cgi.php", methods=["POST"])
    route_mock.side_effect = apply_response

    exploit = Exploit()
    exploit.target = target.host
    exploit.port = target.port

    assert exploit.check()
    assert exploit.run() is None