zulip/frontend_tests/node_tests/stream_list.js

466 lines
12 KiB
JavaScript

set_global('$', global.make_zjquery());
set_global('templates', {});
add_dependencies({
colorspace: 'js/colorspace',
Filter: 'js/filter',
hash_util: 'js/hash_util',
narrow: 'js/narrow',
stream_color: 'js/stream_color',
stream_data: 'js/stream_data',
stream_sort: 'js/stream_sort',
unread: 'js/unread',
unread_ui: 'js/unread_ui',
util: 'js/util',
});
var stream_list = require('js/stream_list.js');
var noop = function () {};
var return_false = function () { return false; };
var return_true = function () { return true; };
set_global('topic_list', {});
(function test_create_sidebar_row() {
// Make a couple calls to create_sidebar_row() and make sure they
// generate the right markup as well as play nice with get_stream_li().
var devel = {
name: 'devel',
stream_id: 100,
color: 'blue',
subscribed: true,
};
global.stream_data.add_sub('devel', devel);
var social = {
name: 'social',
stream_id: 200,
color: 'green',
subscribed: true,
};
global.stream_data.add_sub('social', social);
global.unread.num_unread_for_stream = function () {
return 42;
};
(function create_devel_sidebar_row() {
var devel_value = $('devel-value');
var devel_count = $('devel-count');
$('devel-stub-html').add_child('.count', devel_count);
$('devel-count').add_child('.value', devel_value);
global.templates.render = function (template_name, data) {
assert.equal(template_name, 'stream_sidebar_row');
assert.equal(data.uri, '#narrow/stream/devel');
return 'devel-stub-html';
};
stream_list.create_sidebar_row(devel);
assert.equal(devel_value.text(), '42');
}());
(function create_social_sidebar_row() {
var social_value = $('social-value');
var social_count = $('social-count');
$('social-stub-html').add_child('.count', social_count);
$('social-count').add_child('.value', social_value);
global.templates.render = function (template_name, data) {
assert.equal(template_name, 'stream_sidebar_row');
assert.equal(data.uri, '#narrow/stream/social');
return 'social-stub-html';
};
stream_list.create_sidebar_row(social);
assert.equal(social_value.text(), '42');
}());
function set_getter(elem, stub_value) {
elem.get = function (idx) {
assert.equal(idx, 0);
return stub_value;
};
}
set_getter($('<hr class="stream-split">'), 'split');
set_getter($('devel-stub-html'), 'devel-sidebar');
set_getter($('social-stub-html'), 'social-sidebar');
var appended_elems;
$('#stream_filters').append = function (elems) {
appended_elems = elems;
};
stream_list.build_stream_list();
var expected_elems = [
'split',
'devel-sidebar',
'social-sidebar',
];
assert.deepEqual(appended_elems, expected_elems);
var social_li = $('social-stub-html');
var stream_id = social.stream_id;
var privacy_elem = $('privacy-stub');
social_li.add_child('.stream-privacy', privacy_elem);
social.invite_only = true;
social.color = '#222222';
global.templates.render = function (template_name, data) {
assert.equal(template_name, 'stream_privacy');
assert.equal(data.invite_only, true);
assert.equal(data.dark_background, 'dark_background');
return '<div>privacy-html';
};
stream_list.redraw_stream_privacy(social);
assert.equal(privacy_elem.html(), '<div>privacy-html');
stream_list.set_in_home_view(stream_id, false);
assert(social_li.hasClass('out_of_home_view'));
stream_list.set_in_home_view(stream_id, true);
assert(!social_li.hasClass('out_of_home_view'));
var row = stream_list.stream_sidebar.get_row(stream_id);
stream_data.is_active = return_true;
row.update_whether_active();
assert(!social_li.hasClass('inactive_stream'));
stream_data.is_active = return_false;
row.update_whether_active();
assert(social_li.hasClass('inactive_stream'));
var removed;
social_li.remove = function () {
removed = true;
};
row.remove();
assert(removed);
}());
function initialize_stream_data() {
stream_data.clear_subscriptions();
function add_row(sub) {
global.stream_data.add_sub(sub.name, sub);
var row = {
update_whether_active: function () {},
get_li: function () {
var selector = 'stub-' + sub.name;
return $(selector);
},
};
stream_list.stream_sidebar.set_row(sub.stream_id, row);
}
// pinned streams
var develSub = {
name: 'devel',
stream_id: 1000,
color: 'blue',
pin_to_top: true,
subscribed: true,
};
add_row(develSub);
var RomeSub = {
name: 'Rome',
stream_id: 2000,
color: 'blue',
pin_to_top: true,
subscribed: true,
};
add_row(RomeSub);
var testSub = {
name: 'test',
stream_id: 3000,
color: 'blue',
pin_to_top: true,
subscribed: true,
};
add_row(testSub);
// unpinned streams
var announceSub = {
name: 'announce',
stream_id: 4000,
color: 'green',
pin_to_top: false,
subscribed: true,
};
add_row(announceSub);
var DenmarkSub = {
name: 'Denmark',
stream_id: 5000,
color: 'green',
pin_to_top: false,
subscribed: true,
};
add_row(DenmarkSub);
var carSub = {
name: 'cars',
stream_id: 6000,
color: 'green',
pin_to_top: false,
subscribed: true,
};
add_row(carSub);
}
(function test_narrowing() {
initialize_stream_data();
var document = 'document-stub';
set_global('document', document);
set_global('narrow_state', {
stream: function () { return 'devel'; },
topic: noop,
});
var pm_expanded;
set_global('pm_list', {
close: noop,
expand: function () { pm_expanded = true; },
});
topic_list.set_click_handlers = noop;
topic_list.is_zoomed = return_false;
topic_list.remove_expanded_topics = noop;
topic_list.rebuild = noop;
stream_list.scroll_element_into_container = noop;
assert(!$('stub-devel').hasClass('active-filter'));
stream_list.initialize();
function activate_filter(filter) {
var data = {
filter: filter,
};
$(document).trigger($.Event('narrow_activated.zulip', data));
}
var filter;
filter = new Filter([
{operator: 'stream', operand: 'devel'},
]);
activate_filter(filter);
assert($('stub-devel').hasClass('active-filter'));
filter = new Filter([
{operator: 'stream', operand: 'cars'},
{operator: 'topic', operand: 'sedans'},
]);
activate_filter(filter);
assert(!$("ul.filters li").hasClass('active-filter'));
assert(!$('stub-cars').hasClass('active-filter')); // false because of topic
assert(!pm_expanded);
filter = new Filter([
{operator: 'is', operand: 'private'},
]);
activate_filter(filter);
assert(pm_expanded);
filter = new Filter([
{operator: 'is', operand: 'mentioned'},
]);
activate_filter(filter);
assert(stream_list.get_global_filter_li('mentioned').hasClass('active-filter'));
filter = new Filter([
{operator: 'in', operand: 'home'},
]);
activate_filter(filter);
assert(stream_list.get_global_filter_li('home').hasClass('active-filter'));
filter = new Filter([
{operator: 'stream', operand: 'cars'},
]);
activate_filter(filter);
assert(!$("ul.filters li").hasClass('active-filter'));
assert($('stub-cars').hasClass('active-filter'));
}());
(function test_sort_streams() {
stream_data.clear_subscriptions();
// Get coverage on early-exit.
stream_list.build_stream_list();
initialize_stream_data();
global.stream_data.is_active = function (sub) {
return sub.name !== 'cars';
};
var appended_elems;
$('#stream_filters').append = function (elems) {
appended_elems = elems;
};
stream_list.build_stream_list();
var expected_elems = [
'stub-devel',
'stub-Rome',
'stub-test',
'split',
'stub-announce',
'stub-Denmark',
'split',
'stub-cars',
];
assert.deepEqual(appended_elems, expected_elems);
var streams = global.stream_sort.get_streams();
assert.deepEqual(streams, [
// three groups: pinned, normal, dormant
'devel',
'Rome',
'test',
//
'announce',
'Denmark',
//
'cars',
]);
var denmark_sub = stream_data.get_sub('Denmark');
var stream_id = denmark_sub.stream_id;
assert(stream_list.stream_sidebar.has_row_for(stream_id));
stream_list.remove_sidebar_row(stream_id);
assert(!stream_list.stream_sidebar.has_row_for(stream_id));
}());
(function test_update_count_in_dom() {
function make_elem(elem_selector, count_selector, value_selector) {
var elem = $(elem_selector);
var count = $(count_selector);
var value = $(value_selector);
elem.add_child('.count', count);
count.add_child('.value', value);
return elem;
}
var stream_li = make_elem(
'stream-li',
'stream-count',
'stream-value'
);
stream_li.addClass('subscription_block');
stream_li.addClass('stream-with-count');
assert(stream_li.hasClass('stream-with-count'));
make_elem(
"#global_filters li[data-name='mentioned']",
'mentioned-count',
'mentioned-value'
);
make_elem(
"#global_filters li[data-name='home']",
'home-count',
'home-value'
);
unread_ui.set_count_toggle_button = noop;
var stream_count = new Dict();
var stream_id = 11;
var stream_row = {
get_li: function () { return stream_li; },
};
stream_list.stream_sidebar.set_row(stream_id, stream_row);
stream_count.set(stream_id, 0);
var counts = {
stream_count: stream_count,
subject_count: new Dict(),
mentioned_message_count: 222,
home_unread_messages: 333,
};
stream_list.update_dom_with_unread_counts(counts);
assert.equal($('stream-value').text(), '');
assert(!stream_li.hasClass('stream-with-count'));
assert.equal($('mentioned-value').text(), '222');
assert.equal($('home-value').text(), '333');
stream_count.set(stream_id, 99);
stream_list.update_dom_with_unread_counts(counts);
assert.equal($('stream-value').text(), '99');
assert(stream_li.hasClass('stream-with-count'));
var topic_results;
topic_list.set_count = function (stream_id, topic, count) {
topic_results = {
stream_id: stream_id,
topic: topic,
count: count,
};
};
var topic_count = new Dict({fold_case: true});
topic_count.set('lunch', '555');
counts.subject_count.set(stream_id, topic_count);
stream_list.update_dom_with_unread_counts(counts);
assert.deepEqual(topic_results, {
stream_id: stream_id,
topic: 'lunch',
count: 555,
});
}());
(function test_create_initial_sidebar_rows() {
initialize_stream_data();
var html_dict = new Dict();
stream_list.stream_sidebar = {
has_row_for: return_false,
set_row: function (stream_id, widget) {
html_dict.set(stream_id, widget.get_li().html());
},
};
stream_list.update_count_in_dom = noop;
global.templates.render = function (template_name, data) {
assert.equal(template_name, 'stream_sidebar_row');
return '<div>stub-html-' + data.name;
};
// Test this code with stubs above...
stream_list.create_initial_sidebar_rows();
assert.equal(html_dict.get(1000), '<div>stub-html-devel');
assert.equal(html_dict.get(5000), '<div>stub-html-Denmark');
}());