问题在于: 我有两个单独的测试,一个基于Django的TestCase,另一个继承自APITestCase(Django Rest Framework)。单独运行时不会发生错误,但是当我在TestCase之后运行APITestCase时,self.assertEqual(response.status_code,status.HTTP_201_CREATED)不再起作用。
以下是代码的一部分:
class CalendarTests(APITestCase):
def setUp(self):
self.user = User.objects.create_user(
email='test@test.com', password='secret', username='tester')
self.calendar = Calendar(owner=self.user, caltype='p', name='Test Calendar')
self.calendar.save();
def test_api_create_bla(self):
self.client.login(username='test@test.com', password='secret')
url = reverse('calendar-api')
data_initial = {'text': 'testing hurray', 'cal_date':'2015-03-15', 'calendar':1}
data_expected = {'cal_date': '2015-03-15',
'text': u'testing hurray',
'otype': 'd',
'owner': u'tester',
'calendar': 1,
'id': 1}
response = self.client.post(url, data_initial, format='json')
self.assertEqual(response.status_code, status.HTTP_201_CREATED)
self.assertEqual(response.data, data_expected)
self.client.logout()
任何帮助表示感谢。
答案 0 :(得分:0)
好的,伙计们,谢谢,它已经为我解决了。 通过打印响应对象,我发现calendar_id是错误的。因为我使用带有InnoDB的MySQL(可能必须切换到PostreSQL),IntegrityError“无法添加或更新子行:外键约束失败”导致第二次测试中的奇怪行为。帮助我的解决方案是将settings.py从InnoDB引擎切换到MyISAM:
db_options = "INNODB"
import sys
if 'test' in sys.argv:
db_options = "MYISAM"
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'callist',
'USER': 'test',
'PASSWORD': 'test',
'HOST': 'localhost',
'PORT': '80',
'OPTIONS': {'init_command': 'SET storage_engine=' + db_options},
}
}
会想到切换到PostreSQL。 感谢那些试图帮助的人。