Тестировщик программного обеспечения — критично важная роль в индустрии IT. Каждое собеседование на эту должность обычно представляет собой комбинацию технических и теоретических вопросов. Ниже описано 15 самых часто задаваемых вопросов с ответами, которые помогут вам успешно пройти собеседование.

1. Что такое тестирование ПО?

Тестирование ПО — это процесс проверки качества программного обеспечения, цель которого — обнаружить ошибки, убедиться в соответствии продукта требованиям и гарантировать удовлетворение потребностей конечных пользователей.

2. Каковы основные типы тестирования?

  • Функциональное тестирование: проверка работоспособности программы.

  • Нефункциональное тестирование: включает тестирование производительности, безопасности, удобства использования и других характеристик.

  • Ручное тестирование: тестирование без использования автоматизированных инструментов.

  • Автоматизированное тестирование: выполнение тестов с помощью скриптов и программ.

3. Что такое жизненный цикл дефекта?

Жизненный цикл дефекта — это последовательность этапов, которые проходит дефект от обнаружения до устранения:

  1. Новый (New)

  2. В работе (Assigned)

  3. Исправлен (Fixed)

  4. Проверен (Verified)

  5. Закрыт (Closed) или Отклонён (Rejected).

4. Чем отличается тест-кейс от тест-сценария?

  • Тест-кейс: документ с подробным описанием шагов, входных данных, ожидаемого результата и состояния теста.

  • Тест-сценарий: общий набор условий или действий для проверки функционала.
    Чуть больше об отличиях тут

5. Что такое регрессионное тестирование?

Это тип тестирования, цель которого — убедиться, что внесенные изменения не нарушили существующую функциональность.

6. Какие инструменты автоматизации тестирования вы знаете?

Некоторые популярные инструменты:

  • Selenium

  • JUnit

  • TestNG

  • Appium

  • Postman

  • JMeter

7. Что такое Smoke Testing и Sanity Testing?

  • Smoke Testing: поверхностная проверка базовой функциональности системы.

  • Sanity Testing: проверка отдельных частей системы после внесения изменений.

8. Объясните понятие "чёрного ящика" и "белого ящика".

  • Чёрный ящик: тестирование без знания внутренней структуры кода.

  • Белый ящик: тестирование с использованием знаний о внутренней структуре и логике программы.

9. Что такое тестовое покрытие (Test Coverage)?

Это метрика, показывающая степень покрытия кода или функционала тестами.

10. Как вы приоритизируете тест-кейсы?

Приоритизация основывается на риске, критичности функционала и вероятности возникновения ошибок.

11. Что такое Exploratory Testing?

Это исследовательское тестирование без заранее написанных тест-кейсов, где тестировщик изучает систему в реальном времени.

12. Каковы ключевые шаги в написании отчёта о дефекте?

  1. Уникальный ID дефекта.

  2. Описание проблемы.

  3. Шаги для воспроизведения.

  4. Ожидаемый и фактический результат.

  5. Скриншоты или логи.

  6. Приоритет и серьёзность.

13. Что такое Agile и как тестирование вписывается в эту методологию?

Agile — это гибкая методология разработки ПО. Тестирование интегрируется в спринты, а тестировщики активно взаимодействуют с разработчиками.

14. Как вы документируете процесс тестирования?

Документирование включает:

  • Тест-план.

  • Тестовые сценарии и тест-кейсы.

  • Отчёты о дефектах.

  • Итоговый отчёт о тестировании.

15. Расскажите об успешном проекте, в котором вы участвовали как тестировщик.

Подчеркните свой вклад, например, создание эффективных тест-кейсов, автоматизацию рутинных задач или выявление критических багов, которые могли бы повлиять на конечного пользователя.

16. Какие виды тестирования применяются для мобильных приложений?

Для мобильных приложений применяются:

  • Тестирование совместимости на разных устройствах и ОС.

  • Тестирование производительности.

  • Тестирование безопасности.

  • Тестирование удобства использования (UX).

17. Как вы проверяете веб-приложения на кроссбраузерную совместимость?

Для проверки веб-приложений используются:

  • Инструменты, такие как BrowserStack или CrossBrowserTesting.

  • Ручное тестирование в различных браузерах и их версиях.

  • Автоматизированные тесты с использованием Selenium.

18. Что такое нагрузочное тестирование?

Нагрузочное тестирование определяет, как система справляется с большим количеством пользователей или транзакций за определённый период времени.

19. Какие показатели являются важными при тестировании производительности?

Ключевые метрики:

  • Время отклика.

  • Пропускная способность.

  • Уровень использования ресурсов (CPU, RAM, диска).

  • Количество ошибок.

20. Как вы планируете тестирование?

Планирование включает:

  • Определение целей тестирования.

  • Подготовку тест-плана.

  • Создание тест-кейсов.

  • Оценку ресурсов и времени.

  • Назначение ответственных за выполнение тестов.

Напишите вопросы, которые вам задавали на собеседовании и я добавлю их в следующую статью. Удачного собеседования всем.

Комментарии (3)


  1. Darth_Anjan
    03.01.2025 19:14

    Тест-кейс и тест-сценарий - это одно и то же. Смотрите официальный перевод глоссария istqb.

    То, что по ссылке называют сценарием - это похоже на use case (сценарий использования системы)


  1. clarifyingman
    03.01.2025 19:14

    И ни одного вопроса про тест-дизайн. Какие техники тест-дизайна известны?

    Даже не спросили, что такое дефект/баг. Хотя по ответу на вопрос 12 можно сделать определенные выводы.

    Я так понимаю, при заведении бага указывать версию ПО уже не нужно. И это печалит.

    Про типы тестирования полная каша. В рамках жизненного цикла ПО есть НФ и Регресс. Где-то там притаилось тестирование требований. А в случае сложных систем еще интеграционным тестированием приходится заниматься.

    Для мобилок и браузера неплохо бы еще вспомнить про тестирование api и разницу между фронтом/бэком. И зачем вообще нужно тестирование графического интерфейса.

    Если текст этой статьи был сгенерирован нейросетью, то результат нормальный.

    А так статья скорее вредная, чем полезная.


  1. hir0kashi
    03.01.2025 19:14

    Исключительное ИМХО, но:

    Этот список вопросов в компании от А уровня не задают, если речь идет не о позиции стажера/совсем уж сопливого джуна.

    Рынок, как и требования к QA - сильно изменились в строну большей "инженерности". А потому значительная часть вопросов нормальной компании будет нацелена не на сухую ISTQB Basic теорию, а на реальное понимание той области, где предстоит применять навыки: задачи/вопросы по тестированию API, рел/не рел БД. Из теории обычно могу спросить как раз про ТТД, ибо умение на практике их применять косвено говорит о наличии опыта кандидата и его понимании как вообще что делать

    Отдельной категорией сейчас всегда идут вопросы по CI/CD, развертыванию и инструментам типо Docker,K8s, GitLab/Jenkins/BitBucket etc. Тут чаще просто закидываюи удочку, насколько кандидат погружался в тему непрерывной интеграции и деплоя. Чаще всего есть на то девопсы, то базу знать - высоко летать.

    Ну и автоматизация. Сейчас она пояти на каждой позиции. Чаще всего Java/Python. Иногда есть изврат на JS или там всякие BDD, но эт на любителя.

    По ЯП обычно спрашивают core + вопросы по инструментам (appium/restAssured, Selenium/selenide etc)

    Вывод:

    Знать теорию базовую - это, конечно, нужно. Но, в большинстве нормальных контор мучать вас вопросами по базовой теории никто не станет, ибо важны ваши реальные навыки, а не сухая теория.

    Всем добра!