2023-08-25 21:20:56 +08:00
|
|
|
import { module, test } from "qunit";
|
2023-10-11 02:38:59 +08:00
|
|
|
import fabricators 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";
|
|
|
|
|
|
|
|
module("Discourse Chat | Unit | get-reaction-text", function () {
|
|
|
|
test("no reaction ", function (assert) {
|
|
|
|
const reaction = fabricators.reaction({ count: 0, users: [] });
|
|
|
|
const currentUser = fabricators.user();
|
|
|
|
|
|
|
|
assert.strictEqual(getReactionText(reaction, currentUser), undefined);
|
|
|
|
});
|
|
|
|
|
|
|
|
test("current user reacted - one reaction", function (assert) {
|
|
|
|
const currentUser = fabricators.user();
|
|
|
|
const reaction = fabricators.reaction({
|
|
|
|
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) {
|
|
|
|
const currentUser = fabricators.user();
|
|
|
|
const secondUser = fabricators.user({ username: "martin" });
|
|
|
|
const reaction = fabricators.reaction({
|
|
|
|
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) {
|
|
|
|
const currentUser = fabricators.user();
|
|
|
|
const otherUsers = Array.from(Array(MAX_DISPLAYED_USERNAMES + 1)).map(
|
|
|
|
(_, i) => fabricators.user({ username: "user" + i })
|
|
|
|
);
|
|
|
|
const reaction = fabricators.reaction({
|
|
|
|
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) {
|
|
|
|
const currentUser = fabricators.user();
|
|
|
|
const otherUsers = Array.from(Array(MAX_DISPLAYED_USERNAMES - 2)).map(
|
|
|
|
(_, i) => fabricators.user({ username: "user" + i })
|
|
|
|
);
|
|
|
|
const reaction = fabricators.reaction({
|
|
|
|
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) {
|
|
|
|
const currentUser = fabricators.user();
|
|
|
|
const reaction = fabricators.reaction({
|
|
|
|
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) {
|
|
|
|
const currentUser = fabricators.user();
|
|
|
|
const secondUser = fabricators.user({ username: "martin" });
|
|
|
|
const reaction = fabricators.reaction({
|
|
|
|
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) {
|
|
|
|
const currentUser = fabricators.user();
|
|
|
|
const otherUsers = Array.from(Array(MAX_DISPLAYED_USERNAMES + 1)).map(
|
|
|
|
(_, i) => fabricators.user({ username: "user" + i })
|
|
|
|
);
|
|
|
|
const reaction = fabricators.reaction({
|
|
|
|
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) {
|
|
|
|
const currentUser = fabricators.user();
|
|
|
|
const otherUsers = Array.from(Array(MAX_DISPLAYED_USERNAMES - 2)).map(
|
|
|
|
(_, i) => fabricators.user({ username: "user" + i })
|
|
|
|
);
|
|
|
|
const reaction = fabricators.reaction({
|
|
|
|
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) {
|
|
|
|
const user = fabricators.user({ username: "martin" });
|
|
|
|
const reaction = fabricators.reaction({
|
|
|
|
count: 1,
|
|
|
|
users: [user],
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.strictEqual(
|
|
|
|
getReactionText(reaction, fabricators.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) {
|
|
|
|
const firstUser = fabricators.user({ username: "claude" });
|
|
|
|
const secondUser = fabricators.user({ username: "martin" });
|
|
|
|
const reaction = fabricators.reaction({
|
|
|
|
count: 2,
|
|
|
|
users: [firstUser, secondUser],
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.strictEqual(
|
|
|
|
getReactionText(reaction, fabricators.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) =>
|
|
|
|
fabricators.user({ username: "user" + i })
|
|
|
|
);
|
|
|
|
const reaction = fabricators.reaction({
|
|
|
|
count: users.length,
|
|
|
|
users,
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.strictEqual(
|
|
|
|
getReactionText(reaction, fabricators.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) =>
|
|
|
|
fabricators.user({ username: "user" + i })
|
|
|
|
);
|
|
|
|
const reaction = fabricators.reaction({
|
|
|
|
count: users.length,
|
|
|
|
users,
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.strictEqual(
|
|
|
|
getReactionText(reaction, fabricators.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
|
|
|
);
|
|
|
|
});
|
|
|
|
});
|