Django入门三之第一个测试用例
第一部分:
1.在boards里的test.py操作:是一个非常简单但非常有用的测试用例,我们测试的是请求该URL后返回的响应状态码。状态码200意味着成功。
from django.core.urlresolvers import reverse
from django.test import TestCase
class HomeTests(TestCase):
def test_home_view_status_code(self):
url = reverse('home')
response = self.client.get(url)
self.assertEquals(response.status_code, 200)
2.启动python manage.py runserver ,然后在浏览器中请求下主页,可以看到命令端显示如下,其中200代表成功:
如果出现未捕获的异常,语法错误或其他任何情况,Django会返回状态代码500,这意味着是内部服务器错误。现在,想象我们的应用程序有100个视图函数。如果我们为所有视图编写这个简单的测试,只需一个命令,我们就能够测试所有视图是否返回成功代码,因此用户在任何地方都看不到任何错误消息。如果没有自动化测试,我们需要逐一检查每个页面是否有错误。
3.执行Django的测试套件:python manage.py test
第二部分:
现在我们可以测试Django是否在请求的URL的时候返回了正确的视图函数。这也是一个有用的测试,因为随着开发的进展,会发现urls.py 模块可能变得非常庞大而复杂。URL conf 全部是关于解析正则表达式的。有些情况下有一个非常宽容的URL(本来不应该匹配的,却因为正则表达式写的过于宽泛而错误的匹配了),所以Django最终可能返回错误的视图函数。
1.我们可以这样做:
from django.test import TestCase
from django.core.urlresolvers import reverse
from django.urls import resolve
from .views import home
class HomeTests(TestCase):
def test_home_view_status_code(self):
url = reverse('home')
response = self.client.get(url)
self.assertEquals(response.status_code,200)
def test_home_url_resolves_home_view(self):
view = resolve('/')
self.assertEquals(view.func,home)
在第二个测试中,使用resolve函数,Django使用它来将浏览器发起请求的URL和url.py模块中的URL进行匹配,该测试用于确定URL/返回home视图。
2.然后再次执行Django的测试套件:python manage.py test --verbosity=2
要查看有关测试执行时更详细的信息,可将verbosity的级别设置得更高一点:Verbosity决定了将要打印到控制台的通知和调试信息量; 0是无输出,1是正常输出,2是详细输出。