我想编写一个直接执行HTTP请求的单元测试(而不是使用django.test.client.Client)。
如果你很好奇为什么 - 这是因为我想测试我从我的Django应用程序公开的Thrift-over-HTTP API - 我想在单元测试中使用Thrift客户端。
问题是在测试期间,服务器实际上并未运行。使用django.test.client.Client时,它只是调用视图函数而不是实际发出HTTP请求。 (如果我错了,请纠正我。)
那么强制测试框架启动HTTP服务器的最佳方法是什么?
我尝试编写一个类似这样的bash脚本:
./manage.py testserver --addrport 7000 &
PID=$!
sleep 5
./manage.py test --no-input
kill $PID
但这很麻烦(并没有真正起作用),因为1)我需要睡眠(否则测试将在测试服务器初始化DB之前启动)和2)测试将尝试再次初始化数据库(在testserver已经初始化之后)。
对此还有其他解决方案吗?
谢谢。
答案 0 :(得分:7)
是的,你是对的 - 这是一个问题而且有一个错误:http://code.djangoproject.com/ticket/2879
然后,您可能会遇到多线程问题,故意被忽略:http://code.djangoproject.com/ticket/10117 http://code.djangoproject.com/ticket/4513 http://code.djangoproject.com/ticket/3357
我很沮丧,因此我编写了一个库,其中包括在单独的线程中启动实时服务器并在之后清除它:http://devel.almad.net/trac/django-sane-testing/。它还通过运行时monkeypatching启动Django的服务器多线程,你可以使用cherrypy http(无论如何都更好)。
唯一的问题是它需要使用nose作为测试框架(与标准unittest 100%向后兼容,但如果你已经使用了其他东西......)。然后你可以使用--with-django和--with-djangoliveserver / - with-cherrypyliveserver。不知道它如何与节俭一起工作。
请注意:
答案 1 :(得分:0)
如果您想使用真实的 HTTP 请求测试您的应用程序,请使用 LiveServerTestCase
or StaticLiveServerTestCase
,它随 Django 一起提供。
在您的 tests.py
文件中,添加如下代码:
from django.contrib.staticfiles.testing import StaticLiveServerTestCase
class Example(StaticLiveServerTestCase):
def test_example(self):
subprocess.check_call(["curl", self.live_server_url])
然后通过运行 python manage.py test
来运行测试。