2020-04-16 20:47:18 +02:00
|
|
|
zrequire('message_util');
|
|
|
|
|
2020-06-01 17:17:41 +02:00
|
|
|
const noop = () => {};
|
2020-05-23 09:04:51 +02:00
|
|
|
set_global('$', global.make_zjquery({
|
|
|
|
silent: true,
|
|
|
|
}));
|
2020-04-08 13:59:56 +02:00
|
|
|
set_global('hashchange', {
|
2020-06-01 17:17:41 +02:00
|
|
|
exit_overlay: noop,
|
2020-04-08 13:59:56 +02:00
|
|
|
});
|
2020-05-26 10:33:35 +02:00
|
|
|
set_global('stream_data', {
|
2020-06-19 22:20:30 +02:00
|
|
|
get_sub_by_id: () => {
|
2020-05-26 10:33:35 +02:00
|
|
|
return {
|
|
|
|
color: "",
|
|
|
|
invite_only: false,
|
|
|
|
is_web_public: true,
|
|
|
|
};
|
|
|
|
},
|
2020-05-29 17:22:53 +02:00
|
|
|
is_muted: () => {
|
|
|
|
// We only test via muted topics for now.
|
|
|
|
// TODO: Make muted streams and test them.
|
|
|
|
return false;
|
|
|
|
},
|
2020-05-26 10:33:35 +02:00
|
|
|
});
|
2020-04-08 13:59:56 +02:00
|
|
|
set_global('overlays', {
|
|
|
|
open_overlay: (opts) => {
|
|
|
|
overlays.close_callback = opts.on_close;
|
|
|
|
},
|
2020-05-29 12:03:22 +02:00
|
|
|
recent_topics_open: () => {
|
|
|
|
return true;
|
|
|
|
},
|
2020-04-08 13:59:56 +02:00
|
|
|
});
|
2020-03-21 14:42:10 +01:00
|
|
|
set_global('people', {
|
|
|
|
is_my_user_id: function (id) {
|
|
|
|
return id === 1;
|
|
|
|
},
|
2020-05-22 21:04:03 +02:00
|
|
|
sender_info_with_small_avatar_urls_for_sender_ids: (ids) => {
|
|
|
|
return ids;
|
|
|
|
},
|
2020-03-21 14:42:10 +01:00
|
|
|
});
|
2020-05-22 08:16:08 +02:00
|
|
|
set_global('XDate', zrequire('XDate', 'xdate'));
|
|
|
|
set_global('timerender', {
|
|
|
|
last_seen_status_from_date: () => {
|
|
|
|
return "Just now";
|
|
|
|
},
|
2020-06-26 12:25:35 +02:00
|
|
|
get_full_datetime: () => {
|
|
|
|
return {
|
|
|
|
date: "date",
|
|
|
|
time: "time",
|
|
|
|
};
|
|
|
|
},
|
2020-05-22 08:16:08 +02:00
|
|
|
});
|
|
|
|
set_global('unread', {
|
|
|
|
unread_topic_counter: {
|
2020-05-23 09:04:51 +02:00
|
|
|
get: (stream_id, topic) => {
|
|
|
|
if (stream_id === 1 && topic === "topic-1") {
|
|
|
|
// Only stream1, topic-1 is read.
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
return 1;
|
|
|
|
},
|
2020-05-22 08:16:08 +02:00
|
|
|
},
|
|
|
|
});
|
|
|
|
set_global('hash_util', {
|
|
|
|
by_stream_uri: () => {
|
|
|
|
return "https://www.example.com";
|
|
|
|
},
|
|
|
|
by_stream_topic_uri: () => {
|
|
|
|
return "https://www.example.com";
|
|
|
|
},
|
|
|
|
});
|
2020-05-22 21:04:03 +02:00
|
|
|
set_global('recent_senders', {
|
|
|
|
get_topic_recent_senders: () => { return [1, 2]; },
|
|
|
|
});
|
2020-06-01 17:17:41 +02:00
|
|
|
set_global('list_render', {
|
|
|
|
modifier: noop,
|
|
|
|
create: (container, mapped_topic_values, opts) => {
|
|
|
|
const formatted_topics = [];
|
|
|
|
list_render.modifier = opts.modifier;
|
|
|
|
for (const item of mapped_topic_values) {
|
|
|
|
formatted_topics.push(opts.modifier(item));
|
|
|
|
opts.filter.predicate(item);
|
|
|
|
}
|
2020-06-01 13:24:29 +02:00
|
|
|
// Just for coverage, the mechanisms
|
|
|
|
// are tested in list_render
|
|
|
|
if (mapped_topic_values.length >= 2) {
|
|
|
|
opts.sort_fields.stream_sort(mapped_topic_values[0], mapped_topic_values[1]);
|
|
|
|
opts.sort_fields.stream_sort(mapped_topic_values[1], mapped_topic_values[0]);
|
|
|
|
opts.sort_fields.stream_sort(mapped_topic_values[0], mapped_topic_values[0]);
|
|
|
|
opts.sort_fields.topic_sort(mapped_topic_values[0], mapped_topic_values[1]);
|
|
|
|
opts.sort_fields.topic_sort(mapped_topic_values[1], mapped_topic_values[0]);
|
|
|
|
opts.sort_fields.topic_sort(mapped_topic_values[0], mapped_topic_values[0]);
|
|
|
|
}
|
2020-06-01 17:17:41 +02:00
|
|
|
return list_render;
|
|
|
|
},
|
|
|
|
hard_redraw: noop,
|
|
|
|
render_item: (item) => {
|
|
|
|
return list_render.modifier(item);
|
|
|
|
},
|
|
|
|
});
|
2020-03-21 14:42:10 +01:00
|
|
|
|
|
|
|
// Custom Data
|
|
|
|
|
|
|
|
// New stream
|
|
|
|
const stream1 = 1;
|
2020-04-16 20:47:18 +02:00
|
|
|
const stream2 = 2;
|
|
|
|
const stream3 = 3;
|
2020-06-01 13:24:29 +02:00
|
|
|
const stream4 = 4;
|
2020-03-21 14:42:10 +01:00
|
|
|
|
2020-05-23 09:04:51 +02:00
|
|
|
// Topics in the stream, all unread except topic1 & stream1.
|
|
|
|
const topic1 = "topic-1"; // No Other sender & read.
|
2020-03-21 14:42:10 +01:00
|
|
|
const topic2 = "topic-2"; // Other sender
|
|
|
|
const topic3 = "topic-3"; // User not present
|
|
|
|
const topic4 = "topic-4"; // User not present
|
|
|
|
const topic5 = "topic-5"; // other sender
|
|
|
|
const topic6 = "topic-6"; // other sender
|
|
|
|
const topic7 = "topic-7"; // muted topic
|
2020-04-16 20:47:18 +02:00
|
|
|
const topic8 = "topic-8";
|
|
|
|
const topic9 = "topic-9";
|
2020-06-01 13:24:29 +02:00
|
|
|
const topic10 = "topic-10";
|
2020-03-21 14:42:10 +01:00
|
|
|
|
|
|
|
set_global('muting', {
|
|
|
|
is_topic_muted: (stream_id, topic) => {
|
|
|
|
if (stream_id === stream1 && topic === topic7) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
// sender1 == current user
|
|
|
|
// sender2 == any other user
|
|
|
|
const sender1 = 1;
|
|
|
|
const sender2 = 2;
|
|
|
|
|
|
|
|
const messages = [];
|
|
|
|
|
2020-04-16 20:47:18 +02:00
|
|
|
set_global('message_list', {
|
|
|
|
all: {
|
|
|
|
all_messages: function () {
|
|
|
|
return messages;
|
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|
2020-05-22 08:16:08 +02:00
|
|
|
set_global('message_store', {
|
|
|
|
get: (msg_id) => {
|
|
|
|
return messages[msg_id - 1];
|
|
|
|
},
|
|
|
|
});
|
2020-04-16 20:47:18 +02:00
|
|
|
|
2020-03-21 14:42:10 +01:00
|
|
|
let id = 0;
|
|
|
|
|
|
|
|
messages[0] = {
|
|
|
|
stream_id: stream1,
|
2020-05-22 08:16:08 +02:00
|
|
|
stream: 'stream1',
|
2020-03-21 14:42:10 +01:00
|
|
|
id: id += 1,
|
|
|
|
topic: topic1,
|
|
|
|
sender_id: sender1,
|
|
|
|
type: 'stream',
|
|
|
|
};
|
|
|
|
|
|
|
|
messages[1] = {
|
|
|
|
stream_id: stream1,
|
2020-05-22 08:16:08 +02:00
|
|
|
stream: 'stream1',
|
2020-03-21 14:42:10 +01:00
|
|
|
id: id += 1,
|
|
|
|
topic: topic2,
|
|
|
|
sender_id: sender1,
|
|
|
|
type: 'stream',
|
|
|
|
};
|
|
|
|
|
|
|
|
messages[2] = {
|
|
|
|
stream_id: stream1,
|
2020-05-22 08:16:08 +02:00
|
|
|
stream: 'stream1',
|
2020-03-21 14:42:10 +01:00
|
|
|
id: id += 1,
|
|
|
|
topic: topic2,
|
|
|
|
sender_id: sender2,
|
|
|
|
type: 'stream',
|
|
|
|
};
|
|
|
|
|
|
|
|
messages[3] = {
|
|
|
|
stream_id: stream1,
|
2020-05-22 08:16:08 +02:00
|
|
|
stream: 'stream1',
|
2020-03-21 14:42:10 +01:00
|
|
|
id: id += 1,
|
|
|
|
topic: topic3,
|
|
|
|
sender_id: sender2,
|
|
|
|
type: 'stream',
|
|
|
|
};
|
|
|
|
|
|
|
|
messages[4] = {
|
|
|
|
stream_id: stream1,
|
2020-05-22 08:16:08 +02:00
|
|
|
stream: 'stream1',
|
2020-03-21 14:42:10 +01:00
|
|
|
id: id += 1,
|
|
|
|
topic: topic4,
|
|
|
|
sender_id: sender2,
|
|
|
|
type: 'stream',
|
|
|
|
};
|
|
|
|
|
|
|
|
messages[5] = {
|
|
|
|
stream_id: stream1,
|
2020-05-22 08:16:08 +02:00
|
|
|
stream: 'stream1',
|
2020-03-21 14:42:10 +01:00
|
|
|
id: id += 1,
|
|
|
|
topic: topic5,
|
|
|
|
sender_id: sender1,
|
|
|
|
type: 'stream',
|
|
|
|
};
|
|
|
|
|
|
|
|
messages[6] = {
|
|
|
|
stream_id: stream1,
|
2020-05-22 08:16:08 +02:00
|
|
|
stream: 'stream1',
|
2020-03-21 14:42:10 +01:00
|
|
|
id: id += 1,
|
|
|
|
topic: topic5,
|
|
|
|
sender_id: sender2,
|
|
|
|
type: 'stream',
|
|
|
|
};
|
|
|
|
|
|
|
|
messages[7] = {
|
|
|
|
stream_id: stream1,
|
2020-05-22 08:16:08 +02:00
|
|
|
stream: 'stream1',
|
2020-03-21 14:42:10 +01:00
|
|
|
id: id += 1,
|
|
|
|
topic: topic6,
|
|
|
|
sender_id: sender1,
|
|
|
|
type: 'stream',
|
|
|
|
};
|
|
|
|
|
|
|
|
messages[8] = {
|
|
|
|
stream_id: stream1,
|
2020-05-22 08:16:08 +02:00
|
|
|
stream: 'stream1',
|
2020-03-21 14:42:10 +01:00
|
|
|
id: id += 1,
|
|
|
|
topic: topic6,
|
|
|
|
sender_id: sender2,
|
|
|
|
type: 'stream',
|
|
|
|
};
|
|
|
|
|
|
|
|
messages[9] = {
|
|
|
|
stream_id: stream1,
|
2020-05-22 08:16:08 +02:00
|
|
|
stream: 'stream1',
|
2020-03-21 14:42:10 +01:00
|
|
|
id: id += 1,
|
|
|
|
topic: topic7,
|
|
|
|
sender_id: sender1,
|
|
|
|
type: 'stream',
|
|
|
|
};
|
|
|
|
|
2020-06-01 13:24:29 +02:00
|
|
|
// a message of stream4
|
|
|
|
messages[10] = {
|
|
|
|
stream_id: stream4,
|
|
|
|
stream: 'stream4',
|
|
|
|
id: id += 1,
|
|
|
|
topic: topic10,
|
|
|
|
sender_id: sender1,
|
|
|
|
type: 'stream',
|
|
|
|
};
|
|
|
|
|
2020-06-12 12:46:30 +02:00
|
|
|
function get_topic_key(stream_id, topic) {
|
|
|
|
return stream_id + ":" + topic.toLowerCase();
|
|
|
|
}
|
|
|
|
|
2020-05-28 17:04:32 +02:00
|
|
|
function generate_topic_data(topic_info_array) {
|
|
|
|
// Since most of the fields are common, this function helps generate fixtures
|
|
|
|
// with non common fields.
|
2020-05-29 11:56:19 +02:00
|
|
|
$.clear_all_elements();
|
2020-05-28 17:04:32 +02:00
|
|
|
const data = [];
|
2020-05-29 12:03:22 +02:00
|
|
|
const selectors = [];
|
|
|
|
|
2020-05-29 11:56:19 +02:00
|
|
|
for (const [stream_id, topic, unread_count, muted, participated] of topic_info_array) {
|
2020-06-12 12:46:30 +02:00
|
|
|
const topic_selector = $.create('#recent_topic:' + get_topic_key(stream_id, topic));
|
2020-05-29 11:56:19 +02:00
|
|
|
topic_selector.data = function () {
|
|
|
|
return {
|
|
|
|
participated: participated,
|
|
|
|
muted: muted,
|
|
|
|
unreadCount: unread_count,
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2020-05-29 12:03:22 +02:00
|
|
|
selectors.push(topic_selector);
|
2020-05-28 17:04:32 +02:00
|
|
|
data.push({
|
2020-06-12 12:07:48 +02:00
|
|
|
other_senders_count: 0,
|
2020-05-26 10:33:35 +02:00
|
|
|
invite_only: false,
|
|
|
|
is_web_public: true,
|
2020-05-28 17:04:32 +02:00
|
|
|
last_msg_time: 'Just now',
|
2020-06-26 12:25:35 +02:00
|
|
|
full_last_msg_date_time: "date time",
|
2020-05-28 17:04:32 +02:00
|
|
|
senders: [
|
|
|
|
1,
|
|
|
|
2,
|
|
|
|
],
|
|
|
|
stream: 'stream' + stream_id,
|
2020-05-26 10:33:35 +02:00
|
|
|
stream_color: '',
|
2020-05-28 17:04:32 +02:00
|
|
|
stream_id: stream_id,
|
|
|
|
stream_url: 'https://www.example.com',
|
|
|
|
topic: topic,
|
2020-06-12 12:46:30 +02:00
|
|
|
topic_key: get_topic_key(stream_id, topic),
|
2020-05-28 17:04:32 +02:00
|
|
|
topic_url: 'https://www.example.com',
|
|
|
|
unread_count: unread_count,
|
2020-05-29 11:56:19 +02:00
|
|
|
muted: muted,
|
2020-05-29 17:22:53 +02:00
|
|
|
topic_muted: muted,
|
2020-05-29 11:56:19 +02:00
|
|
|
participated: participated,
|
2020-05-28 17:04:32 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
return data;
|
|
|
|
}
|
|
|
|
|
2020-03-21 14:42:10 +01:00
|
|
|
function verify_topic_data(all_topics, stream, topic, last_msg_id,
|
2020-05-28 13:41:29 +02:00
|
|
|
participated) {
|
2020-03-21 14:42:10 +01:00
|
|
|
const topic_data = all_topics.get(stream + ':' + topic);
|
|
|
|
assert.equal(topic_data.last_msg_id, last_msg_id);
|
|
|
|
assert.equal(topic_data.participated, participated);
|
|
|
|
}
|
|
|
|
|
2020-05-22 08:16:08 +02:00
|
|
|
run_test("test_recent_topics_launch", () => {
|
|
|
|
// Note: unread count and urls are fake,
|
|
|
|
// since they are generated in external libraries
|
|
|
|
// and are not to be tested here.
|
|
|
|
const expected = {
|
2020-06-13 14:03:34 +02:00
|
|
|
filter_participated: false,
|
|
|
|
filter_unread: false,
|
2020-05-29 17:22:53 +02:00
|
|
|
filter_muted: false,
|
2020-06-01 17:17:41 +02:00
|
|
|
search_val: '',
|
2020-05-22 08:16:08 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
global.stub_templates(function (template_name, data) {
|
2020-05-29 12:03:22 +02:00
|
|
|
if (template_name === 'recent_topics_table') {
|
|
|
|
assert.deepEqual(data, expected);
|
|
|
|
} else if (template_name === 'recent_topics_filters') {
|
|
|
|
assert.equal(data.filter_unread, expected.filter_unread);
|
|
|
|
assert.equal(data.filter_participated, expected.filter_participated);
|
|
|
|
}
|
2020-05-22 08:16:08 +02:00
|
|
|
return '<recent_topics table stub>';
|
|
|
|
});
|
2020-03-21 14:42:10 +01:00
|
|
|
|
2020-05-22 08:16:08 +02:00
|
|
|
const rt = zrequire('recent_topics');
|
|
|
|
rt.process_messages(messages);
|
|
|
|
|
|
|
|
rt.launch();
|
2020-06-13 14:00:32 +02:00
|
|
|
|
|
|
|
// Test if search text is selected
|
2020-05-22 08:16:08 +02:00
|
|
|
overlays.close_callback();
|
|
|
|
|
|
|
|
// incorrect topic_key
|
|
|
|
assert.equal(rt.inplace_rerender('stream_unknown:topic_unknown'), false);
|
|
|
|
});
|
|
|
|
|
2020-05-23 09:04:51 +02:00
|
|
|
run_test('test_filter_all', () => {
|
|
|
|
// Just tests inplace rerender of a message
|
|
|
|
// in All topics filter.
|
2020-06-01 17:17:41 +02:00
|
|
|
const expected = {
|
|
|
|
filter_participated: false,
|
|
|
|
filter_unread: false,
|
|
|
|
filter_muted: false,
|
|
|
|
search_val: "",
|
|
|
|
};
|
|
|
|
let row_data;
|
|
|
|
let i;
|
2020-05-23 09:04:51 +02:00
|
|
|
global.stub_templates(function (template_name, data) {
|
2020-06-01 17:17:41 +02:00
|
|
|
if (template_name === 'recent_topic_row') {
|
|
|
|
// All the row will be processed.
|
|
|
|
i -= 1;
|
|
|
|
assert.deepEqual(data, row_data[i]);
|
|
|
|
} else if (template_name === 'recent_topics_table') {
|
|
|
|
assert.deepEqual(data, expected);
|
|
|
|
}
|
2020-05-23 09:04:51 +02:00
|
|
|
return '<recent_topics row stub>';
|
|
|
|
});
|
|
|
|
|
|
|
|
// topic is not muted
|
2020-06-01 17:17:41 +02:00
|
|
|
row_data = generate_topic_data([[1, 'topic-1', 0, false, true]]);
|
|
|
|
i = row_data.length;
|
2020-05-23 09:04:51 +02:00
|
|
|
const rt = zrequire('recent_topics');
|
2020-06-01 17:17:41 +02:00
|
|
|
rt.set_filter('all');
|
2020-05-23 09:04:51 +02:00
|
|
|
rt.process_messages([messages[0]]);
|
|
|
|
|
2020-06-01 17:17:41 +02:00
|
|
|
row_data = row_data.concat(generate_topic_data([[1, 'topic-7', 1, true, true]]));
|
|
|
|
i = row_data.length;
|
2020-05-23 09:04:51 +02:00
|
|
|
// topic is muted (=== hidden)
|
|
|
|
rt.process_messages([messages[9]]);
|
2020-06-01 17:17:41 +02:00
|
|
|
|
|
|
|
// Test search
|
|
|
|
expected.search_val = "topic-1";
|
|
|
|
row_data = generate_topic_data([[1, 'topic-1', 0, false, true]]);
|
|
|
|
const search_element = $.create("#recent_topics_search");
|
|
|
|
search_element.val('topic-3');
|
|
|
|
i = row_data.length;
|
|
|
|
assert.equal(rt.inplace_rerender('1:topic-1'), true);
|
2020-05-23 09:04:51 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
run_test('test_filter_unread', () => {
|
|
|
|
// Tests rerender of all topics when filter changes to "unread".
|
2020-06-01 17:17:41 +02:00
|
|
|
const expected = {
|
2020-05-23 09:39:47 +02:00
|
|
|
filter_participated: false,
|
|
|
|
filter_unread: true,
|
2020-05-29 17:22:53 +02:00
|
|
|
filter_muted: false,
|
2020-06-01 17:17:41 +02:00
|
|
|
search_val: '',
|
2020-05-23 09:04:51 +02:00
|
|
|
};
|
|
|
|
|
2020-06-01 17:17:41 +02:00
|
|
|
const row_data = generate_topic_data([
|
|
|
|
// stream_id, topic, unread_count, muted, participated
|
2020-06-01 13:24:29 +02:00
|
|
|
[4, 'topic-10', 1, false, true],
|
2020-06-01 17:17:41 +02:00
|
|
|
[1, 'topic-7', 1, true, true],
|
|
|
|
[1, 'topic-6', 1, false, true],
|
|
|
|
[1, 'topic-5', 1, false, true],
|
|
|
|
[1, 'topic-4', 1, false, false],
|
|
|
|
[1, 'topic-3', 1, false, false],
|
|
|
|
[1, 'topic-2', 1, false, true],
|
|
|
|
[1, 'topic-1', 0, false, true],
|
|
|
|
]);
|
|
|
|
let i = 0;
|
|
|
|
|
2020-05-23 09:04:51 +02:00
|
|
|
const rt = zrequire('recent_topics');
|
|
|
|
|
|
|
|
global.stub_templates(function () {
|
|
|
|
return '<recent_topics table stub>';
|
|
|
|
});
|
|
|
|
rt.process_messages(messages);
|
2020-06-01 17:17:41 +02:00
|
|
|
assert.equal(rt.inplace_rerender('1:topic-1'), true);
|
2020-05-23 09:04:51 +02:00
|
|
|
|
2020-06-13 14:03:34 +02:00
|
|
|
$('#recent_topics_filter_buttons').removeClass('btn-recent-selected');
|
2020-05-23 09:04:51 +02:00
|
|
|
global.stub_templates(function (template_name, data) {
|
2020-06-01 17:17:41 +02:00
|
|
|
assert.equal(template_name, 'recent_topics_filters');
|
|
|
|
assert.equal(data.filter_unread, expected.filter_unread);
|
|
|
|
assert.equal(data.filter_participated, expected.filter_participated);
|
2020-05-23 09:04:51 +02:00
|
|
|
return '<recent_topics table stub>';
|
|
|
|
});
|
2020-05-29 12:03:22 +02:00
|
|
|
|
2020-06-13 14:03:34 +02:00
|
|
|
rt.set_filter('unread');
|
2020-05-29 12:03:22 +02:00
|
|
|
rt.update_filters_view();
|
|
|
|
|
|
|
|
global.stub_templates(function (template_name, data) {
|
2020-06-01 17:17:41 +02:00
|
|
|
if (template_name === 'recent_topic_row') {
|
|
|
|
// All the row will be processed.
|
|
|
|
assert.deepEqual(data, row_data[i]);
|
|
|
|
i += 1;
|
|
|
|
} else if (template_name === 'recent_topics_table') {
|
|
|
|
assert.deepEqual(data, expected);
|
|
|
|
}
|
2020-05-29 12:03:22 +02:00
|
|
|
return '<recent_topics row stub>';
|
|
|
|
});
|
|
|
|
rt.process_messages([messages[0]]);
|
2020-05-23 09:04:51 +02:00
|
|
|
|
|
|
|
// Unselect "unread" filter by clicking twice.
|
2020-05-23 09:39:47 +02:00
|
|
|
expected.filter_unread = false;
|
2020-05-29 12:03:22 +02:00
|
|
|
$('#recent_topics_filter_buttons').addClass('btn-recent-selected');
|
2020-05-23 09:04:51 +02:00
|
|
|
rt.set_filter('unread');
|
|
|
|
|
2020-06-01 17:17:41 +02:00
|
|
|
$('#recent_topics_filter_buttons').removeClass('btn-recent-selected');
|
|
|
|
// reselect "unread" filter
|
|
|
|
rt.set_filter('unread');
|
|
|
|
|
2020-05-23 09:04:51 +02:00
|
|
|
// Now clicking "all" filter should have no change to expected data.
|
|
|
|
rt.set_filter('all');
|
|
|
|
});
|
|
|
|
|
|
|
|
run_test('test_filter_participated', () => {
|
|
|
|
// Tests rerender of all topics when filter changes to "unread".
|
2020-06-01 17:17:41 +02:00
|
|
|
const expected = {
|
2020-05-23 09:39:47 +02:00
|
|
|
filter_participated: true,
|
|
|
|
filter_unread: false,
|
2020-06-01 17:17:41 +02:00
|
|
|
filter_muted: false,
|
|
|
|
search_val: '',
|
2020-05-23 09:04:51 +02:00
|
|
|
};
|
|
|
|
|
2020-06-01 17:17:41 +02:00
|
|
|
const row_data = generate_topic_data([
|
|
|
|
// stream_id, topic, unread_count, muted, participated
|
2020-06-01 13:24:29 +02:00
|
|
|
[4, 'topic-10', 1, false, true],
|
2020-06-01 17:17:41 +02:00
|
|
|
[1, 'topic-7', 1, true, true],
|
|
|
|
[1, 'topic-6', 1, false, true],
|
|
|
|
[1, 'topic-5', 1, false, true],
|
|
|
|
[1, 'topic-4', 1, false, false],
|
|
|
|
[1, 'topic-3', 1, false, false],
|
|
|
|
[1, 'topic-2', 1, false, true],
|
|
|
|
[1, 'topic-1', 0, false, true],
|
|
|
|
]);
|
|
|
|
let i = 0;
|
|
|
|
|
2020-05-23 09:04:51 +02:00
|
|
|
const rt = zrequire('recent_topics');
|
|
|
|
|
|
|
|
global.stub_templates(function () {
|
|
|
|
return '<recent_topics table stub>';
|
|
|
|
});
|
|
|
|
rt.process_messages(messages);
|
2020-06-01 17:17:41 +02:00
|
|
|
assert.equal(rt.inplace_rerender('1:topic-4'), true);
|
|
|
|
|
|
|
|
// Set muted filter
|
|
|
|
rt.set_filter('muted');
|
|
|
|
assert.equal(rt.inplace_rerender('1:topic-7'), true);
|
|
|
|
|
|
|
|
// remove muted filter
|
|
|
|
rt.set_filter('muted');
|
2020-05-23 09:04:51 +02:00
|
|
|
|
2020-06-13 14:03:34 +02:00
|
|
|
$('#recent_topics_filter_buttons').removeClass('btn-recent-selected');
|
2020-05-23 09:04:51 +02:00
|
|
|
global.stub_templates(function (template_name, data) {
|
2020-06-01 17:17:41 +02:00
|
|
|
assert.equal(template_name, 'recent_topics_filters');
|
|
|
|
assert.equal(data.filter_unread, expected.filter_unread);
|
|
|
|
assert.equal(data.filter_participated, expected.filter_participated);
|
2020-05-23 09:04:51 +02:00
|
|
|
return '<recent_topics table stub>';
|
|
|
|
});
|
2020-06-13 14:03:34 +02:00
|
|
|
rt.set_filter('participated');
|
2020-05-29 12:03:22 +02:00
|
|
|
rt.update_filters_view();
|
2020-06-01 17:17:41 +02:00
|
|
|
|
2020-05-29 12:03:22 +02:00
|
|
|
|
|
|
|
global.stub_templates(function (template_name, data) {
|
2020-06-01 17:17:41 +02:00
|
|
|
if (template_name === 'recent_topic_row') {
|
|
|
|
// All the row will be processed.
|
|
|
|
assert.deepEqual(data, row_data[i]);
|
|
|
|
i += 1;
|
|
|
|
} else if (template_name === 'recent_topics_table') {
|
|
|
|
assert.deepEqual(data, expected);
|
|
|
|
}
|
2020-05-29 12:03:22 +02:00
|
|
|
return '<recent_topics row stub>';
|
|
|
|
});
|
|
|
|
rt.process_messages([messages[4]]);
|
2020-05-23 09:04:51 +02:00
|
|
|
|
2020-05-23 09:39:47 +02:00
|
|
|
expected.filter_participated = false;
|
2020-05-23 09:04:51 +02:00
|
|
|
rt.set_filter('all');
|
|
|
|
});
|
|
|
|
|
2020-05-29 12:03:22 +02:00
|
|
|
run_test('test_update_unread_count', () => {
|
|
|
|
const rt = zrequire('recent_topics');
|
2020-06-01 17:17:41 +02:00
|
|
|
rt.set_filter('all');
|
2020-05-29 12:03:22 +02:00
|
|
|
global.stub_templates(function () {
|
|
|
|
return '<recent_topics table stub>';
|
|
|
|
});
|
|
|
|
rt.process_messages(messages);
|
|
|
|
|
|
|
|
// update a message
|
|
|
|
generate_topic_data([[1, 'topic-7', 1, false, true]]);
|
2020-06-12 12:46:30 +02:00
|
|
|
rt.update_topic_unread_count(messages[9]);
|
2020-05-29 12:03:22 +02:00
|
|
|
});
|
|
|
|
|
2020-05-22 08:16:08 +02:00
|
|
|
// template rendering is tested in test_recent_topics_launch.
|
|
|
|
global.stub_templates(function () {
|
|
|
|
return '<recent_topics table stub>';
|
|
|
|
});
|
|
|
|
|
|
|
|
run_test('basic assertions', () => {
|
|
|
|
const rt = zrequire('recent_topics');
|
2020-06-01 17:17:41 +02:00
|
|
|
rt.set_filter('all');
|
2020-03-21 14:42:10 +01:00
|
|
|
rt.process_messages(messages);
|
|
|
|
let all_topics = rt.get();
|
|
|
|
|
2020-05-22 08:16:08 +02:00
|
|
|
// update a message
|
2020-05-29 12:03:22 +02:00
|
|
|
generate_topic_data([[1, 'topic-7', 1, false, true]]);
|
2020-05-22 08:16:08 +02:00
|
|
|
rt.process_messages([messages[9]]);
|
2020-03-21 14:42:10 +01:00
|
|
|
// Check for expected lengths.
|
2020-06-01 13:24:29 +02:00
|
|
|
// total 8 topics, 1 muted
|
|
|
|
assert.equal(all_topics.size, 8);
|
2020-03-21 14:42:10 +01:00
|
|
|
assert.equal(Array.from(all_topics.keys()).toString(),
|
2020-06-01 13:24:29 +02:00
|
|
|
'4:topic-10,1:topic-7,1:topic-6,1:topic-5,1:topic-4,1:topic-3,1:topic-2,1:topic-1');
|
2020-03-21 14:42:10 +01:00
|
|
|
|
|
|
|
rt.process_message({
|
|
|
|
type: 'private',
|
|
|
|
});
|
|
|
|
|
|
|
|
// Private msgs are not processed.
|
2020-06-01 13:24:29 +02:00
|
|
|
assert.equal(all_topics.size, 8);
|
2020-03-21 14:42:10 +01:00
|
|
|
assert.equal(Array.from(all_topics.keys()).toString(),
|
2020-06-01 13:24:29 +02:00
|
|
|
'4:topic-10,1:topic-7,1:topic-6,1:topic-5,1:topic-4,1:topic-3,1:topic-2,1:topic-1');
|
2020-03-21 14:42:10 +01:00
|
|
|
|
2020-05-28 13:41:29 +02:00
|
|
|
// participated
|
|
|
|
verify_topic_data(all_topics, stream1, topic1, messages[0].id, true);
|
2020-03-21 14:42:10 +01:00
|
|
|
|
|
|
|
// No message was sent by us.
|
2020-05-28 13:41:29 +02:00
|
|
|
verify_topic_data(all_topics, stream1, topic3, messages[3].id, false);
|
2020-03-21 14:42:10 +01:00
|
|
|
|
2020-05-28 13:41:29 +02:00
|
|
|
// Not participated
|
|
|
|
verify_topic_data(all_topics, stream1, topic4, messages[4].id, false);
|
2020-03-21 14:42:10 +01:00
|
|
|
|
|
|
|
// topic3 now participated
|
|
|
|
rt.process_message({
|
|
|
|
stream_id: stream1,
|
|
|
|
id: id += 1,
|
|
|
|
topic: topic3,
|
|
|
|
sender_id: sender1,
|
|
|
|
type: 'stream',
|
|
|
|
});
|
|
|
|
|
|
|
|
all_topics = rt.get();
|
|
|
|
assert.equal(Array.from(all_topics.keys()).toString(),
|
2020-06-01 13:24:29 +02:00
|
|
|
'1:topic-3,4:topic-10,1:topic-7,1:topic-6,1:topic-5,1:topic-4,1:topic-2,1:topic-1');
|
2020-05-28 13:41:29 +02:00
|
|
|
verify_topic_data(all_topics, stream1, topic3, id, true);
|
2020-03-21 14:42:10 +01:00
|
|
|
|
|
|
|
// Send new message to topic7 (muted)
|
2020-05-22 08:16:08 +02:00
|
|
|
// The topic will be hidden when displayed
|
2020-03-21 14:42:10 +01:00
|
|
|
rt.process_message({
|
|
|
|
stream_id: stream1,
|
|
|
|
id: id += 1,
|
|
|
|
topic: topic7,
|
|
|
|
sender_id: sender1,
|
|
|
|
type: 'stream',
|
|
|
|
});
|
|
|
|
|
|
|
|
all_topics = rt.get();
|
|
|
|
assert.equal(Array.from(all_topics.keys()).toString(),
|
2020-06-01 13:24:29 +02:00
|
|
|
'1:topic-7,1:topic-3,4:topic-10,1:topic-6,1:topic-5,1:topic-4,1:topic-2,1:topic-1');
|
2020-05-15 14:27:36 +02:00
|
|
|
|
2020-05-29 17:22:53 +02:00
|
|
|
// update_topic_is_muted now relies on external libraries completely
|
|
|
|
// so we don't need to check anythere here.
|
|
|
|
generate_topic_data([[1, topic1, 0, false, true]]);
|
|
|
|
assert.equal(rt.update_topic_is_muted(stream1, topic1), true);
|
2020-05-15 14:27:36 +02:00
|
|
|
// a topic gets muted which we are not tracking
|
2020-05-29 17:22:53 +02:00
|
|
|
assert.equal(rt.update_topic_is_muted(stream1, "topic-10"), false);
|
2020-03-21 14:42:10 +01:00
|
|
|
});
|
2020-04-16 20:47:18 +02:00
|
|
|
|
2020-05-28 09:48:58 +02:00
|
|
|
run_test('test_reify_local_echo_message', () => {
|
|
|
|
const rt = zrequire('recent_topics');
|
2020-06-01 17:17:41 +02:00
|
|
|
rt.set_filter('all');
|
2020-05-28 09:48:58 +02:00
|
|
|
rt.process_messages(messages);
|
|
|
|
|
|
|
|
rt.process_message({
|
|
|
|
stream_id: stream1,
|
|
|
|
id: 1000.01,
|
|
|
|
topic: topic7,
|
|
|
|
sender_id: sender1,
|
|
|
|
type: 'stream',
|
2020-06-12 12:05:06 +02:00
|
|
|
});
|
2020-05-28 09:48:58 +02:00
|
|
|
|
|
|
|
assert.equal(rt.reify_message_id_if_available({
|
|
|
|
old_id: 1000.01,
|
|
|
|
new_id: 1001,
|
|
|
|
}), true);
|
|
|
|
|
|
|
|
rt.process_message({
|
|
|
|
stream_id: stream1,
|
|
|
|
id: 1001.01,
|
|
|
|
topic: topic7,
|
|
|
|
sender_id: sender1,
|
|
|
|
type: 'stream',
|
2020-06-12 12:05:06 +02:00
|
|
|
});
|
2020-05-28 09:48:58 +02:00
|
|
|
|
|
|
|
// A new message arrived in the same topic before we could reify the message_id
|
|
|
|
rt.process_message({
|
|
|
|
stream_id: stream1,
|
|
|
|
id: 1003,
|
|
|
|
topic: topic7,
|
|
|
|
sender_id: sender1,
|
|
|
|
type: 'stream',
|
2020-06-12 12:05:06 +02:00
|
|
|
});
|
2020-05-28 09:48:58 +02:00
|
|
|
|
|
|
|
assert.equal(rt.reify_message_id_if_available({
|
|
|
|
old_id: 1000.01,
|
|
|
|
new_id: 1001,
|
|
|
|
}), false);
|
|
|
|
});
|
|
|
|
|
2020-04-16 20:47:18 +02:00
|
|
|
run_test('test_topic_edit', () => {
|
2020-05-22 08:16:08 +02:00
|
|
|
// NOTE: This test should always run in the end as it modified the messages data.
|
|
|
|
const rt = zrequire('recent_topics');
|
2020-06-01 17:17:41 +02:00
|
|
|
rt.set_filter('all');
|
2020-04-16 20:47:18 +02:00
|
|
|
rt.process_messages(messages);
|
|
|
|
|
|
|
|
let all_topics = rt.get();
|
|
|
|
assert.equal(Array.from(all_topics.keys()).toString(),
|
2020-06-01 13:24:29 +02:00
|
|
|
'4:topic-10,1:topic-7,1:topic-6,1:topic-5,1:topic-4,1:topic-3,1:topic-2,1:topic-1');
|
2020-04-16 20:47:18 +02:00
|
|
|
|
|
|
|
////////////////// test change topic //////////////////
|
2020-05-28 13:41:29 +02:00
|
|
|
verify_topic_data(all_topics, stream1, topic6, messages[8].id, true);
|
2020-06-12 12:46:30 +02:00
|
|
|
assert.equal(all_topics.get(get_topic_key(stream1, topic8)), undefined);
|
2020-04-16 20:47:18 +02:00
|
|
|
|
2020-06-12 12:46:30 +02:00
|
|
|
let topic_selector = $.create('#recent_topic:' + get_topic_key(stream1, topic8));
|
2020-05-29 11:56:19 +02:00
|
|
|
topic_selector.data = function () {
|
|
|
|
return {
|
|
|
|
participated: true,
|
|
|
|
muted: false,
|
|
|
|
unreadCount: 1,
|
|
|
|
};
|
|
|
|
};
|
2020-04-16 20:47:18 +02:00
|
|
|
// change topic of topic6 to topic8
|
|
|
|
messages[7].topic = topic8;
|
|
|
|
messages[8].topic = topic8;
|
|
|
|
rt.process_topic_edit(stream1, topic6, topic8);
|
|
|
|
all_topics = rt.get();
|
|
|
|
|
2020-05-28 13:41:29 +02:00
|
|
|
verify_topic_data(all_topics, stream1, topic8, messages[8].id, true);
|
2020-06-12 12:46:30 +02:00
|
|
|
assert.equal(all_topics.get(get_topic_key(stream1, topic6)), undefined);
|
2020-04-16 20:47:18 +02:00
|
|
|
|
|
|
|
////////////////// test stream change //////////////////
|
2020-05-28 13:41:29 +02:00
|
|
|
verify_topic_data(all_topics, stream1, topic1, messages[0].id, true);
|
2020-06-12 12:46:30 +02:00
|
|
|
assert.equal(all_topics.get(get_topic_key(stream2, topic1)), undefined);
|
2020-04-16 20:47:18 +02:00
|
|
|
|
2020-06-12 12:46:30 +02:00
|
|
|
topic_selector = $.create('#recent_topic:' + get_topic_key(stream2, topic1));
|
2020-05-29 11:56:19 +02:00
|
|
|
topic_selector.data = function () {
|
|
|
|
return {
|
|
|
|
participated: true,
|
|
|
|
muted: false,
|
|
|
|
unreadCount: 0,
|
|
|
|
};
|
|
|
|
};
|
2020-04-16 20:47:18 +02:00
|
|
|
messages[0].stream_id = stream2;
|
|
|
|
rt.process_topic_edit(stream1, topic1, topic1, stream2);
|
|
|
|
all_topics = rt.get();
|
|
|
|
|
2020-06-12 12:46:30 +02:00
|
|
|
assert.equal(all_topics.get(get_topic_key(stream1, topic1)), undefined);
|
2020-05-28 13:41:29 +02:00
|
|
|
verify_topic_data(all_topics, stream2, topic1, messages[0].id, true);
|
2020-04-16 20:47:18 +02:00
|
|
|
|
|
|
|
////////////////// test stream & topic change //////////////////
|
2020-05-28 13:41:29 +02:00
|
|
|
verify_topic_data(all_topics, stream2, topic1, messages[0].id, true);
|
2020-06-12 12:46:30 +02:00
|
|
|
assert.equal(all_topics.get(get_topic_key(stream3, topic9)), undefined);
|
2020-04-16 20:47:18 +02:00
|
|
|
|
2020-06-12 12:46:30 +02:00
|
|
|
topic_selector = $.create('#recent_topic:' + get_topic_key(stream3, topic9));
|
2020-05-29 11:56:19 +02:00
|
|
|
topic_selector.data = function () {
|
|
|
|
return {
|
|
|
|
participated: false,
|
|
|
|
muted: false,
|
|
|
|
unreadCount: 1,
|
|
|
|
};
|
|
|
|
};
|
2020-04-16 20:47:18 +02:00
|
|
|
messages[0].stream_id = stream3;
|
|
|
|
messages[0].topic = topic9;
|
|
|
|
rt.process_topic_edit(stream2, topic1, topic9, stream3);
|
|
|
|
all_topics = rt.get();
|
|
|
|
|
2020-06-12 12:46:30 +02:00
|
|
|
assert.equal(all_topics.get(get_topic_key(stream2, topic1)), undefined);
|
2020-05-28 13:41:29 +02:00
|
|
|
verify_topic_data(all_topics, stream3, topic9, messages[0].id, true);
|
2020-04-16 20:47:18 +02:00
|
|
|
});
|
2020-06-26 08:42:35 +02:00
|
|
|
|
|
|
|
run_test('test_search', () => {
|
|
|
|
const rt = zrequire('recent_topics');
|
2020-06-29 11:15:48 +02:00
|
|
|
assert.equal(rt.topic_in_search_results('t', 'general', 'Recent Topic'), true);
|
|
|
|
assert.equal(rt.topic_in_search_results('T', 'general', 'Recent Topic'), true);
|
|
|
|
assert.equal(rt.topic_in_search_results('to', 'general', 'Recent Topic'), true);
|
|
|
|
assert.equal(rt.topic_in_search_results('top', 'general', 'Recent Topic'), true);
|
|
|
|
assert.equal(rt.topic_in_search_results('ToP', 'general', 'Recent Topic'), true);
|
|
|
|
assert.equal(rt.topic_in_search_results('Topi', 'general', 'Recent Topic'), true);
|
|
|
|
assert.equal(rt.topic_in_search_results('tOpi', 'general', 'Recent Topic'), true);
|
|
|
|
assert.equal(rt.topic_in_search_results('toPic', 'general', 'Recent Topic'), true);
|
|
|
|
assert.equal(rt.topic_in_search_results('Topic', 'general', 'Recent Topic'), true);
|
|
|
|
assert.equal(rt.topic_in_search_results('topic', 'general', 'Recent Topic'), true);
|
|
|
|
assert.equal(rt.topic_in_search_results('recent', 'general', 'Recent Topic'), true);
|
|
|
|
assert.equal(rt.topic_in_search_results('RECENT', 'general', 'Recent Topic'), true);
|
|
|
|
|
|
|
|
// match in any order of words
|
|
|
|
assert.equal(rt.topic_in_search_results('topic recent', 'general', 'Recent Topic'), true);
|
|
|
|
|
|
|
|
// Matches any sequence of words.
|
|
|
|
assert.equal(rt.topic_in_search_results('o', 'general', 'Recent Topic'), true);
|
|
|
|
assert.equal(rt.topic_in_search_results('nt to', 'general', 'Recent Topic'), true);
|
|
|
|
assert.equal(rt.topic_in_search_results('z', 'general', 'Recent Topic'), false);
|
|
|
|
|
|
|
|
assert.equal(rt.topic_in_search_results('?', 'general', 'Recent Topic'), false);
|
2020-06-26 08:42:35 +02:00
|
|
|
|
|
|
|
// Test special character match
|
2020-06-29 11:15:48 +02:00
|
|
|
assert.equal(rt.topic_in_search_results('.*+?^${}()[]\\', 'general', 'Recent Topic'), false);
|
|
|
|
assert.equal(rt.topic_in_search_results('?', 'general', 'not-at-start?'), true);
|
2020-06-26 08:42:35 +02:00
|
|
|
|
2020-06-29 11:15:48 +02:00
|
|
|
assert.equal(rt.topic_in_search_results('?', 'general', '?'), true);
|
|
|
|
assert.equal(rt.topic_in_search_results('?', 'general', '\\?'), true);
|
2020-06-26 08:42:35 +02:00
|
|
|
|
2020-06-29 11:15:48 +02:00
|
|
|
assert.equal(rt.topic_in_search_results('\\', 'general', '\\'), true);
|
|
|
|
assert.equal(rt.topic_in_search_results('\\', 'general', '\\\\'), true);
|
2020-06-26 08:42:35 +02:00
|
|
|
});
|