lsekfe 发表于 2020-8-21 09:42:26

一篇文章搞定Django的单元测试

用例

关于django的单元测试,需要知道的是:
  1、对于每一个测试方法都会将setUp()和tearDown()方法执行一遍
  2、会单独新建一个测试数据库来进行数据库的操作方面的测试,默认在测试完成后销毁
  3、在测试方法中对数据库进行增删操作,最后都会被清除。也就是说,在test_add中插入的数据,在test_add测试结束后插入的数据会被清除
  4、django单元测试时为了模拟生产环境,会修改settings中的变量,例如,把DEBUG变量修改为True,把ALLOWED_HOSTS修改为[*]
  执行单元测试
  在单元测试中,可以指定测试粒度。这样可以专注于只测试还没测试的单元测试,而已经测试过的就不测试了。

 常见问题的解决
  数据表多是创建数据库销毁过多时间
  在单元测试时,若migrations的文档过多时,每次单元测试时间绝大部分都消耗在数据库的创建。不过,单元测试代码运行只要几十秒,而数据库的创建却用去了十几分钟。这是个让人感到不舒服,不过django提供了【--keepdb】命令可以在进行单元测试后不删除数据库。
  指定测试数据库的默认字符集
  在创建测试数据库时,数据库的默认字符集也许不是我们想要的例如latin1。可以通过在数据库配置中指定TEST_CHARSET,TEST_COLLATION参数,来指定字符集以及排序规则。

 **settings变量的修改**  若需要在单元测试时修改setting配置。例如,django在单元测试时会将settings.DEBUG设置为True,而我们需要将其设置为False。
  方式一:直接在修改

方式2:通过装饰器修改

API权限问题的解决  在测试API的时候,往往需要等等进行用户登录才有权限调用,此时需要指定登录用户来解决接口调用的权限问题。

Celery异步任务的测试  在代码中几乎肯定是会有celery异步任务,若想对异步任务进行单元测试。可以将CELERY_ALWAYS_EAGER=True,BROKER_BACKEND='memory'

单元的等级  Grade_First:正常的逻辑可可以用,输入一个正常值,可以输出预定的输出
  Grade_Second:异常逻辑可以用,就是输入一个异常值,不会输出系统的报错,而是自己捕捉到的报错
  Grade_Third:极端情况和边界数据可以用,对输入参数的边界情况也要单独测试,确保输出是正确有效的
  Grade_Fourth:所有分支、循环的逻辑走通
  Grade_Fifth:输出数据的所有字段验证,确保每个字段都是正确的地方






Miss_love 发表于 2020-12-30 14:42:10

支持分享
页: [1]
查看完整版本: 一篇文章搞定Django的单元测试