2024-04-09 03:00:09 +08:00
|
|
|
import { getOwner } from "@ember/application";
|
|
|
|
import { setupTest } from "ember-qunit";
|
2023-08-25 21:20:56 +08:00
|
|
|
import { module, test } from "qunit";
|
2024-04-09 03:00:09 +08:00
|
|
|
import CoreFabricators from "discourse/lib/fabricators";
|
|
|
|
import ChatFabricators from "discourse/plugins/chat/discourse/lib/fabricators";
|
2023-08-25 21:20:56 +08:00
|
|
|
import {
|
|
|
|
getReactionText,
|
2023-10-11 02:38:59 +08:00
|
|
|
MAX_DISPLAYED_USERNAMES,
|
2023-08-25 21:20:56 +08:00
|
|
|
} from "discourse/plugins/chat/discourse/lib/get-reaction-text";
|
|
|
|
|
2024-04-09 03:00:09 +08:00
|
|
|
module("Discourse Chat | Unit | get-reaction-text", function (hooks) {
|
|
|
|
setupTest(hooks);
|
|
|
|
|
2023-08-25 21:20:56 +08:00
|
|
|
test("no reaction ", function (assert) {
|
2024-04-09 03:00:09 +08:00
|
|
|
const reaction = new ChatFabricators(getOwner(this)).reaction({
|
|
|
|
count: 0,
|
|
|
|
users: [],
|
|
|
|
});
|
|
|
|
const currentUser = new CoreFabricators(getOwner(this)).user();
|
2023-08-25 21:20:56 +08:00
|
|
|
|
|
|
|
assert.strictEqual(getReactionText(reaction, currentUser), undefined);
|
|
|
|
});
|
|
|
|
|
|
|
|
test("current user reacted - one reaction", function (assert) {
|
2024-04-09 03:00:09 +08:00
|
|
|
const currentUser = new CoreFabricators(getOwner(this)).user();
|
|
|
|
|
|
|
|
const reaction = new ChatFabricators(getOwner(this)).reaction({
|
2023-08-25 21:20:56 +08:00
|
|
|
count: 1,
|
|
|
|
users: [currentUser],
|
|
|
|
reacted: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.strictEqual(
|
|
|
|
getReactionText(reaction, currentUser),
|
2023-12-11 21:29:16 +08:00
|
|
|
"<span>You reacted with </span>:heart:"
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
test("current user reacted - two reactions", function (assert) {
|
2024-04-09 03:00:09 +08:00
|
|
|
const currentUser = new CoreFabricators(getOwner(this)).user();
|
|
|
|
const secondUser = new CoreFabricators(getOwner(this)).user({
|
|
|
|
username: "martin",
|
|
|
|
});
|
|
|
|
const reaction = new ChatFabricators(getOwner(this)).reaction({
|
2023-08-25 21:20:56 +08:00
|
|
|
count: 2,
|
|
|
|
users: [currentUser, secondUser],
|
|
|
|
reacted: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.strictEqual(
|
|
|
|
getReactionText(reaction, currentUser),
|
2023-12-11 21:29:16 +08:00
|
|
|
"<span>You and martin reacted with </span>:heart:"
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
test("current user reacted - more than display limit reactions", function (assert) {
|
2024-04-09 03:00:09 +08:00
|
|
|
const currentUser = new CoreFabricators(getOwner(this)).user();
|
2023-08-25 21:20:56 +08:00
|
|
|
const otherUsers = Array.from(Array(MAX_DISPLAYED_USERNAMES + 1)).map(
|
2024-04-09 03:00:09 +08:00
|
|
|
(_, i) =>
|
|
|
|
new CoreFabricators(getOwner(this)).user({ username: "user" + i })
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
2024-04-09 03:00:09 +08:00
|
|
|
const reaction = new ChatFabricators(getOwner(this)).reaction({
|
2023-08-25 21:20:56 +08:00
|
|
|
count: [currentUser].concat(otherUsers).length,
|
|
|
|
users: [currentUser].concat(otherUsers),
|
|
|
|
reacted: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.strictEqual(
|
|
|
|
getReactionText(reaction, currentUser),
|
2023-12-11 21:29:16 +08:00
|
|
|
"<span>You, user0, user1, user2, user3, user4, user5, user6, user7, user8, user9, user10, user11, user12, user13, user14 and 1 other reacted with </span>:heart:"
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
test("current user reacted - less or equal than display limit reactions", function (assert) {
|
2024-04-09 03:00:09 +08:00
|
|
|
const currentUser = new CoreFabricators(getOwner(this)).user();
|
2023-08-25 21:20:56 +08:00
|
|
|
const otherUsers = Array.from(Array(MAX_DISPLAYED_USERNAMES - 2)).map(
|
2024-04-09 03:00:09 +08:00
|
|
|
(_, i) =>
|
|
|
|
new CoreFabricators(getOwner(this)).user({ username: "user" + i })
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
2024-04-09 03:00:09 +08:00
|
|
|
const reaction = new ChatFabricators(getOwner(this)).reaction({
|
2023-08-25 21:20:56 +08:00
|
|
|
count: [currentUser].concat(otherUsers).length,
|
|
|
|
users: [currentUser].concat(otherUsers),
|
|
|
|
reacted: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.strictEqual(
|
|
|
|
getReactionText(reaction, currentUser),
|
2023-12-11 21:29:16 +08:00
|
|
|
"<span>You, user0, user1, user2, user3, user4, user5, user6, user7, user8, user9, user10, user11 and user12 reacted with </span>:heart:"
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
test("current user reacted - one reaction", function (assert) {
|
2024-04-09 03:00:09 +08:00
|
|
|
const currentUser = new CoreFabricators(getOwner(this)).user();
|
|
|
|
const reaction = new ChatFabricators(getOwner(this)).reaction({
|
2023-08-25 21:20:56 +08:00
|
|
|
count: 1,
|
|
|
|
users: [currentUser],
|
|
|
|
reacted: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.strictEqual(
|
|
|
|
getReactionText(reaction, currentUser),
|
2023-12-11 21:29:16 +08:00
|
|
|
"<span>You reacted with </span>:heart:"
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
test("current user reacted - two reactions", function (assert) {
|
2024-04-09 03:00:09 +08:00
|
|
|
const currentUser = new CoreFabricators(getOwner(this)).user();
|
|
|
|
const secondUser = new CoreFabricators(getOwner(this)).user({
|
|
|
|
username: "martin",
|
|
|
|
});
|
|
|
|
const reaction = new ChatFabricators(getOwner(this)).reaction({
|
2023-08-25 21:20:56 +08:00
|
|
|
count: 2,
|
|
|
|
users: [currentUser, secondUser],
|
|
|
|
reacted: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.strictEqual(
|
|
|
|
getReactionText(reaction, currentUser),
|
2023-12-11 21:29:16 +08:00
|
|
|
"<span>You and martin reacted with </span>:heart:"
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
test("current user reacted - more than display limit reactions", function (assert) {
|
2024-04-09 03:00:09 +08:00
|
|
|
const currentUser = new CoreFabricators(getOwner(this)).user();
|
2023-08-25 21:20:56 +08:00
|
|
|
const otherUsers = Array.from(Array(MAX_DISPLAYED_USERNAMES + 1)).map(
|
2024-04-09 03:00:09 +08:00
|
|
|
(_, i) =>
|
|
|
|
new CoreFabricators(getOwner(this)).user({ username: "user" + i })
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
2024-04-09 03:00:09 +08:00
|
|
|
const reaction = new ChatFabricators(getOwner(this)).reaction({
|
2023-08-25 21:20:56 +08:00
|
|
|
count: [currentUser].concat(otherUsers).length,
|
|
|
|
users: [currentUser].concat(otherUsers),
|
|
|
|
reacted: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.strictEqual(
|
|
|
|
getReactionText(reaction, currentUser),
|
2023-12-11 21:29:16 +08:00
|
|
|
"<span>You, user0, user1, user2, user3, user4, user5, user6, user7, user8, user9, user10, user11, user12, user13, user14 and 1 other reacted with </span>:heart:"
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
test("current user reacted - less or equal than display limit reactions", function (assert) {
|
2024-04-09 03:00:09 +08:00
|
|
|
const currentUser = new CoreFabricators(getOwner(this)).user();
|
2023-08-25 21:20:56 +08:00
|
|
|
const otherUsers = Array.from(Array(MAX_DISPLAYED_USERNAMES - 2)).map(
|
2024-04-09 03:00:09 +08:00
|
|
|
(_, i) =>
|
|
|
|
new CoreFabricators(getOwner(this)).user({ username: "user" + i })
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
2024-04-09 03:00:09 +08:00
|
|
|
const reaction = new ChatFabricators(getOwner(this)).reaction({
|
2023-08-25 21:20:56 +08:00
|
|
|
count: [currentUser].concat(otherUsers).length,
|
|
|
|
users: [currentUser].concat(otherUsers),
|
|
|
|
reacted: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.strictEqual(
|
|
|
|
getReactionText(reaction, currentUser),
|
2023-12-11 21:29:16 +08:00
|
|
|
"<span>You, user0, user1, user2, user3, user4, user5, user6, user7, user8, user9, user10, user11 and user12 reacted with </span>:heart:"
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
test("current user didn't react - one reaction", function (assert) {
|
2024-04-09 03:00:09 +08:00
|
|
|
const user = new CoreFabricators(getOwner(this)).user({
|
|
|
|
username: "martin",
|
|
|
|
});
|
|
|
|
const reaction = new ChatFabricators(getOwner(this)).reaction({
|
2023-08-25 21:20:56 +08:00
|
|
|
count: 1,
|
|
|
|
users: [user],
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.strictEqual(
|
2024-04-09 03:00:09 +08:00
|
|
|
getReactionText(reaction, new CoreFabricators(getOwner(this)).user()),
|
2023-12-11 21:29:16 +08:00
|
|
|
"<span>martin reacted with </span>:heart:"
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
test("current user didn't react - two reactions", function (assert) {
|
2024-04-09 03:00:09 +08:00
|
|
|
const firstUser = new CoreFabricators(getOwner(this)).user({
|
|
|
|
username: "claude",
|
|
|
|
});
|
|
|
|
const secondUser = new CoreFabricators(getOwner(this)).user({
|
|
|
|
username: "martin",
|
|
|
|
});
|
|
|
|
const reaction = new ChatFabricators(getOwner(this)).reaction({
|
2023-08-25 21:20:56 +08:00
|
|
|
count: 2,
|
|
|
|
users: [firstUser, secondUser],
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.strictEqual(
|
2024-04-09 03:00:09 +08:00
|
|
|
getReactionText(reaction, new CoreFabricators(getOwner(this)).user()),
|
2023-12-11 21:29:16 +08:00
|
|
|
"<span>claude and martin reacted with </span>:heart:"
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
test("current user didn't react - more than display limit reactions", function (assert) {
|
|
|
|
const users = Array.from(Array(MAX_DISPLAYED_USERNAMES + 1)).map((_, i) =>
|
2024-04-09 03:00:09 +08:00
|
|
|
new CoreFabricators(getOwner(this)).user({ username: "user" + i })
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
2024-04-09 03:00:09 +08:00
|
|
|
const reaction = new ChatFabricators(getOwner(this)).reaction({
|
2023-08-25 21:20:56 +08:00
|
|
|
count: users.length,
|
|
|
|
users,
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.strictEqual(
|
2024-04-09 03:00:09 +08:00
|
|
|
getReactionText(reaction, new CoreFabricators(getOwner(this)).user()),
|
2023-12-11 21:29:16 +08:00
|
|
|
"<span>user0, user1, user2, user3, user4, user5, user6, user7, user8, user9, user10, user11, user12, user13, user14 and 1 other reacted with </span>:heart:"
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
test("current user didn't react - less or equal than display limit reactions", function (assert) {
|
|
|
|
const users = Array.from(Array(MAX_DISPLAYED_USERNAMES - 1)).map((_, i) =>
|
2024-04-09 03:00:09 +08:00
|
|
|
new CoreFabricators(getOwner(this)).user({ username: "user" + i })
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
2024-04-09 03:00:09 +08:00
|
|
|
const reaction = new ChatFabricators(getOwner(this)).reaction({
|
2023-08-25 21:20:56 +08:00
|
|
|
count: users.length,
|
|
|
|
users,
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.strictEqual(
|
2024-04-09 03:00:09 +08:00
|
|
|
getReactionText(reaction, new CoreFabricators(getOwner(this)).user()),
|
2023-12-11 21:29:16 +08:00
|
|
|
"<span>user0, user1, user2, user3, user4, user5, user6, user7, user8, user9, user10, user11, user12 and user13 reacted with </span>:heart:"
|
2023-08-25 21:20:56 +08:00
|
|
|
);
|
|
|
|
});
|
|
|
|
});
|