Граничный анализ - Boundary-value analysis

Анализ граничных значений это тестирование программного обеспечения метод, при котором тесты предназначены для включения представителей граничных значений в диапазон. Идея исходит из граница. Учитывая, что у нас есть набор тестовые векторы для тестирования системы на этом наборе может быть определена топология. Те входы, которые принадлежат одному класс эквивалентности как определено разделение по эквивалентности теория составила бы основа. Учитывая, что базисные наборы соседи, между ними существовала бы граница. Тестовые векторы по обе стороны от границы называются граничными значениями. На практике для этого потребуется, чтобы тестовые векторы можно было упорядочить, и чтобы отдельные параметры следовали некоторому порядку (либо частичный заказ или же общий заказ ).

Формальное определение

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

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

Заявление

Ожидаемые входные и выходные значения для программного компонента должны быть извлечены из спецификации компонента. Затем значения группируются в наборы с идентифицируемыми границами. Каждый набор или секция содержит значения, которые, как ожидается, будут обрабатываться компонентом одинаково. Разделение диапазонов тестовых данных объясняется в разделение по эквивалентности Методика разработки тестовых случаев. При разработке тестовых примеров важно учитывать как допустимые, так и недопустимые разделы.

Демонстрация может быть выполнена с помощью функции, написанной на Ява.

учебный класс Безопасный {    статический int Добавить(int а, int б)    {        int c = а + б ;        если (а >= 0 && б >= 0 && c < 0)        {            Система.ошибаться.println("Переполнение!");        }        если (а < 0 && б < 0 && c >= 0)        {            Система.ошибаться.println("Переполнение!");        }        возвращаться c;    }}

На основе кода входные векторы [а, б] разделены. Блоки, которые нам нужно охватить, - это оператор переполнения и оператор потери значимости, и ни один из этих 2. Из самого обзора кода это дает 3 эквивалентных класса.

Демонстрация граничных значений (оранжевый)

отметим, что существует фиксированный размер целое число следовательно:-

MIN_VALUE ≤ Икс + у ≤ MAX_VALUE

Отметим, что входной параметр а и б оба целые числа, поэтому общий заказ существует на них. Когда мы вычисляем равенства: -

Икс + у = MAX_VALUE
MIN_VALUE = Икс + у

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

С другой стороны:-

Икс + у = MAX_VALUE + 1

дает пары (а, б) которые являются недопустимыми комбинациями, для них произойдет переполнение. Таким же образом: -

Икс + у = MIN_VALUE - 1

дает пары (а, б) которые являются недопустимыми комбинациями, для них произойдет потеря значимости.

Граничные значения (нанесенные только для случая переполнения) показаны оранжевой линией на рисунке справа.

В другом примере, если входными значениями были месяцы года, выраженные целыми числами, входной параметр «месяц» мог бы иметь следующие разделы:

       ... -2 -1 0 1 .............. 12 13 14 15 ..... -------------- | --- ---------------- | ------------------- недопустимый раздел 1 допустимый раздел недопустимый раздел 2

Граница между двумя разделами - это место, где изменяется поведение приложения, а не реальное число. Граничное значение - это минимальное (или максимальное) значение, которое находится на границе. Число 0 - максимальное число в первом разделе, число 1 - минимальное значение во втором разделе, оба являются граничными значениями. Должны быть созданы тестовые примеры для генерации входов или выходов, которые будут попадать по обе стороны от каждой границы, что приводит к двум случаям на границу. Тестовые примеры на каждой стороне границы должны иметь наименьшее возможное приращение для тестируемого компонента, для целого числа это 1, но если бы вход был десятичным с двумя знаками, то это было бы 0,01. В приведенном выше примере есть граничные значения 0,1 и 12,13, и каждое из них следует проверить.

Анализ граничных значений не требует недопустимых разделов. Возьмем пример, когда обогреватель включается при температуре 10 градусов и ниже. Есть два раздела (температура ≤10, температура> 10) и два граничных значения для тестирования (температура = 10, температура = 11).

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

Рекомендации