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 =
|
const emberCliDeprecationWorkflows =
|
||||||
window.deprecationWorkflow?.config?.workflow;
|
window.deprecationWorkflow?.config?.workflow;
|
||||||
|
|
||||||
|
let emberDeprecationSilencer;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Display a deprecation warning with the provided message. The warning will be prefixed with the theme/plugin name
|
* 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.
|
* 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.
|
* @param {function} callback The function to call while deprecations are silenced.
|
||||||
*/
|
*/
|
||||||
export function withSilencedDeprecations(deprecationIds, callback) {
|
export function withSilencedDeprecations(deprecationIds, callback) {
|
||||||
|
ensureEmberDeprecationSilencer();
|
||||||
const idArray = [].concat(deprecationIds);
|
const idArray = [].concat(deprecationIds);
|
||||||
try {
|
try {
|
||||||
idArray.forEach((id) => disabledDeprecations.add(id));
|
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.
|
* @param {function} callback The asynchronous function to call while deprecations are silenced.
|
||||||
*/
|
*/
|
||||||
export async function withSilencedDeprecationsAsync(deprecationIds, callback) {
|
export async function withSilencedDeprecationsAsync(deprecationIds, callback) {
|
||||||
|
ensureEmberDeprecationSilencer();
|
||||||
const idArray = [].concat(deprecationIds);
|
const idArray = [].concat(deprecationIds);
|
||||||
try {
|
try {
|
||||||
idArray.forEach((id) => disabledDeprecations.add(id));
|
idArray.forEach((id) => disabledDeprecations.add(id));
|
||||||
|
@ -102,3 +106,23 @@ export async function withSilencedDeprecationsAsync(deprecationIds, callback) {
|
||||||
idArray.forEach((id) => disabledDeprecations.delete(id));
|
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 $ from "jquery";
|
||||||
import { CLOSE_INITIATED_BY_MODAL_SHOW } from "discourse/components/d-modal";
|
import { CLOSE_INITIATED_BY_MODAL_SHOW } from "discourse/components/d-modal";
|
||||||
import { disableImplicitInjections } from "discourse/lib/implicit-injections";
|
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";
|
import I18n from "discourse-i18n";
|
||||||
|
|
||||||
// Known legacy modals in core. Silence deprecation warnings for these so the messages
|
// 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 modalName = `modal/${templateName}`;
|
||||||
const fullName = opts.admin ? `admin/templates/${modalName}` : modalName;
|
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);
|
route.render(fullName, renderArgs);
|
||||||
|
});
|
||||||
|
|
||||||
if (opts.panels) {
|
if (opts.panels) {
|
||||||
if (controller.actions.onSelectPanel) {
|
if (controller.actions.onSelectPanel) {
|
||||||
|
@ -213,9 +220,16 @@ export default class ModalServiceWithLegacySupport extends ModalService {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
getOwner(this)
|
const applicationRoute = getOwner(this).lookup("route:application");
|
||||||
.lookup("route:application")
|
|
||||||
.render("hide-modal", { into: "application", outlet: "modalBody" });
|
// 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");
|
$(".d-modal.fixed-modal").modal("hide");
|
||||||
|
|
||||||
if (controller) {
|
if (controller) {
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
import { deprecate as emberDeprecate } from "@ember/debug";
|
||||||
import { setupTest } from "ember-qunit";
|
import { setupTest } from "ember-qunit";
|
||||||
import { module, test } from "qunit";
|
import { module, test } from "qunit";
|
||||||
import Sinon from "sinon";
|
import Sinon from "sinon";
|
||||||
|
@ -216,4 +217,25 @@ module("Unit | Utility | deprecated", function (hooks) {
|
||||||
"counter is incremented outside the silenced function"
|
"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