ТестированиеПрограмм: различия между версиями
Ilis (обсуждение | вклад) |
Ilis (обсуждение | вклад) |
||
Строка 18: | Строка 18: | ||
==== Обработку --help ==== | ==== Обработку --help ==== | ||
Dmitry Levin | {{начало цитаты|источник=Dmitry Levin}} | ||
Программа, корректно обрабатывающая --help, должна | Программа, корректно обрабатывающая --help, должна | ||
# выводить текст в stdout; | # выводить текст в stdout; | ||
Строка 24: | Строка 24: | ||
При неправильном использовании параметров программа | При неправильном использовании параметров программа | ||
# Не должна показывать help. | |||
# Желательно выводить диагностику об ошибке. | |||
# Конечно, сообщение об ошибке должно быть отправлено в stderr. | |||
# Завершаться с кодом не 0 | |||
{{конец цитаты}} | |||
К сожалению, большинство программ нарушают как минимум одно из этих правил. | К сожалению, большинство программ нарушают как минимум одно из этих правил. |
Версия от 21:24, 28 октября 2008
Автоматическое тестирование программ
Сизиф должен стоять на рабочих машинах, иначе поиск багов и разработка прекратится. Предлагается первым шагов в реализации автоматического тестирования определить каталог типа %_datadir/rpm-autotest, в который будут класться сценарии для автоматического тестирования пакета. То есть вместе с пакетом будет устанавливаться и скрипт для его тестирования. После выполнения обновления по очереди вызываются все скрипты тестирования.
Продумать сценарий для запуска/завершения графических программ (или то же самое можно сделать с помощью ldd -r на бинарнике?)
Что именно проверять в сценарии
Функциональность программ в командной строке
- inkscape, dia, convert (чтобы не повторять altbug:6400, altbug:2441 соответственно)
Обработку --help
Dmitry Levin:
Программа, корректно обрабатывающая --help, должна
- выводить текст в stdout;
- завершаться с кодом возврата 0.
При неправильном использовании параметров программа
- Не должна показывать help.
- Желательно выводить диагностику об ошибке.
- Конечно, сообщение об ошибке должно быть отправлено в stderr.
- Завершаться с кодом не 0
К сожалению, большинство программ нарушают как минимум одно из этих правил.
Способы тестирования
Автоматическое тестирование ПО
Автоматическое тестирование GUI:
- см. пакет в Сизифе test-gui-dialog
- или средство cxTest для тестирования программ WINE
Для библиотек — метод, поставленный на поток в перловых модулях — тесты, позволяющие убедиться, что функции ведут себя правильно. Для командной строки — предполагается при сборке пакета выполнять некие проверки (например, вызов команды с различными ключами — всё собираюсь dia так тестировать.