mirror of https://github.com/zulip/zulip.git
223 lines
7.1 KiB
JavaScript
223 lines
7.1 KiB
JavaScript
global.stub_out_jquery();
|
|
|
|
add_dependencies({
|
|
Handlebars: 'handlebars',
|
|
colorspace: 'js/colorspace',
|
|
hashchange: 'js/hashchange',
|
|
muting: 'js/muting',
|
|
narrow: 'js/narrow',
|
|
stream_color: 'js/stream_color',
|
|
stream_data: 'js/stream_data',
|
|
subs: 'js/subs',
|
|
templates: 'js/templates',
|
|
unread: 'js/unread',
|
|
util: 'js/util',
|
|
});
|
|
|
|
var stream_list = require('js/stream_list.js');
|
|
|
|
var jsdom = require("jsdom");
|
|
var window = jsdom.jsdom().defaultView;
|
|
global.$ = require('jquery')(window);
|
|
$.fn.expectOne = function () {
|
|
assert(this.length === 1);
|
|
return this;
|
|
};
|
|
|
|
global.compile_template('stream_sidebar_row');
|
|
global.compile_template('stream_privacy');
|
|
|
|
function clear_filters() {
|
|
var stream_search_box = $('<input class="stream-list-filter" type="text" placeholder="Search streams">');
|
|
var stream_filters = $('<ul id="stream_filters">');
|
|
$("body").empty();
|
|
$("body").append(stream_search_box);
|
|
$("body").append(stream_filters);
|
|
|
|
}
|
|
|
|
(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().
|
|
|
|
clear_filters();
|
|
|
|
var devel = {
|
|
name: 'devel',
|
|
stream_id: 100,
|
|
color: 'blue',
|
|
subscribed: true,
|
|
id: 5,
|
|
};
|
|
global.stream_data.add_sub('devel', devel);
|
|
|
|
var social = {
|
|
name: 'social',
|
|
stream_id: 200,
|
|
color: 'green',
|
|
subscribed: true,
|
|
id: 6,
|
|
};
|
|
global.stream_data.add_sub('social', social);
|
|
|
|
global.unread.num_unread_for_stream = function () {
|
|
return 42;
|
|
};
|
|
|
|
stream_list.create_sidebar_row(devel);
|
|
stream_list.create_sidebar_row(social);
|
|
stream_list.build_stream_list();
|
|
|
|
var html = $("body").html();
|
|
global.write_test_output("test_create_sidebar_row", html);
|
|
|
|
var li = stream_list.get_stream_li('social');
|
|
assert.equal(li.attr('data-name'), 'social');
|
|
assert.equal(li.find('.streamlist_swatch').attr('style'), 'background-color: green');
|
|
assert.equal(li.find('a.stream-name').text().trim(), 'social');
|
|
assert(li.find('.arrow').find("i").hasClass("icon-vector-chevron-down"));
|
|
|
|
global.append_test_output("Then make 'social' private.");
|
|
global.stream_data.get_sub('social').invite_only = true;
|
|
|
|
stream_list.redraw_stream_privacy('social');
|
|
|
|
html = $("body").html();
|
|
global.append_test_output(html);
|
|
|
|
assert(li.find('.stream-privacy').find("i").hasClass("icon-vector-lock"));
|
|
}());
|
|
|
|
|
|
(function test_sort_streams() {
|
|
clear_filters();
|
|
|
|
// pinned streams
|
|
var develSub = {
|
|
name: 'devel',
|
|
stream_id: 1000,
|
|
color: 'blue',
|
|
id: 5,
|
|
pin_to_top: true,
|
|
subscribed: true,
|
|
};
|
|
stream_list.create_sidebar_row(develSub);
|
|
global.stream_data.add_sub('devel', develSub);
|
|
|
|
var RomeSub = {
|
|
name: 'Rome',
|
|
stream_id: 2000,
|
|
color: 'blue',
|
|
id: 6,
|
|
pin_to_top: true,
|
|
subscribed: true,
|
|
};
|
|
stream_list.create_sidebar_row(RomeSub);
|
|
global.stream_data.add_sub('Rome', RomeSub);
|
|
|
|
var testSub = {
|
|
name: 'test',
|
|
stream_id: 3000,
|
|
color: 'blue',
|
|
id: 7,
|
|
pin_to_top: true,
|
|
subscribed: true,
|
|
};
|
|
stream_list.create_sidebar_row(testSub);
|
|
global.stream_data.add_sub('test', testSub);
|
|
|
|
// unpinned streams
|
|
var announceSub = {
|
|
name: 'announce',
|
|
stream_id: 4000,
|
|
color: 'green',
|
|
id: 8,
|
|
pin_to_top: false,
|
|
subscribed: true,
|
|
};
|
|
stream_list.create_sidebar_row(announceSub);
|
|
global.stream_data.add_sub('announce', announceSub);
|
|
|
|
var DenmarkSub = {
|
|
name: 'Denmark',
|
|
stream_id: 5000,
|
|
color: 'green',
|
|
id: 9,
|
|
pin_to_top: false,
|
|
subscribed: true,
|
|
};
|
|
stream_list.create_sidebar_row(DenmarkSub);
|
|
global.stream_data.add_sub('Denmark', DenmarkSub);
|
|
|
|
var socialSub = {
|
|
name: 'social',
|
|
stream_id: 6000,
|
|
color: 'green',
|
|
id: 10,
|
|
pin_to_top: false,
|
|
subscribed: true,
|
|
};
|
|
stream_list.create_sidebar_row(socialSub);
|
|
global.stream_data.add_sub('social', socialSub);
|
|
|
|
stream_list.build_stream_list();
|
|
|
|
// verify pinned streams are sorted by lowercase stream name
|
|
var devel_li = stream_list.stream_sidebar.get_row(develSub.stream_id).get_li();
|
|
assert.equal(devel_li.next().find('[ data-name="Rome"]').length, 1);
|
|
var Rome_li = stream_list.stream_sidebar.get_row(RomeSub.stream_id).get_li();
|
|
assert.equal(Rome_li.next().find('[ data-name="test"]').length, 1);
|
|
|
|
// verify unpinned streams are sorted by lowercase stream name
|
|
var announce_li = stream_list.stream_sidebar.get_row(announceSub.stream_id).get_li();
|
|
assert.equal(announce_li.next().find('[ data-name="Denmark"]').length, 1);
|
|
var Denmark_li = stream_list.stream_sidebar.get_row(DenmarkSub.stream_id).get_li();
|
|
assert.equal(Denmark_li.next().find('[ data-name="social"]').length, 1);
|
|
|
|
// verify pinned streams are sorted before unpinned streams
|
|
// i.e. the last pinned stream (testSub) is before the first unpinned stream (announceSub)
|
|
var test_li = stream_list.stream_sidebar.get_row(testSub.stream_id).get_li();
|
|
assert.equal(test_li.nextAll().find('[ data-name="announce"]').length, 1);
|
|
|
|
// add another 40 dummy unpinned streams since sort_recent is set to true only when
|
|
// there are more than 40 subscribed streams
|
|
for (var i = 1; i <= 40; i += 1) {
|
|
var dummyName = 'dummy' + i;
|
|
var dummySub = {
|
|
name: dummyName,
|
|
stream_id: 7000 + i,
|
|
color: 'green',
|
|
id: 11 + i,
|
|
pin_to_top: false,
|
|
subscribed: true,
|
|
};
|
|
stream_list.create_sidebar_row(dummySub);
|
|
global.stream_data.add_sub(dummyName, dummySub);
|
|
}
|
|
|
|
stream_data.populate_stream_topics_for_tests(
|
|
// testSub is pinned, DenmarkSub and socialSub are unpinned
|
|
_.object([testSub.name, socialSub.name, DenmarkSub.name], [testSub, socialSub, DenmarkSub])
|
|
);
|
|
|
|
stream_list.build_stream_list();
|
|
|
|
// verify pinned streams are still sorted by lowercase name
|
|
// i.e. not affected by sort_recent set to true
|
|
assert.equal(devel_li.next().find('[ data-name="Rome"]').length, 1);
|
|
assert.equal(Rome_li.next().find('[ data-name="test"]').length, 1);
|
|
|
|
// verify DenmarkSub and socialSub are sorted at the top of unpinned streams
|
|
// because they are active
|
|
assert.equal(Denmark_li.next().find('[ data-name="social"]').length, 1);
|
|
var social_li = stream_list.stream_sidebar.get_row(socialSub.stream_id).get_li();
|
|
assert.equal(social_li.next().find('[ data-name="announce"]').length, 1);
|
|
|
|
// verify inactive unpinned streams are still sorted by lowercase stream name
|
|
assert.equal(announce_li.next().find('[ data-name="dummy1"]').length, 1);
|
|
|
|
// verify pinned streams are still sorted before unpinned streams
|
|
// i.e. the last pinned stream (testSub) is before the first unpinned stream (socialSub)
|
|
assert.equal(test_li.nextAll().find('[ data-name="social"]').length, 1);
|
|
}());
|