Пишу тесты в тестах запускаю через child_process консольную команду которая запускает простенький рест сервис. Записываю процесс в переменную и по окончании теста делаю килл. Но судя по занятым портам и процессам в дебаггере, процесс все ещё активен
Попробуйте убивать сигналом 15. Но по-хорошему конечно разобраться, почему сервис не желает завершаться сам.
Ну судя по процессам создаётся дочерний npx-cli и в нем уже запускается main.js. Возможно в этом дело?
Это легко проверить. В коде main.js подписаться на SIGKILL и SIGINT и залоггировать. Если под тестами логгируется значит сигнал доходит и проблема в коде сервиса.
Спасибо, попробую)
нашел в чем причина, но как решить не знаю. Дело в том что при запуске дочернего процесс через cmd команду "npx functions-framework" (пытаюсь сделать тест для google cloud funcs) процесс отрабатывает и закрывается, а эта команда создает два дочерних процесса npm-cli и main.js. Если через дебаггер нахожу их pid и делаю kill, все отрабатывает. Могу ли я как-то в ноде получить список всех запущенных процессов? P.S. эти два созданных процесса являются дочерними по отношению к процессу теста (Mocha)
Сложна. Надо раскапывать что там в коде тестов, как управление дочерними процессами происходит. Я правильно понимаю что вам надо именно интеграционное тестирование, т.е. не прокатит просто тестировать cloud functions как это советуют в документации? https://github.com/GoogleCloudPlatform/functions-framework-nodejs/blob/7034c37039f5f05d3081a37791644ee3b7d2829e/docs/testing-functions.md
О, спасибо! Не знаю как я сюда не попал. Вечно тут оказывался https://github.com/GoogleCloudPlatform/functions-framework-nodejs Но в целом добавление флага --exit к команде mocha решило проблему с выходом.
О, это говорит о том что у вас процесс mocha повисает после завершения тестов. Обычно это происходит если тесты не чистят за собой, т.е. где-то остается висеть непогашенный сервер, незакрытый сокет, незакрытый файл, незарезолвленный промис итд. Тут в помощь process._getActiveRequests() и process._getActiveHandles()
Проверю, благодарю вас!
Обсуждают сегодня