您的位置:MYSQL中文网 > django请求响应流程 Django4.0 进阶测试主题-请求工厂

django请求响应流程 Django4.0 进阶测试主题-请求工厂

2023-04-06 09:30 Django4中文教程

django请求响应流程 Django4.0 进阶测试主题-请求工厂

django请求响应流程

Django是一个开源的Web应用框架,它使用Python语言编写,可以帮助开发者快速构建功能完善的Web应用。Django请求响应流程是一个复杂的过程,它包含了多个步骤,从请求到响应,都要经过一系列的处理。

首先,当用户发出一个HTTP请求时,Django会将其转发到WSGI服务器中。WSGI服务器会将请求转发到Django中间件中。在中间件中,Django会对请求进行预处理,例如解析URL、设置数据库连接、设置日志文件等。

然后,Django会根据URL映射表来匹配URL地址对应的视图函数。如果找到了对应的函数,就会将请求传递给相应的函数处理。在函数中,开发者可以根据不同的情况来处理请求并生成相应的响应内容。

最后,当视图函数处理完成之后,Django会将生成的响应内容交回WSGI服务器。WSGI服务器会将其返回给用户浏览器作为HTTP响应内容。

def view_func(request):  # 视图函数 

    # 处理请求 

    # 生成相应内容 

    return response  # 返回相应内容

Django4.0 进阶测试主题-请求工厂

class RequestFactory

RequestFactory ​与测试客户端共享相同的 API。 但是,​RequestFactory ​不能像浏览器那样运行,而是提供一种生成请求实例的方法,该实例可用作任何视图的第一个参数。 这意味着您可以像测试任何其他功能一样测试视图函数——就像一个黑匣子一样,具有确切已知的输入,可以测试特定的输出。

RequestFactory ​的 API 是测试客户端 API 的一个稍加限制的子集。

  • 它只能访问 HTTP 的 ​get()​、​post()​、​put()​、​delete()​、​head()​、​options()​ 和 ​trace()​ 方法。
  • 这些方法接受所有相同的参数,除了 ​follow​。因为这只是一个产生请求的工厂,所以由你来处理响应。
  • 它不支持中间件。如果需要视图正常运行,会话和认证属性必须由测试本身提供。

例如

下面是一个使用请求工厂的单元测试:

from django.contrib.auth.models import AnonymousUser, User
from django.test import RequestFactory, TestCase

from .views import MyView, my_view

class SimpleTest(TestCase):
    def setUp(self):
        # Every test needs access to the request factory.
        self.factory = RequestFactory()
        self.user = User.objects.create_user(
            username="jacob", email="jacob@…", password="top_secret")

    def test_details(self):
        # Create an instance of a GET request.
        request = self.factory.get("/customer/details")

        # Recall that middleware are not supported. You can simulate a
        # logged-in user by setting request.user manually.
        request.user = self.user

        # Or you can simulate an anonymous user by setting request.user to
        # an AnonymousUser instance.
        request.user = AnonymousUser()

        # Test my_view() as if it were deployed at /customer/details
        response = my_view(request)
        # Use this syntax for class-based views.
        response = MyView.as_view()(request)
        self.assertEqual(response.status_code, 200)

AsyncRequestFactory

RequestFactory ​创建 ​WSGI ​类的请求。如果你想创建 ​ASGI ​类的请求,包括有一个正确的 ​ASGI scope​,你可以使用 ​django.test.AsyncRequestFactory​。
该类与 ​RequestFactory ​直接 API 兼容,唯一的区别是它返回 ​ASGIRequest ​实例,而不是 ​WSGIRequest ​实例。它的所有方法仍然是可同步调用的。


阅读全文
以上是MYSQL中文网为你收集整理的django请求响应流程 Django4.0 进阶测试主题-请求工厂全部内容。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
相关文章
© 2024 MYSQL中文网 mysqlcn.com 版权所有 联系我们
桂ICP备12005667号-29 Powered by CMS