QA
Когда следует начинать тестировать ПО?
* когда тестирование ПО проводится на ранней стадии, вы можете с легкостью повлиять на дизайн, так как его изменение на этой стадии не столь дорогостоящее чем на более поздних стадиях; * в свою очередь, чем раньше обнаруживается ошибка, тем дешевле она стоит компании; * также тестирование может начинаться до фактического получения ПО (статическое тестирование), что действительно немаловажно, так как снижает сложность провождения динамической стадии тестирования. Бытует мнение, что многие ошибки, которые найдены в стадии динамического тестирования, могли и должны были зафиксированные в стадии статического тестирования; *тестирование на ранних стадиях (изучение требований, спецификаций, бизнес случаев и т.д.) обеспечит тестировщику больше знаний о ПО, поможет обнаружить логические и технические ошибки, которые бы влияли на ПО, его конечный дизайн и стоимость.
Процессы входящие в тестирование ПО
Валидация (validation): доказанное объективными результатами исследования подтверждение того, что требования для конкретного определенного использования приложения были выполнены. Верификация (verification): доказанное объективными результатами исследования подтверждение того, что определенные требования были выполнены.
Матрица трассировки
Для измерения покрытия требований, необходимо проанализировать требования к продукту и разбить их на пункты. Опционально каждый пункт связывается с тест кейсами, проверяющими его. Совокупность этих связей — и является матрицей трассировки (traceability matrix). Проследив связи, можно понять какие именно требования проверяет тестовый случай.Тесты не связанные с требованиями не имеют смысла. Требования, не связанные с тестами — это «белые пятна», т.е. выполнив все созданные тест кейсы, нельзя дать ответ реализовано данное требование в продукте или нет.
Что такое процедура тестирования (Test Procedure)?
Документ, описывающий последовательность действий при выполнении теста. Также известен как ручной сценарий тестирования.
Какие основные уровни тестирования ПО?
Компонентное (component)/ модульное тестирование (module, unit testing) — это тестирование отдельных компонентов ПО [IEEE 610]; Интеграционное тестирование (integration testing) — это тестирование, выполняемое для обнаружения дефектов в интерфейсах и во взаимодействии между интегрированными компонентами или системами.Следует также понимать что такое big-bang тестирование, тестирование «сверху вниз», восходящие и инкрементное тестирование; Системное тестирование (system testing) — это процесс тестирования системы в целом с целью проверки того, что она соответствует установленным требованиям; Приёмочное тестирование (acceptance testing) — это формальное тестирование по отношению к потребностям, требованиям и бизнес процессам пользователя, проводимое с целью определения соответствия системы критериям приёмки (критерии выхода, которым должны соответствовать компонент или система, для того, чтобы быть принятыми пользователем, заказчиком или другим уполномоченным лицом) [IEEE 610], с чего следуют такие виды, о которых желательно не забывать:пользовательское приёмочное тестирование (user acceptance testing);производственное приемочное тестирование (factory acceptance testing) — это приемочное тестирование, проводимое на стороне разработчика программного продукта и проводящееся сотрудниками компании-поставщика с целью определить, соответствует или нет компонент или система как программным, так и аппаратным требованиям;стороннее приемочное тестирование (site acceptance testing) — это приёмочное тестирование пользователями или заказчиком на своей стороне. Проводится с целью определить как соответствие бизнес-процессу, так и удостовериться, что данная система или компонент удовлетворяет потребностям пользователей или заказчика. Обычно включает в себя проверку как программного обеспечения, так и технической базы;эксплуатационное приемочное тестирование (operational acceptance testing) — это эксплуатационное тестирование в фазе приемочного тестирования, обычно выполняемое пользователем и/или сотрудниками с администраторским доступом, в рабочей среде (возможно, симулированой), фокусируясь на функциональных аспектах (восстанавливаемость, поведение ресурсов, устанавливаемость и техническое соответствие). Альфа-тестирование (alpha testing) — это моделируемое или действительное эксплуатационное тестирование потенциальными пользователями/заказчиками или независимой командой тестирования на стороне разработчиков, но вне разрабатывающей организации. Альфа-тестирование часто применяется к коробочному ПО в качестве внутреннего приёмочного тестирования; Бета-тестирование (beta testing) — это эксплуатационное тестирование потенциальными и/или существующими клиентами/заказчиками на внешней стороне никак не связанными с разработчиками, с целью определения действительно ли компонент или система удовлетворяет требованиям клиента/заказчика и вписывается в бизнес-процессы. Бета-тестирование часто проводится как форма внешнего приёмочного тестирования готового программного обеспечения для того чтобы получить отзывы рынка;
Проведение проверок
Либо согласно документации, либо ad hoc (интуитивно, свободный поиск, без документации). В любом случае это проводится согласно списку отобранных проверок. Почему-то большинство именно этот пункт называет тестированием. И в голове обывателя, незнакомого с профессией, только один этот пункт и содержится J.
Как вы объясните Bug/Defect/Error в ПО?
Любая проблема/ошибка в ПО, что вызвана следующим поведением: поломка ПО или отображение недействительного уведомления; ПО предоставляет недействительные результаты; ПО не удалось выполнить, как ожидалось (любое отклонение от ожидаемых результатов).
примеры верификации в зависимости от уровней тестирования.
Модульное тестирование (unit testing):-проверка осуществления проектирования программного обеспечения. Интеграционное тестирование (integration testing):-тестирование на интеграцию между всеми соответствующими компонентами до того как ПО перейдет к следующему уровню (system). Системное тестирование (system testing):-обеспечение соответствия системы предопределенным требованиям и спецификации. Приёмочное тестирование (acceptance testing):-убедитесь, что система отвечает требованиям клиента.
Выявление требований
Неизвестны требования - нет тестирования. Необходимо собрать всю доступную информацию о предмете тестирования, вариантах использования и т. п. Первый источник - техническая документация и юзер-стори - это прямые требования. Качество же косвенных требований во многом зависят от добросовестности, ответственности, квалификации тестировщика и всей команды проекта.
Что такое ошибка?
Ошибка - несоответствие производимого продукта требованиям, прямым или косвенным.
основные фазы модели жизненного цикла разработки ПО
Принятия решения (идея) о необходимости создания ПО; Сбор и анализ требований; Дизайн (Системы и ПО) на основе требований; Кодирование на основе дизайна системы; Тестирование; Внедрение в пользовательскую среду; Сопровождение (в том числе фиксация найденных в пользовательской среде ошибок); Изъятие из эксплуатации (редко);
Код завершен
Простой термин, имеющий отношение к конкретному этапу SDLC. Говоря «код завершен», мы на самом деле имеем ввиду, что его реализация завершена (вся функциональность ПО успешно реализована). Хотя если даже код будет полностью реализован, всегда есть новые ошибки обнаруженные во время тестирования.
пример прямых и косвенных требований
Самый очевидный и «простой» пример: в ТЗ — «кнопка должна быть красного цвета» - прямое требование, из него проистекают косвенные - она не должна быть синей, зеленой, серой или черной и т. д... Естественно, это сильное упрощение, но очень показательное. А главное - такой подход отсекает излишне формальное отношение к тестированию и поднимает планку квалификации тестирования как такового, ибо для грамотного тестирования мало знать только ТЗ и юзер-стори, надо еще изучить прикладную область и специфику потребления производимого продукта. Такое тестирование значительно эффективнее.
Что такое тестирование? В чем его суть как процесса?
Тестирование - комплекс мероприятий, направленный на проведение проверок на соответствие производимого продукта требованиям, к нему предъявляемым (прямым и косвенным).
Какие бывают требования?
Требования бывают прямыми (т. е. формализованными в технической документации, спеках, юзер-стори и прочих формальных артефактах) и косвенными (т. е. проистекающими из прямых, либо являющимися негласным стандартом для данной продукции или основывающиеся на опыте и здравом смысле использования данного продукта или продуктах, подобных ему). Все требования также подразделяются на функциональные (описывающие какие функции должен выполнять продукт) и нефункциональные (требования к окружению, поддерживаемости, надежности и прочим характеристикам продукта). Прямые требования всегда приоритетнее косвенных.
Передача информации о соответствии продукта требованиям.
Формально: передача внешней тестовой документации заинтересованным в ней сторонам, зачастую инициатору сессии тестирования. В общем случае: помимо документации предоставляется информация о рисках, которые были выявлены в продукте, требованиях, процессах, передаются рекомендации по отработке этих рисков и т. п.
В чем цель тестирования?
Цель тестирования - предоставление актуальной информации о соответствии производимого продукта требованиям. «Как там мой продукт?», - спрашивает заказчик. «35% процентов требований реализовано полностью, еще 5% - с замечаниями и еще 2% - сейчас в реализации», - отвечает ПМ/тестировщик.
Эмулятор и симулятор
Эмуляция — это воспроизведение работы программы или системы (а не какой-то её мизерной части) с сохранением ключевых её свойств и принципов работы. Эмуляция выполняет программный код в привычной для этого кода среде, состоящей из тех же компонентов, что и эмулируемый объект. Симуляция — это воспроизведение работы программы-оригинала сугубо виртуально, на движке специальной программы (средство разработки курсов, к примеру). Симуляция лишь имитирует выполнение кода, а не копирует его, всё виртуально на 100%, всё «понарошку». Следовательно: Эмулятор ПО — это полнофункциональный аналог оригинального ПО, либо его версия, в которой может быть предусмотрен ряд ограничений по функционалу, возможностям и поведению ПО. Симулятор ПО — это модель оригинального ПО, в которой реализуется логика работы этого ПО (частично или полностью), имитируется поведение ПО, копируется его интерфейс.Симулятор по полноте функций/учитываемых параметров уже, чем эмулятор. Эмулируется объект, а симулируются его свойства, функции или поведение.
мероприятия процесса верификации.
анализ различных аспектов тестирования (сроки, ресурсы, персонал, стоимость, инструменты тестирования и т.д.); покрытие операторов (statement coverage) — процентное отношение операторов, исполняемых набором тестов, к их общему количеству; покрытие условий (condition coverage) — процент исходов условий, которые были проверены набором тестов. 100% покрытие условий требует, чтобы каждое отдельное условие в каждом выражении решения было проверено как Истина и Ложь; покрытие альтернатив (decision coverage) — процент результатов альтернативы, который был проверен набором тестов. Стопроцентное покрытие решений подразумевает стопроцентное покрытие ветвей и стопроцентное покрытие операторов; рецензирование (review) — это оценка состояния продукта или проекта с целью установления расхождений с запланированными результатами и для выдвижения предложений по улучшению. Примерами рецензирования могут служить: управленческое рецензирование, неформальное рецензирование, технический анализ, инспекция и разбор; разбор (walkthrough) — это пошаговый разбор, проводимый автором документа для сбора информации и обеспечения одинакового понимания содержания документа; инспекция (inspection) — это тип равноправного анализа, основанный на визуальной проверке документов для поиска ошибок. Например, нарушение стандартов разработки и несоответствие документации более высокого уровня. Наиболее формальная методика рецензирования и поэтому всегда основывается на документированной процедуре.
Критичность
важность воздействия конкретного дефекта на разработку или функционирование компонента или системы. Критичность ошибки определяется тестировщиком, который обнаружил баг, но перед этим он должен ответить себе на такие вопросы: Как эта ошибка будет влиять на процесс тестирования? Как эта ошибка будет влиять на клиента? Как эта ошибка влияет на систему? Как эта ошибка влияет на сроки тестирования? Блокирует ли эта ошибка другие тесты? И т.д. Каждая компания может определить свою собственную шкалу для степени критичности (серьезности), но есть несколько уровней, которые используются почти всеми командами: Blocker/show-stopper (блокирование) — ПО или конкретный компонент не подходит для использования/тестирования (полный отказ, краш системы и т.д.) и нет обхода.Примеры: система рухнет, когда пользователь нажимает кнопку «Пуск»; система не запускается после повреждения инсталлятора; отключение ПО, вызванное аппаратными сбоями. Critical (критический) — главная функциональность не работает как надо, есть обходной путь, который может повлиять на целостность испытаний.Пример: ПО может рандомно крашиться, используя различные функциональные возможности; ПО вырабатывает противоречивые результаты, основные требования не удается подтвердить. Major (важный) — поражение незначительных функциональностей, нет влияния на другие компоненты, и есть быстрый и действующий обход.Пример: Пользователь не может использовать определенную функциональность напрямую, но может использовать ее же, воспользовавшись доступом к ней из разных модулей. Minor (второстепенный, незначительный) — незначительное воздействие на определенном месте, нет необходимости создавать обходной путь, целостность ПО не затронута.Примеры: ошибки орфографии, улучшения, запрос на изменение
Приведите несколько инструментов, которые могут использоваться для автоматизации тестирования.
внутренние инструменты автоматизации; серия программных продуктов Selenium; MS VS; JUnit; Test Complete; LoadRunner; Testing Аnywhere; WinRunner.
Приведите несколько примеров, которые объясняют критерии входа для тестирования ПО.
все дефекты, которые относятся к ранним стадиям (проектирования) закрыты и проверены; код проверенный с помощью осуществления «Unit» тестов; основные функциональные возможности ПО готовы для тестирования; имеется документация, которая определяет требования; все тестировщики ознакомлены с архитектурой ПО; все тестировщики ознакомлены с целями проекта; готова среда тестирования; доступные для использования билды; утверждены план тестирования и/или тестовые случаи.
Приведите несколько примеров, которые объясняют критерии выхода для тестирования ПО.
все заранее предопределенные области ПО как «рисковые» протестированы и такой статус понижен/удален; все ошибки тщательно задокументированы и доведены менеджменту/акционерам/заказчикам; все тесты с высоким приоритетом пройдены и соответственно помечены как «Pass»; все требования документации SRS (Спецификация требований ПО); STR утверждено собственником проекта; протестирована архитектура ПО; ни одна серьезная или критическая ошибки не остаются открытыми; 90-95% всех тестов сделано.
анализ результатов
вынесение решения о соответствии проверенного продукта требованиям. Формализация данного решения и его обоснование в виде отчета о тестировании. Сюда также входят процедуры по оценке покрытия требований проверками, тайм-шитинг и пр. Таким образом, проводится анализ не только результатов, но и самой сессии тестирования.
генерация тестовых случаев
выявление всех возможных случаев использования продукта, его характеристик и особенностей в процессе эксплуатации. Это значит: всех случаев, которые тестировщик может «придумать» на основе прямых и косвенных требований, известных ему. Этот этап требует высокой квалификации специалиста по тестированию.
Из каких этапов состоит процесс тестирования
инициация, выявление требований прямых и косвенных, генерация тестовых случаев, отбор показательных тестовых случаев, проведение проверок, фиксация результатов, анализ результатов, передача информации о соответствии проверенного продукта требованиям.
SDLC жизненный цикл разработки программного обеспечения
концепция, которая описывает комплекс мероприятий, выполняемых на каждом этапе (фазе) разработки программного обеспечения.
Программный компонент
мелкие айтемы ПО, которые построены из еще мелких единиц, которые в свою очередь интегрированы вместе (классы, методы, хранимые процедуры, бинарные деревья и т.д.).
Покрытие кода (code coverage)
метод анализа, определяющий, какие части ПО были проверены (покрыты) набором тестов, а какие нет, например, покрытие операторов, покрытие альтернатив или покрытие условий.
Конверсионное тестирование (сonversion testing)
методика тестирования, что используется для проверки того, как имеющие в системе А данные будут преобразовываться и становиться доступными для использования в системе Б.
Критерии входа (entry criteria)
набор общих и специфичных условий для продолжения процесса с определенной задачей, например, фаза тестирования. Цель критериев входа — предотвращение начала задачи, которое может потребовать больше (бесполезных) усилий, чем на устранение не пройденных критериев входа.Проще говоря для Вас, как будущего тестировщика, критерии входа следует понимать как основные условия, которые должны быть выполнены до того, как Вы и Ваша команда могут начать тестирование.
Критерии выхода (exit criteria)
набор общих и специфичных условий, согласованных заранее с заинтересованными сторонами, для того, чтобы процесс мог официально считаться завершенным. Цель критериев выхода — предотвращение возможности, когда задание считается завершенным, однако еще существуют отдельные незавершенные части задания. Критерии выхода используются для отчетности, а также планирования того, когда остановить тестирование.Проще говоря, как критерии входа определяют начало тестирования, так и критерии выхода определяют его окончание и ПО готово к следующему этапу жизненного цикла (внедрение и т.д.).
Преимущества SDLC
обеспечение основы проекта (методологии, активность...); обеспечение визуализации хода реализации проекта; помощь компании в эффективности и успешного завершения проекта (сокращение затрат, уменьшение сроков разработки и тестирования, повышение качества конечного продукта); уменьшение рисков, связанных с процессом разработки ПО; обеспечение специальным механизмом отслеживания прогресса проекта.
отбор тестовых случаев
отбор наиболее показательных, значимых и воспроизводимых тестовых случаев. От этого этапа зависит, насколько тестирование будет полезным, эффективным и анализируемым. Например, в «простом» примере с красной кнопкой понятно, что количество косвенных требований стремится к бесконечности, и проверять их все подряд - полный абсурд, но подобные кейсы должны быть сгенерированы хотя бы в голове проверяющего. А для того чтобы они не вошли в проверки, необходимо выполнить соответствующий отбор и проверить только, действительно ли кнопка красная.Пример примитивный, но после его озвучивания соискатели перестают первым делом пытаться налить в стакан радий на тестовом задании J (кто принимал участие в собеседовании на должность тестировщика, тот знает это нехитрое задание на генерацию и отбор тестовых случаев).
SLC жизненный цикл программного обеспечения
период времени, начинающийся с момента появления концепции ПО и заканчивающийся тогда, когда использование ПО более невозможно. Жизненный цикл программного обеспечения обычно включает в себя следующие этапы: концепт, описание требований, дизайн, реализация, тестирование, инсталляция и наладка, эксплуатация и поддержка и, иногда, этап вывода из эксплуатации. Данные фазы могут накладываться друг на друга или проводиться итерационно.
Сборка
подготовленный для использования информационный продукт. Чаще всего это исполняемый файл (двоичный файл, содержащий исполняемый код программы).Предположим, что номер версии сборки выглядит так: 1.35.6.2 Первый идентификатор — основной номер версии. Второй идентификатор — дополнительный номер версии. Третий идентификатор — номер сборки. Четвёртый идентификатор — номер редакции.
Почему я пошла в тестирование?
потому что без тестирования невозможно выявить соответствует ли ожиданиям потребителя продукт
Задачей тестирования стабильности (stability) / надежности (reliability)
проверка работоспособности приложения при длительном (многочасовом) тестировании со средним уровнем нагрузки. Время выполнения операций может играть в данном виде тестирования второстепенную роль. При этом на первое место выходит отсутствие утечек памяти, перезапусков серверов под нагрузкой и другие аспекты влияющие именно на стабильность работы.
Отладка
процесс поиска, анализа, и устранения причин отказов и ошибок в ПО. Чтобы понять, где возникла ошибка, приходится: узнавать текущие значения переменных; выяснять, по какому пути выполнялась программа. Существуют две взаимодополняющие технологии отладки. Использование отладчиков — программ, которые включают в себя пользовательский интерфейс для пошагового выполнения программы: оператор за оператором, функция за функцией, с остановками на некоторых строках исходного кода или при достижении определённого условия. Вывод текущего состояния программы с помощью расположенных в критических точках программы операторов вывода — на экран, принтер, громкоговоритель или в файл. Вывод отладочных сведений в файл называется журналированием.
Инспекция кода (code inspection) или просмотр кода (code review)
систематическая проверка исходного кода программы с целью обнаружения и исправления ошибок, которые остались незамеченными в начальной фазе разработки. Целью просмотра является улучшение качества программного продукта и совершенствование навыков разработчика.В процессе инспекции могут быть найдены и устранены такие проблемы, как ошибки в форматировании строк, состояние гонки (race condition), утечка памяти (memory leak) и переполнение буфера (buffer overflow), что улучшает безопасность программного продукта. Системы контроля версий дают возможность проведения совместной инспекции кода. Кроме того, существуют специальные инструментальные средства для совместной инспекции кода.Программное обеспечение для автоматизированной инспекции кода упрощает задачу просмотра больших кусков кода, систематически сканируя его на предмет обнаружения наиболее известных уязвимостей.
Инициация
событие, которое извещает команду тестирования о необходимости сессии тестирования, а также гарантирует выполнение требований к продукту для проведения тестирования.Для производства ПО требования включают: доступно необходимое тестовое окружение, доступен билд/ресурс/предмет тестирования, код, БД, прочие компоненты объекта тестирования «заморожены», т. е. не изменяются в период всей сессии тестирования, модификация требований (хотя бы прямых) «заморожена», известно направление тестирования, известны сроки на сессию тестирования.
Контроль качества (QC)
совокупность мероприятий, охватывающих все технологические этапы разработки, выпуска и эксплуатации ПО и предпринимаемых на разных стадиях жизненного цикла ПО, для обеспечения требуемого уровня качества выпускаемого продукта.Обеспечение качества определено в стандарте ISO 9000:2005 «Системы менеджмента качества. Основные положения и словарь» как «часть менеджмента качества, направленная на создание уверенности в том, что требования к качеству будут выполнены».Менеджмент качества в этом же стандарте представлен как «скоординированная деятельность по руководству и управлению организацией применительно к качеству», а в примечании сказано, что он «обычно включает разработку политики и целей в области качества, планирование качества, управление качеством, обеспечение качества и улучшение качества».
Обеспечение качества (QA)
совокупность мероприятий, охватывающих все технологические этапы разработки, выпуска и эксплуатации ПО и предпринимаемых на разных стадиях жизненного цикла ПО, для обеспечения требуемого уровня качества выпускаемого продукта.Обеспечение качества определено в стандарте ISO 9000:2005 «Системы менеджмента качества. Основные положения и словарь» как «часть менеджмента качества, направленная на создание уверенности в том, что требования к качеству будут выполнены».Менеджмент качества в этом же стандарте представлен как «скоординированная деятельность по руководству и управлению организацией применительно к качеству», а в примечании сказано, что он «обычно включает разработку политики и целей в области качества, планирование качества, управление качеством, обеспечение качества и улучшение качества».
Требование
совокупность утверждений относительно атрибутов, свойств или качеств программной системы, подлежащей реализации. Создаются в процессе разработки требований к программному обеспечению, в результате анализа требований.Требования могут выражаться в виде текстовых утверждений и графических моделей.
Фиксация результатов
создание внутренней и внешней тестовой документации в формализованном виде или в виде записей и т. п. На данном этапе отчет о тестирование даже если и создается, то не считается законченным.
Приоритет
степень важности, присваиваемая багу. Другими словами определяется, насколько срочно это ошибка должна быть исправлена.Приоритет — инструмент менеджмента, и перед его определением последний должен ответить минимум на следующие вопросы: Как баг влияет на сроки? Как баг влияет на процесс тестирования? Как баг влияет на работу остальных тестировщиков? Каковы затраты необходимы на устранение бага? Должны ли мы изменить требования к ПО?
Тестирование чёрного ящика или поведенческое тестирование
стратегия (метод) тестирования функционального поведения ПО с точки зрения внешнего мира, при котором не используется знание о внутреннем устройстве тестируемого объекта. Под стратегией понимаются систематические методы отбора и создания тестов для тестового набора. Стратегия поведенческого теста исходит из технических требований и их спецификацийНекоторые приёмы тестирования чёрного ящика: эквивалентное разбиение; анализ граничных значений; анализ причинно-следственных связей; предположение об ошибке;
процесс валидации.
строим ли мы правильный продукт? Процесс, позволяющий тестировщику оценить ПО после стадии разработки до передачи его заказчику. В этом процессе мы должны убедиться, что ПО разработано на основе потребностей пользователей.Помните, валидация охватывает динамическую сторону тестирования, где определенное ПО тестируется и оценивается вопреки заданной SRS документации.
процесс верификации.
строим ли мы продукт правильно? Процесс верификации (verification) выполняется, чтобы убедиться, что каждый этап жизненного цикла разработки ПО (разработка, тестирование и т.д.) строится на основе предопределенных требований (requirements) и спецификаций (specifications) и без каких-либо отклонений от них.
Спецификация ПО
текстовый файл с описанием того, что нужно протестировать в тестовых данных. В ней указывается какие результаты должна получить программа. Тестовый код находит реальные, вычисленные на живом коде результаты. А тестовый движок производит сверку спецификации и вычисленных результатов.Спецификацию получаем от заказчика проанализировав, исследовав его требования и переведя их на качественно новый, более детализированный уровень, на котором ими и будет пользоваться команда разработчика.
Белый ящик
тестирование кода на предмет логики работы программы и корректности её работы с точки зрения компилятора того языка, на котором она писалась.Техника тестирования по принципу Белого ящика, также называемая техникой тестирования, управляемой логикой программы, позволяет проверить внутреннюю структуру программы. Исходя из этой стратегии тестировщик получает тестовые данные путем анализа логики работы программы.Техника Белого ящика включает в себя следующие методы тестирования: покрытие решений; покрытие условий; покрытие решений и условий; комбинаторное покрытие условий;
Конформационное тестирование
тестирование с целью убедиться, что ПО отвечает определенным отраслевым стандартам (IEEE, W3C и т.д.) для разработки ПО.
End-to-end тестирование
тип тестирования где тестировщик использует ПО (сценарии, которые исследуют весь поток выполнения) в условиях которыми вероятней всего обладает пользователь.В дополнение, тесты будут работать сочетая в себе несколько сценариев уместных в реальном мире: запуск ПО в среде с задержками связи сети; запуск ПО в среде с низкими ресурсами; Запуск ПО на другом серверном оборудовании; Запустите ПО в той же среде, что имеет некоторые другие приложения, которые потребляют ресурсы сервера
Когда следует заканчивать тестирование ПО?
управленческое решение, которое вероятней всего будет принято на основе: тестового покрытия; анализа рисков; ухудшения тестирования.
несколько причин, которые приводят к багам в ПО.
человеческие ошибки (процесс проектирования и процесс реализации); изменение требований в то время как ПО под испытанием; непонимание требований и спецификаций; отсутствие времени; плохая приоритизация тестирования; плохая ориентация в версиях ПО; сложность самого ПО.