discourse/plugins/chat/test/javascripts/components/chat-user-display-name-test.gjs
David Taylor 9322a46fa4
DEV: Remove unneeded const self = this; from qunit tests (#35632)
This was required in older versions of Ember. But now, bare template
tags can access `this.`. This commit was created by upgrading lint-configs, and then running 
`pnpm lint:js:fix && pnpm lint:prettier:fix`

Rule development: https://github.com/discourse/lint-configs/pull/154
2025-10-27 18:07:22 +00:00

62 lines
1.9 KiB
Text

import { render } from "@ember/test-helpers";
import { module, test } from "qunit";
import { setupRenderingTest } from "discourse/tests/helpers/component-test";
import ChatUserDisplayName from "discourse/plugins/chat/discourse/components/chat-user-display-name";
module(
"Discourse Chat | Component | chat-user-display-name | prioritize username in UX",
function (hooks) {
setupRenderingTest(hooks);
test("username and no name", async function (assert) {
this.siteSettings.prioritize_username_in_ux = true;
this.set("user", { username: "bob", name: null });
await render(
<template><ChatUserDisplayName @user={{this.user}} /></template>
);
assert.dom(".chat-user-display-name").hasText("bob");
});
test("username and name", async function (assert) {
this.siteSettings.prioritize_username_in_ux = true;
this.set("user", { username: "bob", name: "Bobcat" });
await render(
<template><ChatUserDisplayName @user={{this.user}} /></template>
);
assert.dom(".chat-user-display-name").hasText("bob Bobcat");
});
}
);
module(
"Discourse Chat | Component | chat-user-display-name | prioritize name in UX",
function (hooks) {
setupRenderingTest(hooks);
test("no name", async function (assert) {
this.siteSettings.prioritize_username_in_ux = false;
this.set("user", { username: "bob", name: null });
await render(
<template><ChatUserDisplayName @user={{this.user}} /></template>
);
assert.dom(".chat-user-display-name").hasText("bob");
});
test("name and username", async function (assert) {
this.siteSettings.prioritize_username_in_ux = false;
this.set("user", { username: "bob", name: "Bobcat" });
await render(
<template><ChatUserDisplayName @user={{this.user}} /></template>
);
assert.dom(".chat-user-display-name").hasText("Bobcat bob");
});
}
);