2022-12-22 21:35:18 +08:00
|
|
|
import { setupRenderingTest } from "discourse/tests/helpers/component-test";
|
2022-11-02 21:41:30 +08:00
|
|
|
import { exists, query } from "discourse/tests/helpers/qunit-helpers";
|
|
|
|
import hbs from "htmlbars-inline-precompile";
|
|
|
|
import fabricators from "../helpers/fabricators";
|
|
|
|
import { CHATABLE_TYPES } from "discourse/plugins/chat/discourse/models/chat-channel";
|
2022-12-22 21:35:18 +08:00
|
|
|
import { module, test } from "qunit";
|
|
|
|
import { render } from "@ember/test-helpers";
|
2022-11-02 21:41:30 +08:00
|
|
|
|
|
|
|
module("Discourse Chat | Component | chat-channel-title", function (hooks) {
|
|
|
|
setupRenderingTest(hooks);
|
|
|
|
|
2022-12-22 21:35:18 +08:00
|
|
|
test("category channel", async function (assert) {
|
|
|
|
this.set(
|
|
|
|
"channel",
|
|
|
|
fabricators.chatChannel({
|
|
|
|
chatable_type: CHATABLE_TYPES.categoryChannel,
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
await render(hbs`<ChatChannelTitle @channel={{this.channel}} />`);
|
|
|
|
|
|
|
|
assert.strictEqual(
|
|
|
|
query(".chat-channel-title__category-badge").getAttribute("style"),
|
|
|
|
`color: #${this.channel.chatable.color}`
|
|
|
|
);
|
|
|
|
assert.strictEqual(
|
|
|
|
query(".chat-channel-title__name").innerText,
|
|
|
|
this.channel.title
|
|
|
|
);
|
2022-11-02 21:41:30 +08:00
|
|
|
});
|
|
|
|
|
2022-12-22 21:35:18 +08:00
|
|
|
test("category channel - escapes title", async function (assert) {
|
|
|
|
this.set(
|
|
|
|
"channel",
|
|
|
|
fabricators.chatChannel({
|
|
|
|
chatable_type: CHATABLE_TYPES.categoryChannel,
|
|
|
|
title: "<div class='xss'>evil</div>",
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
await render(hbs`<ChatChannelTitle @channel={{this.channel}} />`);
|
|
|
|
|
|
|
|
assert.false(exists(".xss"));
|
2022-11-02 21:41:30 +08:00
|
|
|
});
|
|
|
|
|
2022-12-22 21:35:18 +08:00
|
|
|
test("category channel - read restricted", async function (assert) {
|
|
|
|
this.set(
|
|
|
|
"channel",
|
|
|
|
fabricators.chatChannel({
|
|
|
|
chatable_type: CHATABLE_TYPES.categoryChannel,
|
|
|
|
chatable: { read_restricted: true },
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
await render(hbs`<ChatChannelTitle @channel={{this.channel}} />`);
|
|
|
|
|
|
|
|
assert.true(exists(".d-icon-lock"));
|
2022-11-02 21:41:30 +08:00
|
|
|
});
|
|
|
|
|
2022-12-22 21:35:18 +08:00
|
|
|
test("category channel - not read restricted", async function (assert) {
|
|
|
|
this.set(
|
|
|
|
"channel",
|
|
|
|
fabricators.chatChannel({
|
|
|
|
chatable_type: CHATABLE_TYPES.categoryChannel,
|
|
|
|
chatable: { read_restricted: false },
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
await render(hbs`<ChatChannelTitle @channel={{this.channel}} />`);
|
|
|
|
|
|
|
|
assert.false(exists(".d-icon-lock"));
|
2022-11-02 21:41:30 +08:00
|
|
|
});
|
|
|
|
|
2022-12-22 21:35:18 +08:00
|
|
|
test("direct message channel - one user", async function (assert) {
|
|
|
|
this.set("channel", fabricators.directMessageChatChannel());
|
2022-11-02 21:41:30 +08:00
|
|
|
|
2022-12-22 21:35:18 +08:00
|
|
|
await render(hbs`<ChatChannelTitle @channel={{this.channel}} />`);
|
2022-11-02 21:41:30 +08:00
|
|
|
|
2022-12-22 21:35:18 +08:00
|
|
|
const user = this.channel.chatable.users[0];
|
2022-11-02 21:41:30 +08:00
|
|
|
|
2022-12-22 21:35:18 +08:00
|
|
|
assert.true(
|
|
|
|
exists(`.chat-user-avatar-container .avatar[title="${user.username}"]`)
|
|
|
|
);
|
2022-11-02 21:41:30 +08:00
|
|
|
|
2022-12-22 21:35:18 +08:00
|
|
|
assert.strictEqual(
|
|
|
|
query(".chat-channel-title__name").innerText.trim(),
|
|
|
|
user.username
|
|
|
|
);
|
2022-11-02 21:41:30 +08:00
|
|
|
});
|
|
|
|
|
2022-12-22 21:35:18 +08:00
|
|
|
test("direct message channel - multiple users", async function (assert) {
|
|
|
|
const channel = fabricators.directMessageChatChannel();
|
|
|
|
|
|
|
|
channel.chatable.users.push({
|
|
|
|
id: 2,
|
|
|
|
username: "joffrey",
|
|
|
|
name: null,
|
|
|
|
avatar_template: "/letter_avatar_proxy/v3/letter/t/31188e/{size}.png",
|
|
|
|
});
|
|
|
|
|
|
|
|
this.set("channel", channel);
|
|
|
|
|
|
|
|
await render(hbs`<ChatChannelTitle @channel={{this.channel}} />`);
|
|
|
|
|
|
|
|
const users = this.channel.chatable.users;
|
|
|
|
assert.strictEqual(
|
|
|
|
parseInt(query(".chat-channel-title__users-count").innerText.trim(), 10),
|
|
|
|
users.length
|
|
|
|
);
|
|
|
|
assert.strictEqual(
|
|
|
|
query(".chat-channel-title__name").innerText.trim(),
|
|
|
|
users.mapBy("username").join(", ")
|
|
|
|
);
|
2022-11-02 21:41:30 +08:00
|
|
|
});
|
|
|
|
});
|