Тестировщики по всему миру за свою карьеру участвовали во многих типах тестов производительности. В первую очередь это делается по двум причинам: убедиться, что система не выйдет из строя внезапно, и, во-вторых, чтобы система работала должным образом в нормальных условиях.
Однако вам также необходимо учитывать, какой тест производительности необходим в какой ситуации, и знать разницу между одним типом теста и другим, например, нагрузочным тестом по сравнению со стресс-тестом. Это поможет вам решить, какой тип тестирования соответствует требованиям работы, которую вы выполняете в данный момент. Ниже мы поможем вам сфокусировать ваши вопросы и дадим вам некоторые ответы.
Тестирование производительности
Тестирование производительности — это нефункциональный тип тестирования, используемый для изучения поведения системы при нормальной рабочей нагрузке.
Различные факторы, такие как скорость (время отклика), надежность (вероятность сбоев/ошибок), использование ресурсов (ЦП/сеть), пропускная способность (данные, передаваемые в байтах в секунду) и т. д., будут контролироваться во время теста производительности на основе ожидаемое нормальное поведение пользователя. Другими словами, вы выясняете, ведет ли себя система ненормально, когда один пользователь обращается к системе в течение определенного периода времени.
Чтобы знать, как работает ваш веб-сайт, а также базы данных, сети, серверы и многое другое, перед выпуском каждой новой версии необходимо проводить периодическую проверку производительности. Тест проводится, чтобы убедиться, что растущее число пользователей не влияет на время отклика, низкий уровень ошибок и постоянное число попаданий в секунду при доступе к системе определенного числа пользователей. В этом тесте никогда не предполагается нагружать серверы тяжелыми пользовательскими запросами. Вы ожидаете только нормальную нагрузку, поэтому тест будет проходить в «контролируемой» среде.
Нагрузочное тестирование
Нагрузочное тестирование — это вариант тестирования производительности, при котором поведение системы отслеживается, когда к системе обращается большое количество пользователей в течение определенного периода времени. Как вы определяете количество пользователей? В основном это зависит от бизнес-ценностей и требований системы. Например, розничный веб-сайт, такой как Amazon, может рассчитывать на сотни тысяч пользователей в любой момент времени, но будет множество других розничных сайтов, которые не ожидают таких больших нагрузок.
Процесс тестирования и отслеживаемые матрицы будут аналогичны тестированию производительности, но здесь эти матрицы будут отслеживаться для разных наборов пользовательских нагрузок и разных итераций. Например, 1000 пользователей за 5 минут, 2000 пользователей за 5 минут, 5000 пользователей за 10 минут и т. д. Это также будет зависеть от бизнес-ценностей системы, но конечной целью является определение скорости (времени отклика) для разных пользователей. нагрузки. Наиболее распространенными инструментами нагрузочного тестирования с открытым исходным кодом являются Jmeter и Gatling.
Нагрузочное тестирование
Стресс-тестирование — это еще один вариант тестирования производительности, целью которого является обнаружение критической точки, в которой система рушится. Другими словами, при какой пользовательской нагрузке моя система рухнет. Стресс-тестирование жизненно важно для любой системы, где трудно предсказать нагрузку на ваши серверы. Его также можно назвать тестированием на выносливость, поскольку оно отслеживает такие параметры, как безопасность, утечки памяти, скорость, точность данных и т. д.
Процесс стресс-тестирования выполняется с помощью инструментов нагрузочного тестирования, которые могут определить тестовый сценарий с большим количеством одновременных виртуальных пользователей. Если стресс-тест предназначен для представления системы с внезапным увеличением количества виртуальных пользователей, он будет известен как пиковый тест. Если стресс-тест проводится в течение длительного периода времени с целью проверки устойчивости системы с медленным наращиванием, этот процесс будет называться тестом на выдержку.
Стресс-тесты для веб-сайтов и приложений необходимы перед запуском любого крупного мероприятия. Одним из распространенных примеров может служить праздничная кампания по распродажам, проводимая некоторыми интернет-магазинами, когда они ожидают, что огромное количество покупателей придет и сделает покупки. Другим примером будет открытие продажи билетов на крупные мероприятия, которые будут с нетерпением ожидать миллионы болельщиков. Тем не менее, рекомендуется время от времени проводить стресс-тесты, чтобы знать, сколько может выдержать система. Это поможет вам справиться с внезапными всплесками трафика и даст вам больше времени и ресурсов для устранения любых узких мест.
С помощью этих различных типов тестов производительности вы узнаете обо всех проблемах, с которыми можете столкнуться. Знание того, что они собой представляют, поможет вам спланировать и справиться с ними заранее.
#тестирование #qa #тестировщик #ит