2013-07-28 18:40:50 +02:00
|
|
|
// Unit test the unread.js module, which depends on these global variables:
|
|
|
|
//
|
|
|
|
// _, narrow, current_msg_list, home_msg_list, subs
|
|
|
|
//
|
|
|
|
// These tests are framework-free and run sequentially; they are invoked
|
|
|
|
// immediately after being defined. The contract here is that tests should
|
|
|
|
// clean up after themselves, and they should explicitly stub all
|
|
|
|
// dependencies (except _).
|
|
|
|
|
2013-08-21 20:27:14 +02:00
|
|
|
add_dependencies({
|
|
|
|
_: 'third/underscore/underscore.js',
|
2013-09-28 00:00:44 +02:00
|
|
|
muting: 'js/muting.js',
|
2013-08-21 23:53:37 +02:00
|
|
|
Dict: 'js/dict.js'
|
2013-08-21 20:27:14 +02:00
|
|
|
});
|
|
|
|
|
2013-08-21 23:53:37 +02:00
|
|
|
var stream_data = require('js/stream_data.js');
|
|
|
|
|
|
|
|
stream_data = {
|
|
|
|
canonicalized_name: stream_data.canonicalized_name
|
|
|
|
};
|
|
|
|
set_global('stream_data', stream_data);
|
|
|
|
|
2013-08-07 23:56:51 +02:00
|
|
|
var Dict = global.Dict;
|
2013-09-28 00:00:44 +02:00
|
|
|
var muting = global.muting;
|
2013-08-01 17:53:10 +02:00
|
|
|
var unread = require('js/unread.js');
|
2013-07-28 18:40:50 +02:00
|
|
|
var assert = require('assert');
|
|
|
|
|
|
|
|
var narrow = {};
|
|
|
|
global.narrow = narrow;
|
|
|
|
|
|
|
|
var current_msg_list = {};
|
|
|
|
global.current_msg_list = current_msg_list;
|
|
|
|
|
|
|
|
var home_msg_list = {};
|
|
|
|
global.home_msg_list = home_msg_list;
|
|
|
|
|
|
|
|
var zero_counts = {
|
|
|
|
private_message_count: 0,
|
|
|
|
home_unread_messages: 0,
|
|
|
|
mentioned_message_count: 0,
|
2013-08-07 23:56:51 +02:00
|
|
|
stream_count: new Dict(),
|
|
|
|
subject_count: new Dict(),
|
|
|
|
pm_count: new Dict(),
|
2013-07-28 18:40:50 +02:00
|
|
|
unread_in_current_view: 0
|
|
|
|
};
|
|
|
|
|
|
|
|
(function test_empty_counts_while_narrowed() {
|
|
|
|
narrow.active = function () {
|
|
|
|
return true;
|
|
|
|
};
|
|
|
|
current_msg_list.all = function () {
|
|
|
|
return [];
|
|
|
|
};
|
|
|
|
|
|
|
|
var counts = unread.get_counts();
|
|
|
|
assert.deepEqual(counts, zero_counts);
|
|
|
|
}());
|
|
|
|
|
|
|
|
(function test_empty_counts_while_home() {
|
|
|
|
narrow.active = function () {
|
|
|
|
return false;
|
|
|
|
};
|
|
|
|
current_msg_list.all = function () {
|
|
|
|
return [];
|
|
|
|
};
|
|
|
|
|
|
|
|
var counts = unread.get_counts();
|
|
|
|
assert.deepEqual(counts, zero_counts);
|
|
|
|
}());
|
|
|
|
|
|
|
|
(function test_changing_subjects() {
|
|
|
|
// Summary: change the subject of a message from 'lunch'
|
|
|
|
// to 'dinner' using update_unread_subjects().
|
|
|
|
var count = unread.num_unread_for_subject('social', 'lunch');
|
|
|
|
assert.equal(count, 0);
|
|
|
|
|
|
|
|
var message = {
|
|
|
|
id: 15,
|
|
|
|
type: 'stream',
|
|
|
|
stream: 'social',
|
|
|
|
subject: 'lunch'
|
|
|
|
};
|
|
|
|
|
|
|
|
unread.process_loaded_messages([message]);
|
|
|
|
|
2013-08-23 04:49:56 +02:00
|
|
|
count = unread.num_unread_for_subject('Social', 'lunch');
|
2013-07-28 18:40:50 +02:00
|
|
|
assert.equal(count, 1);
|
|
|
|
|
|
|
|
var event = {
|
|
|
|
subject: 'dinner'
|
|
|
|
};
|
|
|
|
|
|
|
|
unread.update_unread_subjects(message, event);
|
|
|
|
|
|
|
|
count = unread.num_unread_for_subject('social', 'lunch');
|
|
|
|
assert.equal(count, 0);
|
|
|
|
|
|
|
|
count = unread.num_unread_for_subject('social', 'dinner');
|
|
|
|
assert.equal(count, 1);
|
|
|
|
|
|
|
|
// cleanup
|
|
|
|
message.subject = 'dinner';
|
|
|
|
unread.process_read_message(message);
|
|
|
|
count = unread.num_unread_for_subject('social', 'dinner');
|
|
|
|
assert.equal(count, 0);
|
|
|
|
}());
|
|
|
|
|
2013-09-28 00:00:44 +02:00
|
|
|
(function test_muting() {
|
|
|
|
stream_data.is_subscribed = function () {
|
|
|
|
return true;
|
|
|
|
};
|
|
|
|
|
|
|
|
stream_data.in_home_view = function () {
|
|
|
|
return true;
|
|
|
|
};
|
|
|
|
|
|
|
|
unread.declare_bankruptcy();
|
|
|
|
|
|
|
|
var message = {
|
|
|
|
id: 15,
|
|
|
|
type: 'stream',
|
|
|
|
stream: 'social',
|
|
|
|
subject: 'test_muting'
|
|
|
|
};
|
|
|
|
|
|
|
|
unread.process_loaded_messages([message]);
|
|
|
|
var counts = unread.get_counts();
|
|
|
|
assert.equal(counts.stream_count.get('social'), 1);
|
|
|
|
assert.equal(counts.home_unread_messages, 1);
|
|
|
|
|
|
|
|
muting.mute_topic('social', 'test_muting');
|
|
|
|
counts = unread.get_counts();
|
|
|
|
assert.equal(counts.stream_count.get('social'), 0);
|
|
|
|
assert.equal(counts.home_unread_messages, 0);
|
|
|
|
}());
|
|
|
|
|
2013-07-28 18:40:50 +02:00
|
|
|
(function test_num_unread_for_subject() {
|
|
|
|
// Test the num_unread_for_subject() function using many
|
|
|
|
// messages.
|
2013-09-28 00:00:44 +02:00
|
|
|
unread.declare_bankruptcy();
|
2013-07-28 18:40:50 +02:00
|
|
|
|
|
|
|
var count = unread.num_unread_for_subject('social', 'lunch');
|
|
|
|
assert.equal(count, 0);
|
|
|
|
|
|
|
|
var message = {
|
|
|
|
type: 'stream',
|
|
|
|
stream: 'social',
|
|
|
|
subject: 'lunch'
|
|
|
|
};
|
|
|
|
|
|
|
|
var num_msgs = 10000;
|
|
|
|
var i;
|
|
|
|
for (i = 0; i < num_msgs; ++i) {
|
|
|
|
message.id = i+1;
|
|
|
|
unread.process_loaded_messages([message]);
|
|
|
|
}
|
|
|
|
|
|
|
|
count = unread.num_unread_for_subject('social', 'lunch');
|
|
|
|
assert.equal(count, num_msgs);
|
|
|
|
|
|
|
|
for (i = 0; i < num_msgs; ++i) {
|
|
|
|
message.id = i+1;
|
|
|
|
unread.process_read_message(message);
|
|
|
|
}
|
|
|
|
|
|
|
|
count = unread.num_unread_for_subject('social', 'lunch');
|
|
|
|
assert.equal(count, 0);
|
|
|
|
}());
|
|
|
|
|
|
|
|
|
|
|
|
(function test_home_messages() {
|
|
|
|
narrow.active = function () {
|
|
|
|
return false;
|
|
|
|
};
|
2013-08-15 21:11:07 +02:00
|
|
|
stream_data.is_subscribed = function () {
|
2013-07-28 18:40:50 +02:00
|
|
|
return true;
|
|
|
|
};
|
2013-08-15 21:11:07 +02:00
|
|
|
stream_data.in_home_view = function () {
|
2013-07-28 18:40:50 +02:00
|
|
|
return true;
|
|
|
|
};
|
|
|
|
|
|
|
|
var message = {
|
|
|
|
id: 15,
|
|
|
|
type: 'stream',
|
|
|
|
stream: 'social',
|
|
|
|
subject: 'lunch'
|
|
|
|
};
|
|
|
|
|
|
|
|
home_msg_list.get = function (msg_id) {
|
|
|
|
return (msg_id === '15') ? message : undefined;
|
|
|
|
};
|
|
|
|
|
|
|
|
var counts = unread.get_counts();
|
|
|
|
assert.equal(counts.home_unread_messages, 0);
|
|
|
|
|
|
|
|
unread.process_loaded_messages([message]);
|
|
|
|
|
|
|
|
counts = unread.get_counts();
|
|
|
|
assert.equal(counts.home_unread_messages, 1);
|
2013-08-23 04:56:11 +02:00
|
|
|
assert.equal(counts.stream_count.get('social'), 1);
|
2013-07-28 18:40:50 +02:00
|
|
|
unread.process_read_message(message);
|
|
|
|
counts = unread.get_counts();
|
|
|
|
assert.equal(counts.home_unread_messages, 0);
|
2013-08-23 04:56:11 +02:00
|
|
|
|
|
|
|
unread.process_loaded_messages([message]);
|
|
|
|
counts = unread.get_counts();
|
|
|
|
assert.equal(counts.home_unread_messages, 1);
|
|
|
|
|
|
|
|
// Now unsubscribe all our streams.
|
|
|
|
stream_data.is_subscribed = function () {
|
|
|
|
return false;
|
|
|
|
};
|
|
|
|
counts = unread.get_counts();
|
|
|
|
assert.equal(counts.home_unread_messages, 0);
|
|
|
|
|
2013-07-28 18:40:50 +02:00
|
|
|
}());
|
|
|
|
|
2013-09-28 23:09:29 +02:00
|
|
|
(function test_phantom_messages() {
|
|
|
|
var message = {
|
|
|
|
id: 999,
|
|
|
|
type: 'stream',
|
|
|
|
stream: 'foo',
|
|
|
|
subject: 'phantom'
|
|
|
|
};
|
|
|
|
|
|
|
|
unread.process_read_message(message);
|
|
|
|
var counts = unread.get_counts();
|
|
|
|
assert.equal(counts.home_unread_messages, 0);
|
|
|
|
}());
|
|
|
|
|
2013-07-28 18:40:50 +02:00
|
|
|
(function test_private_messages() {
|
|
|
|
narrow.active = function () {
|
|
|
|
return false;
|
|
|
|
};
|
2013-08-15 21:11:07 +02:00
|
|
|
stream_data.is_subscribed = function () {
|
2013-07-28 18:40:50 +02:00
|
|
|
return true;
|
|
|
|
};
|
|
|
|
|
|
|
|
var counts = unread.get_counts();
|
|
|
|
assert.equal(counts.private_message_count, 0);
|
|
|
|
|
|
|
|
var message = {
|
|
|
|
id: 15,
|
2013-09-10 23:33:46 +02:00
|
|
|
type: 'private',
|
|
|
|
reply_to: 'alice@zulip.com'
|
2013-07-28 18:40:50 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
unread.process_loaded_messages([message]);
|
|
|
|
|
|
|
|
counts = unread.get_counts();
|
|
|
|
assert.equal(counts.private_message_count, 1);
|
|
|
|
unread.process_read_message(message);
|
|
|
|
counts = unread.get_counts();
|
|
|
|
assert.equal(counts.private_message_count, 0);
|
2013-09-27 23:39:12 +02:00
|
|
|
|
|
|
|
// Test unknown message is harmless
|
|
|
|
message = {
|
|
|
|
id: 9,
|
|
|
|
type: 'private',
|
|
|
|
reply_to: 'unknown@zulip.com'
|
|
|
|
};
|
|
|
|
|
|
|
|
unread.process_read_message(message);
|
|
|
|
counts = unread.get_counts();
|
|
|
|
assert.equal(counts.private_message_count, 0);
|
2013-07-28 18:40:50 +02:00
|
|
|
}());
|
|
|
|
|
2013-08-22 19:06:04 +02:00
|
|
|
(function test_num_unread_for_person() {
|
2013-09-10 23:33:46 +02:00
|
|
|
var email = 'unknown@zulip.com';
|
|
|
|
assert.equal(unread.num_unread_for_person(email), 0);
|
|
|
|
|
|
|
|
email = 'alice@zulip.com';
|
2013-08-22 19:06:04 +02:00
|
|
|
assert.equal(unread.num_unread_for_person(email), 0);
|
|
|
|
|
|
|
|
var message = {
|
|
|
|
id: 15,
|
|
|
|
reply_to: email,
|
|
|
|
type: 'private'
|
|
|
|
};
|
2013-08-23 03:23:08 +02:00
|
|
|
|
|
|
|
var read_message = {
|
|
|
|
flags: ['read']
|
|
|
|
};
|
|
|
|
unread.process_loaded_messages([message, read_message]);
|
2013-08-22 19:06:04 +02:00
|
|
|
assert.equal(unread.num_unread_for_person(email), 1);
|
|
|
|
}());
|
|
|
|
|
2013-07-28 18:40:50 +02:00
|
|
|
|
|
|
|
(function test_mentions() {
|
|
|
|
narrow.active = function () {
|
|
|
|
return false;
|
|
|
|
};
|
2013-08-15 21:11:07 +02:00
|
|
|
stream_data.is_subscribed = function () {
|
2013-07-28 18:40:50 +02:00
|
|
|
return true;
|
|
|
|
};
|
|
|
|
|
|
|
|
var counts = unread.get_counts();
|
|
|
|
assert.equal(counts.mentioned_message_count, 0);
|
|
|
|
|
|
|
|
var message = {
|
|
|
|
id: 15,
|
|
|
|
type: 'stream',
|
|
|
|
stream: 'social',
|
|
|
|
subject: 'lunch',
|
|
|
|
mentioned: true
|
|
|
|
};
|
|
|
|
|
|
|
|
unread.process_loaded_messages([message]);
|
|
|
|
|
|
|
|
counts = unread.get_counts();
|
|
|
|
assert.equal(counts.mentioned_message_count, 1);
|
|
|
|
unread.process_read_message(message);
|
|
|
|
counts = unread.get_counts();
|
|
|
|
assert.equal(counts.mentioned_message_count, 0);
|
|
|
|
}());
|
|
|
|
|
|
|
|
(function test_declare_bankruptcy() {
|
|
|
|
unread.declare_bankruptcy();
|
|
|
|
|
|
|
|
var counts = unread.get_counts();
|
|
|
|
assert.deepEqual(counts, zero_counts);
|
|
|
|
}());
|
|
|
|
|
|
|
|
(function test_num_unread_current_messages() {
|
|
|
|
var count = unread.num_unread_current_messages();
|
|
|
|
assert.equal(count, 0);
|
|
|
|
|
|
|
|
var message = {
|
|
|
|
id: 15
|
|
|
|
};
|
|
|
|
current_msg_list.all = function () {
|
|
|
|
return [message];
|
|
|
|
};
|
|
|
|
|
|
|
|
// It's a little suspicious that num_unread_current_messages()
|
|
|
|
// is using the pointer as a hint for filtering out unread
|
|
|
|
// messages, but right now, it's impossible for unread messages
|
|
|
|
// to be above the pointer in a narrowed view, so unread.js uses
|
|
|
|
// this for optimization purposes.
|
|
|
|
current_msg_list.selected_id = function () {
|
|
|
|
return 11; // less than our message's id
|
|
|
|
};
|
|
|
|
|
|
|
|
count = unread.num_unread_current_messages();
|
|
|
|
assert.equal(count, 1);
|
|
|
|
}());
|
|
|
|
|
2013-08-23 03:20:42 +02:00
|
|
|
|
|
|
|
(function test_message_unread() {
|
|
|
|
// Test some code that might be overly defensive, for line coverage sake.
|
|
|
|
assert(!unread.message_unread(undefined));
|
|
|
|
assert(unread.message_unread({flags: []}));
|
|
|
|
assert(!unread.message_unread({flags: ['read']}));
|
|
|
|
}());
|
|
|
|
|