Тема 5.3. Функціональне тестування
Одним із способів перевірки програм є тестування з управлінням за даними або по принципу «чорного ящика». В цьому випадку програма розглядається як «чорний ящик», і метою тестування є з'ясування обставин, в яких поведінка програми не відповідає специфікації.
Для виявлення всіх помилок в програмі, використовуючи управління за даними, необхідно виконати вичерпне тестування, тобто тестування на всіх можливих наборах даних. Для тих же програм, де виконання команди залежить від попередніх нею подій, необхідно перевірити і всі можливі послідовності. Очевидно, що проведення вичерпного тестування для переважної більшості випадків неможливо. Тому зазвичай виконують «розумне» або «прийнятне» тестування, яке обмежується прогонами програми на невеликій підмножині всіх можливих вхідних даних. Цей варіант не дає гарантії відсутність відхилень від специфікацій.
Правильно вибраний тест повинен зменшувати, причому більш ніж на одиницю, число інших тестів, які мають бути розроблені для забезпечення необхідної якості програмного забезпечення.
При функціональному тестуванні розрізняють наступні методи формування тестових наборів даних:
• еквівалентне розбиття;
• аналіз граничних значень;
• аналіз причинно-наслідкових зв'язків;
• припущення про помилку.
Еквівалентне розбиття.Метод еквівалентного розбиття полягає в наступному.
Область всіх можливих наборів вхідних даних програми по кожному параметру розбивають на кінцеве число груп - класів еквівалентності. Набори даних такого класу об'єднують за принципом виявлення одних і тих же помилок: якщо набір якого-небудь класу виявляє деяку помилку, то передбачається, що всі інші тести цього класу еквівалентності теж виявлять цю помилку і навпаки.
Розробку тестів методом еквівалентного розбиття здійснюють в два етапи: на першому виділяють класи еквівалентності, а на другому - формують тести.
Виділення класів еквівалентності є евристичним процесом, проте за доцільне вважають виділяти в окремі класи еквівалентності набори, що містять допустимі і неприпустимі значення деякого параметра. При цьому існує ряд правил:
• якщо деякий параметр х може набувати значень в інтервалі [1, 999], то виділяють один правильний клас 1 > х < 999 і два неправильних: х < I і х>999;
• якщо вхідну умову визначає діапазон значень порядкового типа, наприклад, «в автомобілі можуть їхати від одного до шести чоловік», то визначається один правильний клас еквівалентності і два неправильних: жодного і більше шести чоловік;
• якщо вхідну умову описує безліч вхідних значень і є підстави вважати, що кожне значення програміст трактує особливо, наприклад, «типи графічних файлів: bmp jpeg, vsd», то визначають правильний клас еквівалентності для кожного значення і один неправильний клас, наприклад, txt;
• якщо вхідна умова описує ситуацію «повинно бути», наприклад, «першим символом ідентифікатора має бути буква», то визначається один правильний клас еквівалентності (перший символ -буква) і один неправильний (перший символ - не буква);
• якщо є підстава вважати, що різні елементи класу еквівалентності трактуючи програмою неоднаково, то даний клас розбивається на менші класи еквівалентності.
Таким чином, класи еквівалентності виділяють, перебираючи обмеження, встановлені для кожного вхідного значення в технічному завданні або при уточненні специфікації.
Кожне обмеження розбивають на дві або більш за групи. При цьому використовують спеціальні бланки - таблиці класів еквівалентності:
Таблиця 1