Django视图测试:构建可靠Web应用的关键步骤

简介: Django视图测试:构建可靠Web应用的关键步骤

接着上一篇的基础测试用例,这一篇也是属于 django 框架的视图测试, django 视图测试能很好地从视图入手模拟用户的视角习惯来进行逻辑测试。

视图测试

基础测试是我们先编写测试用例,然后测试方法,最后编写代码来修复问题,我们现在来使用工具来测试。

django 提供了一个测试 client 来模拟用户在视图级别与代码交互。

我们可以在 tests.py 中使用它 ,甚至可以在 shell 中使用它。

shell 中使用:

python manage.py shell
>>> from django.test.utils import setup_test_environment
>>> setup_test_environment()

setup_test_environment() 安装模板渲染器,这将允许我们检查响应中的一些其他属性,例如 response.context ,否则将不可用他的属性。

请注意,此方法不会设置测试数据库,因此以下内容将针对现有数据库运行,并且输出可能会略有不同,具体取决于已创建的问题。

如果您的 TIME_ZONEsettings.py 设置中不正确,可能会得到其他的结果。

接下来我们需要导入测试客户端类,tests.py 中将使用 django.test.TestCase ,必须带有自己的客户端的类,因此这一步骤是必需的。

>>> from django.test import Client
>>> # create an instance of the client for our use
>>> client = Client()

根据顺序执行下面shell(每一步的结果我都会在相应的的命令下面展示出来):

>>> response = client.get("/")

得到下面返回结果: image.png

>>> response.status_code

得到下面返回结果:

image.png

>>> from django.urls import reverse
>>> response = client.get(reverse("polls:index"))
>>> response.status_code

这一步注意:polls是我加的命名空间,在urls里面类似这种 app_name = 'polls' ,得到下面返回结果:

image.png

>>> response.content

得到下面返回结果:

image.png

>>> response.context["latest_question_list"]

得到下面返回结果:

image.png

这里 shell 测试就结束了。然后我们用 test.py 来做测试,首先先打开我们的 members/views.py 文件,修改一下 index 视图:

from django.utils import timezone
def index(request):
    # latest_question_list = Question.objects.order_by('-pub_date')[:5]
    latest_question_list = Question.objects.filter(pub_date__lte=timezone.now()).order_by("-pub_date")[:5]
    template = loader.get_template('polls/index.html')
    context = {
        'latest_question_list': latest_question_list,
    }
    return HttpResponse(template.render(context, request))

在打开 members/views.py 修改方法:

from django.urls import reverse
def create_question(question_text, days):
    """
    Create a question with the given `question_text` and published the
    given number of `days` offset to now (negative for questions published
    in the past, positive for questions that have yet to be published).
    """
    time = timezone.now() + datetime.timedelta(days=days)
    return Question.objects.create(question_text=question_text, pub_date=time)
    
class QuestionIndexViewTests(TestCase):
    def test_past_question(self):
        """
        Questions with a pub_date in the past are displayed on the
        index page.
        """
        question = create_question(question_text="Past question.", days=-30)
        response = self.client.get(reverse("members:index"))
        self.assertQuerySetEqual(
            response.context["latest_question_list"],
            [question],
        )

上面的这个测试方法,我们都是围绕视图 members/index 来进行一些测试。

首先是问题快捷添加功能,create_question 可以减少创建问题过程中的一些重复。

test_past_question ,我们创建一个问题并验证它是否出现在列表中。

执行命令:

python manage.py test members

得到下面返回结果:

image.png

如需要做特定测试,可以单独对某个测试用例进行修改,而不需要修改我们本身的代码。

四、总结

既然写测试用例,就要合理对每个方法和视图进行测试,你的代码就不会变得难以管理。这里有一些经验:

  • 每个模型或视图单独创建一个TestClass
  • 针对要测试的条件逻辑采用单独的测试方法,
  • 详细描述测试方法名称和他的功能。

在项目开发中,我们更多要从编程工作中去面对编写测试用例,看起来非常麻烦,影响我们的产品开发周期。

实际上它会提高我们后面的效率,其实当你编写测试的任务比花费数小时手动测试应用程序或尝试找出新出现的问题的原因要充实得多。

测试不是发现问题,还能预防问题,测试并不只是我们作为开发简单调试一下。

如果没有测试,应用程序的目的或预期行为可能会相当模糊。

即使是你自己的代码,你有时也会发现自己在里面摸索着试图找出它到底在做什么。

从团队维护的角度,编写自动测试也是大大提高我们团队协作的效率。


相关文章
|
9月前
|
前端开发 JavaScript 开发者
JavaScript:构建动态Web的核心力量
JavaScript:构建动态Web的核心力量
|
前端开发 算法 API
构建高性能图像处理Web应用:Next.js与TailwindCSS实践
本文分享了构建在线图像黑白转换工具的技术实践,涵盖技术栈选择、架构设计与性能优化。项目采用Next.js提供优秀的SSR性能和SEO支持,TailwindCSS加速UI开发,WebAssembly实现高性能图像处理算法。通过渐进式处理、WebWorker隔离及内存管理等策略,解决大图像处理性能瓶颈,并确保跨浏览器兼容性和移动设备优化。实际应用案例展示了其即时处理、高质量输出和客户端隐私保护等特点。未来计划引入WebGPU加速、AI增强等功能,进一步提升用户体验。此技术栈为Web图像处理应用提供了高效可行的解决方案。
|
开发框架 JSON 中间件
Go语言Web开发框架实践:使用 Gin 快速构建 Web 服务
Gin 是一个高效、轻量级的 Go 语言 Web 框架,支持中间件机制,非常适合开发 RESTful API。本文从安装到进阶技巧全面解析 Gin 的使用:快速入门示例(Hello Gin)、定义 RESTful 用户服务(增删改查接口实现),以及推荐实践如参数校验、中间件和路由分组等。通过对比标准库 `net/http`,Gin 提供更简洁灵活的开发体验。此外,还推荐了 GORM、Viper、Zap 等配合使用的工具库,助力高效开发。
|
数据可视化 图形学 UED
从模型托管到交互开发:DataV 如何简化三维 Web 应用构建?
从模型托管到交互开发:DataV 如何简化三维 Web 应用构建?
374 2
|
安全 Linux 开发工具
零基础构建开源项目OpenIM桌面应用和pc web- Electron篇
OpenIM 为开发者提供开源即时通讯 SDK,作为 Twilio、Sendbird 等云服务的替代方案。借助 OpenIM,开发者可以构建安全可靠的即时通讯应用,如 WeChat、Zoom、Slack 等。 本仓库基于开源版 OpenIM SDK 开发,提供了一款基于 Electron 的即时通讯应用。您可以使用此应用程序作为 OpenIM SDK 的参考实现。本项目同时引用了 @openim/electron-client-sdk 和 @openim/wasm-client-sdk,分别为 Electron 版本和 Web 版本的 SDK,可以同时构建 PC Web 程序和桌面应用(Wi
1516 2
|
数据可视化 前端开发 测试技术
接口测试新选择:Postman替代方案全解析
在软件开发中,接口测试工具至关重要。Postman长期占据主导地位,但随着国产工具的崛起,越来越多开发者转向更适合中国市场的替代方案——Apifox。它不仅支持中英文切换、完全免费不限人数,还具备强大的可视化操作、自动生成文档和API调试功能,极大简化了开发流程。
|
Java 测试技术 容器
Jmeter工具使用:HTTP接口性能测试实战
希望这篇文章能够帮助你初步理解如何使用JMeter进行HTTP接口性能测试,有兴趣的话,你可以研究更多关于JMeter的内容。记住,只有理解并掌握了这些工具,你才能充分利用它们发挥其应有的价值。+
1617 23
|
SQL 安全 测试技术
2025接口测试全攻略:高并发、安全防护与六大工具实战指南
本文探讨高并发稳定性验证、安全防护实战及六大工具(Postman、RunnerGo、Apipost、JMeter、SoapUI、Fiddler)选型指南,助力构建未来接口测试体系。接口测试旨在验证数据传输、参数合法性、错误处理能力及性能安全性,其重要性体现在早期发现问题、保障系统稳定和支撑持续集成。常用方法包括功能、性能、安全性及兼容性测试,典型场景涵盖前后端分离开发、第三方服务集成与数据一致性检查。选择合适的工具需综合考虑需求与团队协作等因素。
2147 24
|
JSON 前端开发 测试技术
大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡
大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡
1239 10
大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡
|
JSON 前端开发 API
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
1037 5
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡