在使用单元测试时,有时候需要测试数据库中有数据,这时我们可以使用Django的Fixtures来生成测试数据。
在对Django项目做单元测试时,我们需要一些初始的数据来作为检测结果的依据,那么对于我们已经有正式数据库的模块来说,使用Fixture载入数据是简单有效的方法。
首先,你需要一份json格式的数据文件,Django对此提供了很好的支持—dumpdata 命令:
python manage.py dumpdata myapp >myapp/fixtures/myapp.json # 这个命令将帮助你把数据库中myapp 导入到myapp/fixtures/test.json中 # 这个myapp可以没有,会把数据库所有数据生成Json文件
基础配置
在settings.py 中配置如下内容:
FIXTURE_DIRS = ('/path/to/api/fixtures/',)
接着在test.py中 加入:
fixtures = ['test.json']
最后么当然是运行test命令了:
./manage.py test
示例代码
# coding=utf-8 from __future__ import unicode_literals import json from rest_framework import status from rest_framework.test import APITestCase class DjangoUnittest01(APITestCase): fixtures = ["my_test.json"] def setUp(self): data = { "username": 't1', "password": 'admin123', "code": 666, } self.client.post('/base/admin/login/', data) def test_usergroup_user_information(self):# 以test开头的方法将会执行 url = '/base/admin/teacher/usergroup/21/user/4/information/"update_date": "2018-05-31 16:22:55", "task": "196311177981753978", "otype": "soldier", "task_name": "f_test1", "progress": 1.0, "id": 871 } self.assertEqual(response.status_code, status.HTTP_200_OK) self.assertDictEqual(response.data["results"][0], data)
测试用例通过
Creating test database for alias 'default'...
System check identified no issues (0 silenced).
.
----------------------------------------------------------------------
Ran 1 test in 3.863sOK
Destroying test database for alias 'default'...
常用断言
assertEqual(a, b) a == b assertNotEqual(a, b) a != b assertTrue(x) bool(x) is True assertFalse(x) bool(x) is False assertIs(a, b) a is b assertIsNot(a, b) a is not b assertIsNone(x) x is None assertIsNotNone(x) x is not None assertIn(a, b) a in b assertNotIn(a, b) a not in b assertIsInstance(a, b) isinstance(a, b) assertNotIsInstance(a, b) not isinstance(a, b) assertListEqual(a, b) lists assertTupleEqual(a, b) tuples assertDictEqual(a, b) dicts