РЕДАКТИРОВАТЬ:
Этот ответ устарел на данный момент:
- Используйте Jenkins вместо Hudson (то же самое, но с новым именем).
- Используйте django-jenkins вместо xmlrunner.py.
Ссылка на django-jenkins ведет к хорошему руководству по использованию Jenkins с Django. Я оставлю текст ниже, так как в нем все еще есть полезная информация.
Как сказал Брайан, я бы использовал Hudson для планирования, запуска и сбора результатов тестирования. Вы можете изменить свои тесты, чтобы использовать xmlrunner.py (написанный Себастьяном Риттау), который выведет результаты ваших тестов в XML-файл, совместимый с JUnit, для Hudson.
Вот пример того, как тестовый код будет использовать xmlrunner:
import unittest
import xmlrunner
class TheTest(unittest.TestCase):
def testOne(self):
self.assertEquals(1, 1)
def testTwo(self):
self.assertEquals(2, 2)
def testThree(self):
self.assertEquals(3, 4)
if __name__ == '__main__':
suite = unittest.TestLoader().loadTestsFromTestCase(TheTest)
xmlrunner.XMLTestRunner().run(suite)
После установки Hudson вы создадите новый проект для тестируемого исходного репозитория. Вам понадобится RTFM, но в двух словах:
- В разделе «Управление исходным кодом» вы вводите информацию о своих репозиториях и периодически опрашиваете репозиторий (я обычно просто делаю * * * * *, поэтому он проверяет каждую минуту)
- Добавьте команду, которая запускает тестовый скрипт (например,
python test.py
).
- Проверьте отчет о результатах теста публикации JUnit. Если у него есть такая ошибка, как
'TEST-*.xml' doesn't match anything
, вы можете спокойно ее игнорировать. Это будет выглядеть примерно так:
(источник: snowpeaksoftware.com)
После того, как все это будет сделано, вы сможете видеть результаты тестов каждый раз, когда Hudson запускается после регистрации. Это будет выглядеть примерно так:
(источник: snowpeaksoftware .com)
Вы также получаете более подробные страницы, такие как эта страница:
(источник: snowpeaksoftware.com)
и эта страница:
(источник: snowpeaksoftware.com)
25.05.2010