设置 funkload 代理记录器并使用浏览器登录到您的站点,如 funkload 文档中所述:http: //funkload.nuxeo.org/recorder.html
然后,您可以轻松地准确检查您通过 POST 发送的内容。您可能会按照您的想法发送其他参数。在下面的示例中,我正在测试一个使用 crsfmiddleware 的 django 登录,并且还有一个 redirect_to 参数,因此如果登录成功,服务器就知道重定向到哪里。测试并没有真正使用表单,它只是发送浏览器会发送的内容,如果有人这样做的话。如果你想测试真实表单的功能,最好的方法是使用 selenium 之类的东西。
我必须添加以手动提取 crsftoken,因为它随每个请求而变化,并添加一个断言以检查它是否不会返回到登录页面,但除此之外,这个测试就像为我自动生成的记录器一样:
def test_LoginTest(self):
# The description should be set in the configuration file
server_url = self.server_url
# begin of test ---------------------------------------------
# /tmp/tmpMFahey_funkload/watch0001.request
self.get(server_url + "/",
description="Get /")
# /tmp/tmpMFahey_funkload/watch0002.request
reply = self.get(server_url + "/company/config/dashboard/",
description="Get /company/config/dashboard/")
csrftoken = extract_token(self.getBody(), "name='csrfmiddlewaretoken' value='", "' />")
# /tmp/tmpMFahey_funkload/watch0005.request
self.post(server_url + "/accounts/manager/login/?next=/company/config/dashboard/", params=[
['csrfmiddlewaretoken', csrftoken],
['redirect_to', '/company/config/dashboard/'],
['email', 'user'],
['password', '****']],
description="Post /accounts/manager/login/")
self.assert_("login" not in self.getLastUrl(), "Error in login")
# /tmp/tmpMFahey_funkload/watch0008.request
self.get(server_url + "/accounts/manager/logout/",
description="Get /accounts/manager/logout/")
这适用于以下形式:
<form method="post" action="">
<input type='hidden' name='csrfmiddlewaretoken' value='bb7d67ced4a2c6ee44eba811d44c936d' />
<input type="hidden" name="redirect_to" value="/company/config/dashboard/" id="id_redirect_to" />
<input id="id_email" type="text" class="formtxt fom_size1" name="email" maxlength="100" />
<input id="id_password" type="password" class="formtxt fom_size1" name="password" />
<button class="formbtn" type="submit">Validate</button>