discourse/plugins/chat/test/javascripts/components/chat-composer-message-details-test.gjs
David Taylor 999ae73c78
DEV: [gjs-codemod] apply codemod
Co-authored-by: Jarek Radosz <jarek@cvx.dev>
2025-04-02 13:44:15 +01:00

106 lines
3 KiB
Text
Vendored
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

import { getOwner } from "@ember/owner";
import { render } from "@ember/test-helpers";
import { module, test } from "qunit";
import { setupRenderingTest } from "discourse/tests/helpers/component-test";
import ChatComposerMessageDetails from "discourse/plugins/chat/discourse/components/chat-composer-message-details";
import ChatFabricators from "discourse/plugins/chat/discourse/lib/fabricators";
module(
"Discourse Chat | Component | chat-composer-message-details",
function (hooks) {
setupRenderingTest(hooks);
test("data-id attribute", async function (assert) {
const self = this;
this.message = new ChatFabricators(getOwner(this)).message();
await render(
<template>
<ChatComposerMessageDetails @message={{self.message}} />
</template>
);
assert
.dom(".chat-composer-message-details")
.hasAttribute("data-id", this.message.id.toString());
});
test("editing a message has the pencil icon", async function (assert) {
const self = this;
this.message = new ChatFabricators(getOwner(this)).message({
editing: true,
});
await render(
<template>
<ChatComposerMessageDetails @message={{self.message}} />
</template>
);
assert.dom(".chat-composer-message-details .d-icon-pencil").exists();
});
test("replying to a message has the reply icon", async function (assert) {
const self = this;
const firstMessage = new ChatFabricators(getOwner(this)).message();
this.message = new ChatFabricators(getOwner(this)).message({
inReplyTo: firstMessage,
});
await render(
<template>
<ChatComposerMessageDetails @message={{self.message}} />
</template>
);
assert.dom(".chat-composer-message-details .d-icon-reply").exists();
});
test("displays user avatar", async function (assert) {
const self = this;
this.message = new ChatFabricators(getOwner(this)).message();
await render(
<template>
<ChatComposerMessageDetails @message={{self.message}} />
</template>
);
assert
.dom(".chat-composer-message-details .chat-user-avatar .avatar")
.hasAttribute("title", this.message.user.username);
});
test("displays message excerpt", async function (assert) {
const self = this;
this.message = new ChatFabricators(getOwner(this)).message();
await render(
<template>
<ChatComposerMessageDetails @message={{self.message}} />
</template>
);
assert.dom(".chat-reply__excerpt").hasText(this.message.excerpt);
});
test("displays users username", async function (assert) {
const self = this;
this.message = new ChatFabricators(getOwner(this)).message();
await render(
<template>
<ChatComposerMessageDetails @message={{self.message}} />
</template>
);
assert.dom(".chat-reply__username").hasText(this.message.user.username);
});
}
);