DEV: Refactor deprecation silencer (#22526)
- Unify the silencing methods, use a WeakMap to remember the seen objects - Export a proper plugin and use the absolute path in the config, instead of the proprietary config from `broccoli-babel-transpiler` The latter causes problems in Embroider which doesn't use the broccoli based babel pipeline.
This commit is contained in:
parent
bdb9ee8507
commit
cfa2f1fea8
|
@ -17,9 +17,8 @@ module.exports = function (defaults) {
|
||||||
const vendorJs = discourseRoot + "/vendor/assets/javascripts/";
|
const vendorJs = discourseRoot + "/vendor/assets/javascripts/";
|
||||||
|
|
||||||
// Silence deprecations which we are aware of - see `lib/deprecation-silencer.js`
|
// Silence deprecations which we are aware of - see `lib/deprecation-silencer.js`
|
||||||
const ui = defaults.project.ui;
|
DeprecationSilencer.silence(console, "warn");
|
||||||
DeprecationSilencer.silenceUiWarn(ui);
|
DeprecationSilencer.silence(defaults.project.ui, "writeWarnLine");
|
||||||
DeprecationSilencer.silenceConsoleWarn();
|
|
||||||
|
|
||||||
const isProduction = EmberApp.env().includes("production");
|
const isProduction = EmberApp.env().includes("production");
|
||||||
const isTest = EmberApp.env().includes("test");
|
const isTest = EmberApp.env().includes("test");
|
||||||
|
@ -95,7 +94,7 @@ module.exports = function (defaults) {
|
||||||
},
|
},
|
||||||
|
|
||||||
babel: {
|
babel: {
|
||||||
plugins: [DeprecationSilencer.generateBabelPlugin()],
|
plugins: [require.resolve("./lib/deprecation-silencer")],
|
||||||
},
|
},
|
||||||
|
|
||||||
// We need to build tests in prod for theme tests
|
// We need to build tests in prod for theme tests
|
||||||
|
|
|
@ -5,52 +5,57 @@ const SILENCED_WARN_PREFIXES = [
|
||||||
"DEPRECATION: Invoking the `<LinkTo>` component with positional arguments is deprecated",
|
"DEPRECATION: Invoking the `<LinkTo>` component with positional arguments is deprecated",
|
||||||
];
|
];
|
||||||
|
|
||||||
let consoleWarnSilenced = false;
|
class DeprecationSilencer {
|
||||||
|
constructor() {
|
||||||
module.exports = class DeprecationSilencer {
|
this.silenced = new WeakMap();
|
||||||
static silenceUiWarn(ui) {
|
|
||||||
const oldWriteWarning = ui.writeWarnLine.bind(ui);
|
|
||||||
ui.writeWarnLine = (message, ...args) => {
|
|
||||||
if (
|
|
||||||
!SILENCED_WARN_PREFIXES.some((prefix) => message.startsWith(prefix))
|
|
||||||
) {
|
|
||||||
return oldWriteWarning(message, ...args);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static silenceConsoleWarn() {
|
silence(object, method) {
|
||||||
if (consoleWarnSilenced) {
|
if (this.alreadySilenced(object, method)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/* eslint-disable no-console */
|
|
||||||
const oldConsoleWarn = console.warn.bind(console);
|
let original = object[method];
|
||||||
console.warn = (message, ...args) => {
|
|
||||||
if (
|
object[method] = (message, ...args) => {
|
||||||
!SILENCED_WARN_PREFIXES.some((prefix) => message.startsWith(prefix))
|
if (!this.shouldSilence(message)) {
|
||||||
) {
|
return original.call(object, message, ...args);
|
||||||
return oldConsoleWarn(message, ...args);
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
/* eslint-enable no-console */
|
|
||||||
consoleWarnSilenced = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
alreadySilenced(object, method) {
|
||||||
* Generates a dummy babel plugin which applies the console.warn silences in worker
|
let set = this.silenced.get(object);
|
||||||
|
|
||||||
|
if (!set) {
|
||||||
|
set = new Set();
|
||||||
|
this.silenced.set(object, set);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (set.has(method)) {
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
set.add(method);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
shouldSilence(message) {
|
||||||
|
return SILENCED_WARN_PREFIXES.some((prefix) => message.startsWith(prefix));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const DEPRECATION_SILENCER = new DeprecationSilencer();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Export a dummy babel plugin which applies the console.warn silences in worker
|
||||||
* processes. Does not actually affect babel output.
|
* processes. Does not actually affect babel output.
|
||||||
*/
|
*/
|
||||||
static generateBabelPlugin() {
|
module.exports = function () {
|
||||||
return {
|
DEPRECATION_SILENCER.silence(console, "warn");
|
||||||
_parallelBabel: {
|
|
||||||
requireFile: require.resolve("./deprecation-silencer"),
|
|
||||||
buildUsing: "babelShim",
|
|
||||||
},
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
static babelShim() {
|
|
||||||
DeprecationSilencer.silenceConsoleWarn();
|
|
||||||
return {};
|
return {};
|
||||||
}
|
};
|
||||||
|
|
||||||
|
module.exports.silence = function silence(...args) {
|
||||||
|
DEPRECATION_SILENCER.silence(...args);
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue