Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Tehnologiq_progr-niq-lekcii_dopolnennye.doc
Скачиваний:
11
Добавлен:
07.09.2019
Размер:
529.92 Кб
Скачать

Системное тестирование.

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

Проблема системного тестирования – указание причины. Она возникает, когда разработчик одного системного элемента обвиняет разработчика другого элемента в причине возникновения дефекта.

Для защиты от обвинений разработчик программного элемента должен:

  1. Предусмотреть средства обработки ошибок, которые тестируют все вводы информации от других элементов системы.

  2. Провести тесты, моделирующие неудачные данные или другие потенциальные ошибки интерфейса ПС.

  3. Записать результаты тестов, чтобы использовать их как доказательства невиновности в случае указания причины.

  4. Принятие участия в планировании и проектировании системных тестов, чтобы гарантировать адекватное тестирование программной системы.

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

Основные типы системных тестов.

  1. Тестирование восстановления.

    • Компьютерные системы должны восстанавливаться после отказов и возобновлять обработку в пределах заданного времени.

    • В некоторых случаях система должна быть отказоустойчивой.

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

    • При автоматическом восстановлении оценивается правильность повторной инициализации, механизмы копирования контрольных точек, восстановления данных, перезапуск.

    • При ручном восстановлении оценивается, находится ли среднее время восстановления в допустимых пределах.

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

Проверяет фактическую реакцию механизмов, встроенных в систему на проникновение. Испытатель играет роль взломщика, ему разрешено:

  1. попытки узнать пароль с помощью внешних средств;

  2. атака системы с помощью специальных утилит, анализирующих защиту;

  3. подавление, ошеломление системы в надежде, что она откажется обслуживать других клиентов;

  4. целенаправленное введение ошибок, чтобы проникнуть в систему в ходе восстановления;

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

Задача проектировщика системы – сделать цену проникновения более высокой, чем цена получаемой в результате информации.

  1. Стрессовое тестирование.

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

Стрессовое тестирование производится при не нормальных запросах на ресурсы системы.

Пример:

  1. 10 прерываний в секунду, при норме – 1-2;

  2. формируются варианты, требующие максимум памяти и других ресурсов.

Таким образом, испытатель пытается разрушить систему.

Разновидность стрессового тестирования – тестирование чувствительности. Обычно в математических задачах. Малый диапазон данных в правильных границах может вызвать ошибочную обработку или резкое понижение производительности.

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

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

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]