我有一个功能
def getEvents(eid, request):
......
现在我想单独为上面的函数编写单元测试(不调用视图)。
那么我应该如何在TestCase
中调用上述内容。是否可以创建请求?
答案 0 :(得分:77)
请参阅this solution:
from django.utils import unittest
from django.test.client import RequestFactory
class SimpleTest(unittest.TestCase):
def setUp(self):
# Every test needs access to the request factory.
self.factory = RequestFactory()
def test_details(self):
# Create an instance of a GET request.
request = self.factory.get('/customer/details')
# Test my_view() as if it were deployed at /customer/details
response = my_view(request)
self.assertEqual(response.status_code, 200)
答案 1 :(得分:24)
如果您使用的是django测试客户端(from django.test.client import Client
),您可以从响应对象访问请求,如下所示:
from django.test.client import Client
client = Client()
response = client.get(some_url)
request = response.wsgi_request
或者如果您使用django.TestCase
(from django.test import TestCase, SimpleTestCase, TransactionTestCase
),只需输入self.client
即可访问任何测试用例中的客户端实例:
response = self.client.get(some_url)
request = response.wsgi_request
答案 2 :(得分:11)
使用RequestFactory
创建虚拟请求。
答案 3 :(得分:1)
您可以使用django测试客户端
from django.test import Client
c = Client()
response = c.post('/login/', {'username': 'john', 'password': 'smith'})
response.status_code
response = c.get('/customer/details/')
response.content
了解更多详情
https://docs.djangoproject.com/en/1.11/topics/testing/tools/#overview-and-a-quick-example
答案 4 :(得分:0)
你的意思是def getEvents(request, eid)
对吧?
使用Django unittest,您可以使用from django.test.client import Client
发出请求。
见这里:Test Client
@ Secator的答案是完美的,因为它创建了一个模拟对象,这对于一个非常好的单元测试来说是非常优选的。但是根据你的目的,使用Django的测试工具可能更容易。