好的我正在为我的Django应用程序编写测试。我试图找出一种方法来迭代测试ajax寄存器调用以获得适当的响应。它工作正常,但我知道它可以以更有效的方式完成。
def test_ajax_register(self):
c = Client()
# Check register success
response = c.post('/register/', {
'register-username': 'testuser',
'register-email': 'testuser@email.com',
'register-password': 'password'
})
self.assertEqual(json.loads(response.content)['status'], 'success')
self.assertEqual(response.status_code, 200)
# Check register failed username taken
response = c.post('/register/', {
'register-username': 'testuser',
'register-email': 'testuser@email.com',
'register-password': 'password'
})
self.assertEqual(json.loads(response.content)['status'], 'fail')
self.assertEqual(json.loads(response.content)['error_msg'], 'username already in use')
# Check register failed email in use
response = c.post('/register/', {
'register-username': 'testuser1',
'register-email': 'testuser@email.com',
'register-password': 'password'
})
self.assertEqual(json.loads(response.content)['status'], 'fail')
self.assertEqual(json.loads(response.content)['error_msg'], 'email already in use')
# Check register failed password length
response = c.post('/register/', {
'register-username': 'testuser2',
'register-email': 'testuser2@email.com',
'register-password': 'pass'
})
self.assertEqual(json.loads(response.content)['status'], 'fail')
self.assertEqual(json.loads(response.content)['error_msg'], 'password must be atleast 8 characters long')
答案 0 :(得分:0)
只需将测试分成不同的方法即可。只要它们具有前缀 test _ ,它们中的每一个都将被触发,并且每个测试也可以作为独立测试运行。如果需要预设任何内容,请使用setUp和tearDown方法。
def test_ajax_register(self):
# Test registration
c = Client()
# Check register success
response = c.post('/register/', {
'register-username': 'testuser',
'register-email': 'testuser@email.com',
'register-password': 'password'
})
self.assertEqual(json.loads(response.content)['status'], 'success')
self.assertEqual(response.status_code, 200)
def test_failed_registration(self):
# Check register failed username taken
response = c.post('/register/', {
'register-username': 'testuser',
'register-email': 'testuser@email.com',
'register-password': 'password'
})
self.assertEqual(json.loads(response.content)['status'], 'fail')
self.assertEqual(json.loads(response.content)['error_msg'], 'username already in use')
def test_email_in_use(self):
# Check register failed email in use
response = c.post('/register/', {
'register-username': 'testuser1',
'register-email': 'testuser@email.com',
'register-password': 'password'
})
self.assertEqual(json.loads(response.content)['status'], 'fail')
self.assertEqual(json.loads(response.content)['error_msg'], 'email already in use')
def test_password_length(self):
# Check register failed password length
response = c.post('/register/', {
'register-username': 'testuser2',
'register-email': 'testuser2@email.com',
'register-password': 'pass'
})
self.assertEqual(json.loads(response.content)['status'], 'fail')
self.assertEqual(json.loads(response.content)['error_msg'], 'password must be atleast 8 characters long')
答案 1 :(得分:0)
通常,您应该逻辑地拆分大测试并遵循UnitOfWork_StateUnderTest_ExpectedBehavior
test method naming practice。
数据驱动的测试的概念也是一个相关的想法,我过去亲自使用ddt
package然后切换到pytest
parameterized tests - 这是一种很好的方法来测试相同的特定症状"使用不同输入数据测试的函数 - 这有助于防止代码重复(DRY principle)并使您的测试更有条理和可读。