Django单元测试(一)

2022-01-23 0 472

Django检测架构比较简单,优选方式是应用python标准库中的unittest控制模块。

Writing tests

Django的单元测试卷应用python的unittest控制模块,这一控制模块应用根据类的办法来理解检测。类名叫django.test.TestCase,承继于python的unittest.TestCase。

from django.test import TestCase
from myapp.models import Animal
 
class AnimalTestCase(TestCase):
    def setUp(self):
        Animal.objects.create(name="lion", sound="roar")
        Animal.objects.create(name="cat", sound="meow")
 
    def test_animals_can_speak(self):
        """Animals that can speak are correctly identified"""
        lion = Animal.objects.get(name="lion")
        cat = Animal.objects.get(name="cat")
        self.assertEqual(lion.speak(), 'The lion says "roar"')
        self.assertEqual(cat.speak(), 'The cat says "meow"')

运作检测的情况下,测试代码会在全部以test开始的资料中搜索全部的test cases(inittest.TestCase的派生类),全自动创建检测集随后运作检测。

留意:假如检测是根据数据库查询浏览的(载入、查看Model),一定要用django.test.TestCase创建检测类,而不必用unittest.TestCase。

Runing tests

实行文件目录下任何的检测(全部的test*.py文件):

$ python manage.py test

实行animals新项目下tests包内的检测:

$ python manage.py test animals.tests

实行animals新项目里的test检测:

$ python manage.py test animals

独立实行某一test case:

$ python manage.py test animals.tests.AnimalTestCase

独立实行某一测试标准:

$ python manage.py test animals.tests.AnimalTestCase.test_animals_can_speak

为检测文档给予途径:

$ python manage.py test animals/

通配检测文件夹名称:

$ python manage.py test --pattern="tests_*.py"

开启warnings提示:

$ python -Wall manage.py test

数据库查询

检测是必须数据库查询的,django会为检测独立转化成数据库查询。无论你的检测是不是根据,如果你全部的检测都实行之后,这一检测数据库查询便会被消毁。

默认设置状况下,检测数据库查询的名称是test_DATABASE_NAME,DATABASE_NAME就是你在settings.py里配备的数据库查询名.假如 你需要给检测数据库查询一个别的的名称,在settings.py中特定TEST_DATABASE_NAME的值。应用sqlite3时,数据库查询是在运行内存中建立的。

除开数据库查询是独立建立的之外,检测工具会采用同样的数据库查询配备--DATABASE_ENGINE, DATABASE_USER, DATABASE_HOST这些.建立检测数据库查询的客户DATABASE_USER(settings中)特定,因此你需要确定 DATABASE_USER有充足的管理权限去建立数据库。

检测实行次序

为了确保全部的检测都从整洁的数据库查询逐渐,实行次序如下所示:

1.全部的TestCase派生类最先运作。

2.全部别的的单元测试卷(unittest.TestCase,SimpleTestCase,TransactionTestCase)。

3.其他的检测(例如doctests等)

加快检测

可以将PASSWORD_HASHERS设定为迅速的优化算法:

PASSWORD_HASHERS = (
    'django.contrib.auth.hashers.MD5PasswordHasher',
)

:本文采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可, 转载请附上原文出处链接。
1、本站提供的源码不保证资源的完整性以及安全性,不附带任何技术服务!
2、本站提供的模板、软件工具等其他资源,均不包含技术服务,请大家谅解!
3、本站提供的资源仅供下载者参考学习,请勿用于任何商业用途,请24小时内删除!
4、如需商用,请购买正版,由于未及时购买正版发生的侵权行为,与本站无关。
5、本站部分资源存放于百度网盘或其他网盘中,请提前注册好百度网盘账号,下载安装百度网盘客户端或其他网盘客户端进行下载;
6、本站部分资源文件是经压缩后的,请下载后安装解压软件,推荐使用WinRAR和7-Zip解压软件。
7、如果本站提供的资源侵犯到了您的权益,请邮件联系: 442469558@qq.com 进行处理!

猪小侠源码-最新源码下载平台 Python教程 Django单元测试(一) http://www.20zxx.cn/295669/xuexijiaocheng/python.html

猪小侠源码,优质资源分享网

常见问题
  • 本站所有资源版权均属于原作者所有,均只能用于参考学习,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担
查看详情
  • 最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,建议提前注册好百度网盘账号,使用百度网盘客户端下载
查看详情

相关文章

官方客服团队

为您解决烦忧 - 24小时在线 专业服务