2023-08-09 03:01:52 -06:00
|
|
|
import { expect } from 'chai';
|
|
|
|
|
|
|
|
export async function expectDeprecationMessages (func: () => any, ...expected: string[]) {
|
|
|
|
const messages: string[] = [];
|
|
|
|
|
|
|
|
const originalWarn = console.warn;
|
|
|
|
console.warn = (message) => {
|
|
|
|
messages.push(message);
|
|
|
|
};
|
|
|
|
|
|
|
|
const warningListener = (error: Error) => {
|
|
|
|
messages.push(error.message);
|
|
|
|
};
|
|
|
|
|
|
|
|
process.on('warning', warningListener);
|
|
|
|
|
|
|
|
try {
|
|
|
|
return await func();
|
|
|
|
} finally {
|
|
|
|
// process.emitWarning seems to need us to wait a tick
|
|
|
|
await new Promise(process.nextTick);
|
|
|
|
console.warn = originalWarn;
|
2023-10-10 09:50:47 -06:00
|
|
|
process.off('warning' as any, warningListener);
|
2023-08-09 03:01:52 -06:00
|
|
|
expect(messages).to.deep.equal(expected);
|
|
|
|
}
|
|
|
|
}
|