Когда вы throw
в обработчике catch
здесь:
setTimeout(() => {
try {
stdin.write(inputString);
} catch (e) {
throw new Error(
`Unable to send input "${inputString}" to the cli. Please check to make sure your script didn't exit early.`
);
inputs.splice(0, inputs.length);
}
, исключение просто возвращается в инфраструктуру setTimeout()
. Поскольку он вызывает свой обратный вызов по тайм-ауту из события l oop, а не из вашего собственного кода, в данный момент в стеке вызовов нет вашего кода, поэтому вы не можете перехватить это исключение.
Исключения являются сложными распространяться обратно через простые асинхронные обратные вызовы. На самом деле, вы не можете сделать это так, как вы это сделали. Если бы это был мой код, я бы контролировал свой поток асинхронных операций, используя только функции, которые возвращают обещания. Когда у вас есть асинхронная операция, которая использует простой обратный вызов, а не обещание, вы «обещаете» его с помощью небольшой что-то вроде util.promisify()
или специальной маленькой оболочки обещаний, а затем вы можете выбросить в свое сердце контент, и он автоматически распространится вверх на более высокие уровни или обратно к вызывающей стороне в качестве отклоненного обещания.
К вашему сведению, также неясно, почему у вас есть строка кода:
inputs.splice(0, inputs.length);
в этом фрагменте, поскольку он никогда не может быть выполнен как это после throw
.