mirror of
https://github.com/zulip/zulip.git
synced 2025-11-04 22:13:26 +00:00
The default label for empty narrows depends on whether it's a stream/topic narrow or a PMs narrow. We leave some default text in compose.hbs for reply label because it take some time for the js to display the correct label.
109 lines
2.9 KiB
JavaScript
109 lines
2.9 KiB
JavaScript
"use strict";
|
|
|
|
// Setup
|
|
const {strict: assert} = require("assert");
|
|
|
|
const {mock_cjs, mock_esm, set_global, zrequire} = require("../zjsunit/namespace");
|
|
const {run_test} = require("../zjsunit/test");
|
|
const $ = require("../zjsunit/zjquery");
|
|
|
|
// Mocking and stubbing things
|
|
mock_cjs("jquery", $);
|
|
set_global("document", "document-stub");
|
|
const message_lists = mock_esm("../../static/js/message_lists");
|
|
|
|
// Code we're actually using/testing
|
|
const compose_closed_ui = zrequire("compose_closed_ui");
|
|
const {Filter} = zrequire("filter");
|
|
const {MessageList} = zrequire("message_list");
|
|
|
|
// Helper test function
|
|
function test_reply_label(expected_label) {
|
|
const label = $(".compose_reply_button_label").text();
|
|
const prepend_text_length = "translated: Message ".length;
|
|
assert.equal(
|
|
label.slice(prepend_text_length),
|
|
expected_label,
|
|
"'" + label.slice(prepend_text_length),
|
|
Number("' did not match '") + expected_label + "'",
|
|
);
|
|
}
|
|
|
|
run_test("reply_label", () => {
|
|
// Mocking up a test message list
|
|
const filter = new Filter();
|
|
const list = new MessageList({
|
|
filter,
|
|
});
|
|
message_lists.current = list;
|
|
list.add_messages([
|
|
{
|
|
id: 0,
|
|
stream: "first_stream",
|
|
topic: "first_topic",
|
|
},
|
|
{
|
|
id: 1,
|
|
stream: "first_stream",
|
|
topic: "second_topic",
|
|
},
|
|
{
|
|
id: 2,
|
|
stream: "second_stream",
|
|
topic: "third_topic",
|
|
},
|
|
{
|
|
id: 3,
|
|
stream: "second_stream",
|
|
topic: "second_topic",
|
|
},
|
|
{
|
|
id: 4,
|
|
display_reply_to: "some user",
|
|
},
|
|
{
|
|
id: 5,
|
|
display_reply_to: "some user, other user",
|
|
},
|
|
]);
|
|
|
|
const expected_labels = [
|
|
"#first_stream > first_topic",
|
|
"#first_stream > second_topic",
|
|
"#second_stream > third_topic",
|
|
"#second_stream > second_topic",
|
|
"some user",
|
|
"some user, other user",
|
|
];
|
|
|
|
// Initialize the code we're testing.
|
|
compose_closed_ui.initialize();
|
|
|
|
// Run the tests!
|
|
let first = true;
|
|
for (const expected_label of expected_labels) {
|
|
if (first) {
|
|
list.select_id(list.first().id);
|
|
first = false;
|
|
} else {
|
|
list.select_id(list.next());
|
|
}
|
|
test_reply_label(expected_label);
|
|
}
|
|
});
|
|
|
|
run_test("test_custom_message_input", () => {
|
|
compose_closed_ui.update_reply_recipient_label({
|
|
stream: "stream test",
|
|
topic: "topic test",
|
|
});
|
|
test_reply_label("#stream test > topic test");
|
|
});
|
|
|
|
run_test("empty_narrow", () => {
|
|
message_lists.current.empty = () => true;
|
|
compose_closed_ui.update_reply_recipient_label();
|
|
const label = $(".compose_reply_button_label").text();
|
|
assert.equal(label, "translated: Compose message");
|
|
});
|