DEV: extend `withSilencedDeprecations` to work for ember deprecations (#24153)
This will allow us to globally unsilence deprecations for plugin/theme authors while silencing specific cases in Discourse core.
This commit is contained in:
parent
b7cafdc07f
commit
3071535a14
|
@ -3,6 +3,8 @@ const disabledDeprecations = new Set();
|
|||
const emberCliDeprecationWorkflows =
|
||||
window.deprecationWorkflow?.config?.workflow;
|
||||
|
||||
let emberDeprecationSilencer;
|
||||
|
||||
/**
|
||||
* Display a deprecation warning with the provided message. The warning will be prefixed with the theme/plugin name
|
||||
* if it can be automatically determined based on the current stack.
|
||||
|
@ -72,6 +74,7 @@ export function registerDeprecationHandler(callback) {
|
|||
* @param {function} callback The function to call while deprecations are silenced.
|
||||
*/
|
||||
export function withSilencedDeprecations(deprecationIds, callback) {
|
||||
ensureEmberDeprecationSilencer();
|
||||
const idArray = [].concat(deprecationIds);
|
||||
try {
|
||||
idArray.forEach((id) => disabledDeprecations.add(id));
|
||||
|
@ -94,6 +97,7 @@ export function withSilencedDeprecations(deprecationIds, callback) {
|
|||
* @param {function} callback The asynchronous function to call while deprecations are silenced.
|
||||
*/
|
||||
export async function withSilencedDeprecationsAsync(deprecationIds, callback) {
|
||||
ensureEmberDeprecationSilencer();
|
||||
const idArray = [].concat(deprecationIds);
|
||||
try {
|
||||
idArray.forEach((id) => disabledDeprecations.add(id));
|
||||
|
@ -102,3 +106,23 @@ export async function withSilencedDeprecationsAsync(deprecationIds, callback) {
|
|||
idArray.forEach((id) => disabledDeprecations.delete(id));
|
||||
}
|
||||
}
|
||||
|
||||
function ensureEmberDeprecationSilencer() {
|
||||
if (emberDeprecationSilencer) {
|
||||
return;
|
||||
}
|
||||
|
||||
emberDeprecationSilencer = (message, options, next) => {
|
||||
if (options?.id && disabledDeprecations.has(options.id)) {
|
||||
return;
|
||||
} else {
|
||||
next(message, options);
|
||||
}
|
||||
};
|
||||
|
||||
if (require.has("@ember/debug")) {
|
||||
require("@ember/debug").registerDeprecationHandler(
|
||||
emberDeprecationSilencer
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -6,7 +6,9 @@ import { dasherize } from "@ember/string";
|
|||
import $ from "jquery";
|
||||
import { CLOSE_INITIATED_BY_MODAL_SHOW } from "discourse/components/d-modal";
|
||||
import { disableImplicitInjections } from "discourse/lib/implicit-injections";
|
||||
import deprecated from "discourse-common/lib/deprecated";
|
||||
import deprecated, {
|
||||
withSilencedDeprecations,
|
||||
} from "discourse-common/lib/deprecated";
|
||||
import I18n from "discourse-i18n";
|
||||
|
||||
// Known legacy modals in core. Silence deprecation warnings for these so the messages
|
||||
|
@ -177,7 +179,12 @@ export default class ModalServiceWithLegacySupport extends ModalService {
|
|||
|
||||
const modalName = `modal/${templateName}`;
|
||||
const fullName = opts.admin ? `admin/templates/${modalName}` : modalName;
|
||||
|
||||
// Any use of the legacy modal system will trigger Discourse's own deprecation message
|
||||
// so we can silence Ember's message here.
|
||||
withSilencedDeprecations("route-render-template", () => {
|
||||
route.render(fullName, renderArgs);
|
||||
});
|
||||
|
||||
if (opts.panels) {
|
||||
if (controller.actions.onSelectPanel) {
|
||||
|
@ -213,9 +220,16 @@ export default class ModalServiceWithLegacySupport extends ModalService {
|
|||
return;
|
||||
}
|
||||
|
||||
getOwner(this)
|
||||
.lookup("route:application")
|
||||
.render("hide-modal", { into: "application", outlet: "modalBody" });
|
||||
const applicationRoute = getOwner(this).lookup("route:application");
|
||||
|
||||
// Any use of the legacy modal system will trigger Discourse's own deprecation message
|
||||
// so we can silence Ember's message here.
|
||||
withSilencedDeprecations("route-render-template", () => {
|
||||
applicationRoute.render("hide-modal", {
|
||||
into: "application",
|
||||
outlet: "modalBody",
|
||||
});
|
||||
});
|
||||
$(".d-modal.fixed-modal").modal("hide");
|
||||
|
||||
if (controller) {
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { deprecate as emberDeprecate } from "@ember/debug";
|
||||
import { setupTest } from "ember-qunit";
|
||||
import { module, test } from "qunit";
|
||||
import Sinon from "sinon";
|
||||
|
@ -216,4 +217,25 @@ module("Unit | Utility | deprecated", function (hooks) {
|
|||
"counter is incremented outside the silenced function"
|
||||
);
|
||||
});
|
||||
|
||||
test("can silence Ember deprecations", function (assert) {
|
||||
withSilencedDeprecations("fake-ember-deprecation", () => {
|
||||
emberDeprecate("fake ember deprecation message", false, {
|
||||
id: "fake-ember-deprecation",
|
||||
for: "not-ember-source",
|
||||
since: "v0",
|
||||
until: "v999",
|
||||
});
|
||||
});
|
||||
assert.strictEqual(
|
||||
this.warnStub.callCount,
|
||||
0,
|
||||
"console.warn is not called"
|
||||
);
|
||||
assert.strictEqual(
|
||||
this.counterStub.callCount,
|
||||
0,
|
||||
"counter is not incremented"
|
||||
);
|
||||
});
|
||||
});
|
||||
|
|
Loading…
Reference in New Issue