Продолжаем погружаться в работу тестировщика, он же — QA, quality assurance engineer. Его задача — проверить код на наличие ошибок и работу программы в разных условиях.
Мы уже писали о том, что ещё делают тестировщики и какие инструменты для этого используют:
Сегодня мы попробуем написать автотесты — чаще всего именно этим занимаются тестировщики на работе.
Что такое автотесты
Автотесты — это когда одна программа проверяет работу другой программы. Работает это примерно так:
- У нас есть код программы с нужными функциями.
- Мы пишем новую программу, которая вызывает наши функции и смотрит на результат.
- Если результат совпадает с тем, что должно быть, — тест считается пройденным.
- Если результат не совпадает — тест не пройден и нужно разбираться.
Чтобы всё было наглядно, покажем работу автотестов на реальном коде.
Исходная программа
Допустим, мы пишем интерактивную текстовую игру — в ней всё оформляется текстом, и развитие игры зависит от ответов пользователя. Мы сделали отдельный модуль, который делает четыре вещи:
- получает имя игрока;
- принудительно делает в имени большую букву (вдруг кто-то случайно ввёл с маленькой);
- добавляет к нему приветствие;
- сформированную строку отправляет как результат работы функции.
# Собираем приветствие
def hello(name):
# делаем первую букву имени большой
out = name.title()
# формируем приветствие
out = 'Привет, ' + out + '.'
# возвращаем его как результат работы функции
return out
Эта функция хранится в файле hello_function.py
— так мы разбиваем программу на модули, каждый из которых делает что-то своё.
Напишем начало основной программы, которая запрашивает имя, формирует приветствие и добавляет к нему стартовую фразу:
# импортируем функцию из другого файла
from hello_function import hello
# объясняем, что нужно сделать пользователю
print("Введите имя, чтобы начать игру")
# спрашиваем имя
name = input("Как вас зовут: ")
# обрабатываем имя и формируем приветствие
result = hello(name)
# добавляем вторую строку
print(result + " \nДобро пожаловать в «Код»!")
Сохраним это в новом файле start.py и запустим его:
Вроде работает, но хорошо бы проверить, а всегда ли приветствие будет формироваться правильно? Можно сделать вручную, а можно написать автотест.
Пишем автотест
Первое, что нам нужно сделать, — подключить стандартный модуль для автотестов unittest
. Есть модули покруче, но для наших проектов стандартного хватит с запасом. Также получаем доступ к функции hello()
из файла hello_function.py
— работу именно этой функции мы будем проверять автотестом.
# подключаем модуль для автотестов
import unittest
# импортируем функцию из другого файла
from hello_function import hello
А теперь самое важное: нам нужно объявить класс и функцию, внутри которой и будет находиться наш тест. Причём название функции должно начинаться с test_
, чтобы она выполнялась автоматически.
Внутри функции делаем такое:
- формируем данные, которые мы отправляем в тестируемую функцию;
- прописываем ожидаемый результат.
Этими действиями мы как будто вызываем ту функцию и смотрим, получилось ли то, что нам нужно, или нет. При этом нам не нужно обрабатывать результаты тестов — за нас это сделает модуль unittest.
Для запуска тестов добавляем в конец кода стандартный вызов. Читайте комментарии, чтобы лучше вникнуть в код:
# подключаем модуль для автотестов
import unittest
# импортируем функцию из другого файла
from hello_function import hello
# объявляем класс с тестом
class HelloTestCase(unittest.TestCase):
# функция, которая проверит, как формируется приветствие
def test_hello(self):
# отправляем тестовую строку в функцию
result = hello("миша")
# задаём ожидаемый результат
self.assertEqual(result, "Привет, Миша.")
# запускаем тестирование
if __name__ == '__main__':
unittest.main()
После запуска мы увидим такое. Ответ «OK» означает, что наш тест сработал и завершился без ошибок:
Ещё такие тесты позволяют найти ошибки в самом коде. Допустим, разработчик забыл добавить принудительный перевод большой буквы в имени, и тогда тест не пройдёт. Если получится, система даже подсветит, что именно не совпало в результате, — в нашем случае это первая буква имени.
Что дальше
Мы написали самый простой тест и всего с одним условием. При этом мы не проверили тестами работу основной программы — в реальном проекте это тоже нужно было бы сделать. Чтобы попрактиковаться, мы сделаем тесты для одного из наших старых проектов на Python. Заодно проверим, нет ли там каких ошибок, которые мы не заметили.