In newer Embers jQuery is removed. There is a `find` but it only returns one element and not a jQuery selector. This patch migrates our code to a new helper `queryAll` which allows us to remove the global.
74 lines
2.2 KiB
JavaScript
74 lines
2.2 KiB
JavaScript
import { queryAll } from "discourse/tests/helpers/qunit-helpers";
|
|
import {
|
|
moduleForWidget,
|
|
widgetTest,
|
|
} from "discourse/tests/helpers/widget-test";
|
|
|
|
moduleForWidget("poster-name");
|
|
|
|
widgetTest("basic rendering", {
|
|
template: '{{mount-widget widget="poster-name" args=args}}',
|
|
beforeEach() {
|
|
this.set("args", {
|
|
username: "eviltrout",
|
|
usernameUrl: "/u/eviltrout",
|
|
name: "Robin Ward",
|
|
user_title: "Trout Master",
|
|
});
|
|
},
|
|
test(assert) {
|
|
assert.ok(queryAll(".names").length);
|
|
assert.ok(queryAll("span.username").length);
|
|
assert.ok(queryAll("a[data-user-card=eviltrout]").length);
|
|
assert.equal(queryAll(".username a").text(), "eviltrout");
|
|
assert.equal(queryAll(".full-name a").text(), "Robin Ward");
|
|
assert.equal(queryAll(".user-title").text(), "Trout Master");
|
|
},
|
|
});
|
|
|
|
widgetTest("extra classes and glyphs", {
|
|
template: '{{mount-widget widget="poster-name" args=args}}',
|
|
beforeEach() {
|
|
this.set("args", {
|
|
username: "eviltrout",
|
|
usernameUrl: "/u/eviltrout",
|
|
staff: true,
|
|
admin: true,
|
|
moderator: true,
|
|
new_user: true,
|
|
primary_group_name: "fish",
|
|
});
|
|
},
|
|
test(assert) {
|
|
assert.ok(queryAll("span.staff").length);
|
|
assert.ok(queryAll("span.admin").length);
|
|
assert.ok(queryAll("span.moderator").length);
|
|
assert.ok(queryAll(".d-icon-shield-alt").length);
|
|
assert.ok(queryAll("span.new-user").length);
|
|
assert.ok(queryAll("span.fish").length);
|
|
},
|
|
});
|
|
|
|
widgetTest("disable display name on posts", {
|
|
template: '{{mount-widget widget="poster-name" args=args}}',
|
|
beforeEach() {
|
|
this.siteSettings.display_name_on_posts = false;
|
|
this.set("args", { username: "eviltrout", name: "Robin Ward" });
|
|
},
|
|
test(assert) {
|
|
assert.equal(queryAll(".full-name").length, 0);
|
|
},
|
|
});
|
|
|
|
widgetTest("doesn't render a name if it's similar to the username", {
|
|
template: '{{mount-widget widget="poster-name" args=args}}',
|
|
beforeEach() {
|
|
this.siteSettings.prioritize_username_in_ux = true;
|
|
this.siteSettings.display_name_on_posts = true;
|
|
this.set("args", { username: "eviltrout", name: "evil-trout" });
|
|
},
|
|
test(assert) {
|
|
assert.equal(queryAll(".second").length, 0);
|
|
},
|
|
});
|