Ssylka

Тестирование конкурентности: выявление состояний гонки

Для обнаружения race condition в коде, уязвимого к конкурентному доступу, можно использовать несколько подходов. Простейший — многократный запуск тестов, однако этот метод не гарантирует обнаружение проблемы из-за случайности планировщика. Concurrency fuzzing, вносящий случайные задержки, делает тесты медленнее, хотя и повышает шансы на выявление ошибки. Более радикальный подход — патчинг планировщика событий для выполнения задач в случайном порядке, но это тоже является костылём.
Тестирование конкурентности: выявление состояний гонки
Изображение носит иллюстративный характер

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

Концептуально можно подойти к тестированию конкурентности с точки зрения изменения стейта сервиса. Можно проверить, что конкурентное выполнение двух API-вызовов не приводит к результирующему состоянию, отличному от того, которое получается при их последовательном выполнении в любом порядке. Такой подход, однако, сложен в реализации из-за бесконечного количества возможных состояний.

Перспективный вариант – переиспользование существующих функциональных тестов для проверки инвариантов состояния при конкурентном запуске. При этом подходе уже имеющиеся тесты запускаются повторно с целью выявления race conditions.


Новое на сайте

14783Птицы от рассвета до заката: персональная выставка Джима мойра в Lady Lever Art Gallery 14782Новая жизнь фасада: надежда и история на стенах кинотеатра ABC 14781Поворот в доступности абортов: как законы и технологии меняют картину в США 14780Что стало с лицом Lil Nas X? 14779Взлом аккаунта министра: криптовалютная афера на платформе X 14778Google под прицелом антимонопольной комиссии Японии 14777Хор для тех, кто не умеет петь: как Zest Choir меняет отношение к музыке 14776Поглотила ли покупка Instagram конкуренцию на рынке соцсетей? 14775Как у прилавка с суши возникла уэльская морская трава? 14774Почему муравьи становятся новой целью международных браконьеров? 14773Как пятеро друзей из Dude Perfect стали символом семейного развлечения? 14772Может ли Хельсинки стать новой столицей европейских стартапов? 14771Кто стоял за великой железнодорожной кражей: элита преступного мира? 14770Meta возобновляет обучение искусственного интеллекта на публичных данных европейских...