Хранилище данных - тестирование
Тестирование очень важно для систем хранилищ данных, чтобы они работали правильно и эффективно. Существует три основных уровня тестирования хранилища данных:
- Модульное тестирование
- Интеграционное тестирование
- Системное тестирование
Модульное тестирование
При модульном тестировании каждый компонент тестируется отдельно.
Тестируется каждый модуль, т.е. процедура, программа, SQL-скрипт, оболочка Unix.
Этот тест проводит разработчик.
Интеграционное тестирование
В интеграционном тестировании различные модули приложения объединяются, а затем проверяются на количество входов.
Он выполняется для проверки работоспособности различных компонентов после интеграции.
Системное тестирование
При тестировании системы все приложение хранилища данных тестируется вместе.
Цель тестирования системы - проверить, правильно ли работает вся система вместе или нет.
Системное тестирование проводится командой тестирования.
Поскольку размер всего хранилища данных очень велик, обычно можно выполнить минимальное тестирование системы перед тем, как можно будет принять план тестирования.
График испытаний
Прежде всего, график тестирования создается в процессе разработки плана тестирования. В этом расписании мы прогнозируем примерное время, необходимое для тестирования всей системы хранилища данных.
Существуют разные методики создания расписания тестирования, но ни одна из них не является идеальной, поскольку хранилище данных очень сложное и большое. Система хранилища данных также развивается по своей природе. При создании расписания тестирования можно столкнуться со следующими проблемами:
Простая проблема может заключаться в большом размере запроса, выполнение которого может занять день или больше, т. Е. Запрос не завершается в желаемом масштабе времени.
Возможны сбои оборудования, такие как потеря диска или человеческие ошибки, такие как случайное удаление таблицы или перезапись большой таблицы.
Note - Из-за вышеупомянутых трудностей рекомендуется всегда удваивать количество времени, которое вы обычно отводите на тестирование.
Тестирование восстановления из резервной копии
Чрезвычайно важно протестировать стратегию восстановления из резервной копии. Вот список сценариев, для которых необходимо это тестирование -
- Сбой СМИ
- Потеря или повреждение табличного пространства или файла данных
- Потеря или повреждение файла журнала повторного выполнения
- Утрата или повреждение контрольного файла
- Сбой экземпляра
- Утрата или повреждение архивного файла
- Утеря или повреждение стола
- Сбой во время сбоя данных
Тестирование операционной среды
Есть ряд аспектов, которые необходимо проверить. Эти аспекты перечислены ниже.
Security- Для тестирования безопасности требуется отдельный документ по безопасности. Этот документ содержит список запрещенных операций и тесты для каждой из них.
Scheduler- Программное обеспечение для планирования требуется для управления ежедневными операциями хранилища данных. Это необходимо проверить во время тестирования системы. Программное обеспечение для планирования требует интерфейса с хранилищем данных, которому потребуется планировщик для контроля ночной обработки и управления агрегированием.
Disk Configuration.- Конфигурация диска также должна быть протестирована для выявления узких мест ввода-вывода. Тест следует проводить несколько раз с разными настройками.
Management Tools.- Требуется протестировать все инструменты управления во время тестирования системы. Вот список инструментов, которые нужно протестировать.
- Менеджер по корпоративным мероприятиям
- Системный менеджер
- Менеджер базы данных
- Менеджер конфигурации
- Менеджер резервного копирования и восстановления
Тестирование базы данных
База данных тестируется следующими тремя способами:
Testing the database manager and monitoring tools - Чтобы протестировать менеджер базы данных и инструменты мониторинга, их следует использовать при создании, запуске и управлении тестовой базой данных.
Testing database features - Вот список функций, которые мы должны протестировать -
Запросы параллельно
Создать индекс параллельно
Загрузка данных параллельно
Testing database performance- Выполнение запроса играет очень важную роль в оценке производительности хранилища данных. Есть наборы фиксированных запросов, которые необходимо запускать регулярно и тестировать. Чтобы протестировать специальные запросы, нужно просмотреть документ требований пользователя и полностью понять бизнес. Найдите время, чтобы протестировать самые неудобные запросы, которые, вероятно, может задать компания, с учетом различных стратегий индексации и агрегирования.
Тестирование приложения
Все менеджеры должны быть правильно интегрированы и работать, чтобы гарантировать, что сквозная нагрузка, индекс, агрегирование и запросы работают в соответствии с ожиданиями.
Каждая функция каждого менеджера должна работать корректно
Также необходимо протестировать приложение в течение определенного периода времени.
Также следует тестировать задачи на конец недели и на конец месяца.
Логистика теста
Целью системного тестирования является проверка всех следующих областей:
- Программное обеспечение для планирования
- Ежедневные операционные процедуры
- Стратегия восстановления резервной копии
- Инструменты управления и планирования
- Ночная обработка
- Производительность запроса
Note- Самый главный момент - проверить масштабируемость. В противном случае у нас останется проект системы, который не будет работать, когда система будет расти.