mirror of
				https://github.com/zulip/zulip.git
				synced 2025-11-03 21:43:21 +00:00 
			
		
		
		
	frontend test: De-duplicate test.
Merged two tests since they both use the same test data. The file name of `presence_list_performance.js` also causes confusion as it is no longer use for performance testing.
This commit is contained in:
		@@ -4,14 +4,7 @@ set_global('page_params', {
 | 
				
			|||||||
    people_list: [],
 | 
					    people_list: [],
 | 
				
			||||||
});
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
add_dependencies({
 | 
					set_global('feature_flags', {});
 | 
				
			||||||
    util: 'js/util.js',
 | 
					 | 
				
			||||||
    people: 'js/people.js',
 | 
					 | 
				
			||||||
});
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
set_global('resize', {
 | 
					 | 
				
			||||||
    resize_page_components: function () {},
 | 
					 | 
				
			||||||
});
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
set_global('document', {
 | 
					set_global('document', {
 | 
				
			||||||
    hasFocus: function () {
 | 
					    hasFocus: function () {
 | 
				
			||||||
@@ -19,6 +12,20 @@ set_global('document', {
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
});
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					add_dependencies({
 | 
				
			||||||
 | 
					    Handlebars: 'handlebars',
 | 
				
			||||||
 | 
					    templates: 'js/templates',
 | 
				
			||||||
 | 
					    util: 'js/util.js',
 | 
				
			||||||
 | 
					    compose_fade: 'js/compose_fade.js',
 | 
				
			||||||
 | 
					    people: 'js/people.js',
 | 
				
			||||||
 | 
					    unread: 'js/unread.js',
 | 
				
			||||||
 | 
					    activity: 'js/activity.js',
 | 
				
			||||||
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					set_global('resize', {
 | 
				
			||||||
 | 
					    resize_page_components: function () {},
 | 
				
			||||||
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
var alice = {
 | 
					var alice = {
 | 
				
			||||||
    email: 'alice@zulip.com',
 | 
					    email: 'alice@zulip.com',
 | 
				
			||||||
    user_id: 1,
 | 
					    user_id: 1,
 | 
				
			||||||
@@ -51,20 +58,32 @@ global.people.add(jill);
 | 
				
			|||||||
global.people.add(mark);
 | 
					global.people.add(mark);
 | 
				
			||||||
global.people.add(norbert);
 | 
					global.people.add(norbert);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
var people = global.people;
 | 
					var people = global.people;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
var activity = require('js/activity.js');
 | 
					var activity = require('js/activity.js');
 | 
				
			||||||
 | 
					var compose_fade = require('js/compose_fade.js');
 | 
				
			||||||
 | 
					var jsdom = require('jsdom');
 | 
				
			||||||
 | 
					var window = jsdom.jsdom().defaultView;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					global.$ = require('jquery')(window);
 | 
				
			||||||
 | 
					$.fn.expectOne = function () {
 | 
				
			||||||
 | 
					    assert(this.length === 1);
 | 
				
			||||||
 | 
					    return this;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					compose_fade.update_faded_users = function () {};
 | 
				
			||||||
activity.update_huddles = function () {};
 | 
					activity.update_huddles = function () {};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					global.compile_template('user_presence_row');
 | 
				
			||||||
 | 
					global.compile_template('user_presence_rows');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
(function test_sort_users() {
 | 
					(function test_sort_users() {
 | 
				
			||||||
    var user_ids = [alice.user_id, fred.user_id, jill.user_id];
 | 
					    var user_ids = [alice.user_id, fred.user_id, jill.user_id];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    var user_info = {};
 | 
					    var user_info = {};
 | 
				
			||||||
    user_info[alice.user_id] = {status: 'inactive'};
 | 
					    user_info[alice.user_id] = { status: 'inactive' };
 | 
				
			||||||
    user_info[fred.user_id] = {status: 'active'};
 | 
					    user_info[fred.user_id] = { status: 'active' };
 | 
				
			||||||
    user_info[jill.user_id] = {status: 'active'};
 | 
					    user_info[jill.user_id] = { status: 'active' };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    activity._sort_users(user_ids, user_info);
 | 
					    activity._sort_users(user_ids, user_info);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -85,8 +104,7 @@ activity.update_huddles = function () {};
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    var old_timestamp = 1382479000;
 | 
					    var old_timestamp = 1382479000;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    var messages = [
 | 
					    var messages = [{
 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
            type: 'private',
 | 
					            type: 'private',
 | 
				
			||||||
            reply_to: huddle1,
 | 
					            reply_to: huddle1,
 | 
				
			||||||
            timestamp: timestamp1,
 | 
					            timestamp: timestamp1,
 | 
				
			||||||
@@ -165,10 +183,10 @@ activity.update_huddles = function () {};
 | 
				
			|||||||
    huddle = people.emails_strings_to_user_ids_string(huddle);
 | 
					    huddle = people.emails_strings_to_user_ids_string(huddle);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    var presence_list = {};
 | 
					    var presence_list = {};
 | 
				
			||||||
    presence_list[alice.user_id] = {status: 'active'};
 | 
					    presence_list[alice.user_id] = { status: 'active' };
 | 
				
			||||||
    presence_list[fred.user_id] = {status: 'idle'}; // counts as present
 | 
					    presence_list[fred.user_id] = { status: 'idle' }; // counts as present
 | 
				
			||||||
    // jill not in list
 | 
					    // jill not in list
 | 
				
			||||||
    presence_list[mark.user_id] = {status: 'offline'}; // does not count
 | 
					    presence_list[mark.user_id] = { status: 'offline' }; // does not count
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    assert.equal(
 | 
					    assert.equal(
 | 
				
			||||||
        activity.huddle_fraction_present(huddle, presence_list),
 | 
					        activity.huddle_fraction_present(huddle, presence_list),
 | 
				
			||||||
@@ -229,3 +247,94 @@ activity.update_huddles = function () {};
 | 
				
			|||||||
    assert.equal(status.status, "offline");
 | 
					    assert.equal(status.status, "offline");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}());
 | 
					}());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					activity.presence_info = {};
 | 
				
			||||||
 | 
					activity.presence_info[alice.user_id] = { status: activity.IDLE };
 | 
				
			||||||
 | 
					activity.presence_info[fred.user_id] = { status: activity.ACTIVE };
 | 
				
			||||||
 | 
					activity.presence_info[jill.user_id] = { status: activity.ACTIVE };
 | 
				
			||||||
 | 
					activity.presence_info[mark.user_id] = { status: activity.IDLE };
 | 
				
			||||||
 | 
					activity.presence_info[norbert.user_id] = { status: activity.ACTIVE };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(function test_presence_list_full_update() {
 | 
				
			||||||
 | 
					    var users = activity.update_users();
 | 
				
			||||||
 | 
					    assert.deepEqual(users, [{
 | 
				
			||||||
 | 
					            name: 'Fred Flintstone',
 | 
				
			||||||
 | 
					            user_id: fred.user_id,
 | 
				
			||||||
 | 
					            num_unread: 0,
 | 
				
			||||||
 | 
					            type: 'active',
 | 
				
			||||||
 | 
					            type_desc: 'is active',
 | 
				
			||||||
 | 
					            mobile: undefined
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					            name: 'Jill Hill',
 | 
				
			||||||
 | 
					            user_id: jill.user_id,
 | 
				
			||||||
 | 
					            num_unread: 0,
 | 
				
			||||||
 | 
					            type: 'active',
 | 
				
			||||||
 | 
					            type_desc: 'is active',
 | 
				
			||||||
 | 
					            mobile: undefined
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					            name: 'Norbert Oswald',
 | 
				
			||||||
 | 
					            user_id: norbert.user_id,
 | 
				
			||||||
 | 
					            num_unread: 0,
 | 
				
			||||||
 | 
					            type: 'active',
 | 
				
			||||||
 | 
					            type_desc: 'is active',
 | 
				
			||||||
 | 
					            mobile: undefined
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					            name: 'Alice Smith',
 | 
				
			||||||
 | 
					            user_id: alice.user_id,
 | 
				
			||||||
 | 
					            num_unread: 0,
 | 
				
			||||||
 | 
					            type: 'idle',
 | 
				
			||||||
 | 
					            type_desc: 'is not active',
 | 
				
			||||||
 | 
					            mobile: undefined
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					            name: 'Marky Mark',
 | 
				
			||||||
 | 
					            user_id: mark.user_id,
 | 
				
			||||||
 | 
					            num_unread: 0,
 | 
				
			||||||
 | 
					            type: 'idle',
 | 
				
			||||||
 | 
					            type_desc: 'is not active',
 | 
				
			||||||
 | 
					            mobile: undefined
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					    ]);
 | 
				
			||||||
 | 
					}());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(function test_presence_list_partial_update() {
 | 
				
			||||||
 | 
					    activity.presence_info[alice.user_id] = { status: 'active' };
 | 
				
			||||||
 | 
					    activity.presence_info[mark.user_id] = { status: 'active' };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    var users = {};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    users[alice.user_id] = { status: 'active' };
 | 
				
			||||||
 | 
					    users = activity.update_users(users);
 | 
				
			||||||
 | 
					    assert.deepEqual(users, [{
 | 
				
			||||||
 | 
					        name: 'Alice Smith',
 | 
				
			||||||
 | 
					        user_id: alice.user_id,
 | 
				
			||||||
 | 
					        num_unread: 0,
 | 
				
			||||||
 | 
					        type: 'active',
 | 
				
			||||||
 | 
					        type_desc: 'is active',
 | 
				
			||||||
 | 
					        mobile: undefined
 | 
				
			||||||
 | 
					    }, ]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Test if user index in presence_info is the expected one
 | 
				
			||||||
 | 
					    var all_users = activity._filter_and_sort(activity.presence_info);
 | 
				
			||||||
 | 
					    assert.equal(all_users.indexOf(alice.user_id.toString()), 0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Test another user
 | 
				
			||||||
 | 
					    users = {};
 | 
				
			||||||
 | 
					    users[mark.user_id] = { status: 'active' };
 | 
				
			||||||
 | 
					    users = activity.update_users(users);
 | 
				
			||||||
 | 
					    assert.deepEqual(users, [{
 | 
				
			||||||
 | 
					        name: 'Marky Mark',
 | 
				
			||||||
 | 
					        user_id: mark.user_id,
 | 
				
			||||||
 | 
					        num_unread: 0,
 | 
				
			||||||
 | 
					        type: 'active',
 | 
				
			||||||
 | 
					        type_desc: 'is active',
 | 
				
			||||||
 | 
					        mobile: undefined
 | 
				
			||||||
 | 
					    }, ]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    all_users = activity._filter_and_sort(activity.presence_info);
 | 
				
			||||||
 | 
					    assert.equal(all_users.indexOf(mark.user_id.toString()), 3);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					}());
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,155 +0,0 @@
 | 
				
			|||||||
// TODO: de-dup with activity.js
 | 
					 | 
				
			||||||
global.stub_out_jquery();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
set_global('document', {
 | 
					 | 
				
			||||||
    hasFocus: function () {
 | 
					 | 
				
			||||||
        return true;
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
});
 | 
					 | 
				
			||||||
set_global('feature_flags', {});
 | 
					 | 
				
			||||||
set_global('page_params', {});
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
add_dependencies({
 | 
					 | 
				
			||||||
   Handlebars: 'handlebars',
 | 
					 | 
				
			||||||
   templates: 'js/templates',
 | 
					 | 
				
			||||||
   util: 'js/util.js',
 | 
					 | 
				
			||||||
   compose_fade: 'js/compose_fade.js',
 | 
					 | 
				
			||||||
   people: 'js/people.js',
 | 
					 | 
				
			||||||
   unread: 'js/unread.js',
 | 
					 | 
				
			||||||
   activity: 'js/activity.js',
 | 
					 | 
				
			||||||
});
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
var compose_fade = require('js/compose_fade.js');
 | 
					 | 
				
			||||||
compose_fade.update_faded_users = function () {
 | 
					 | 
				
			||||||
   return;
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
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('user_presence_row');
 | 
					 | 
				
			||||||
global.compile_template('user_presence_rows');
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
var activity = require('js/activity.js');
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// TODO: de-dup with activity.js
 | 
					 | 
				
			||||||
var alice = {
 | 
					 | 
				
			||||||
    email: 'alice@zulip.com',
 | 
					 | 
				
			||||||
    user_id: 1,
 | 
					 | 
				
			||||||
    full_name: 'Alice Smith',
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
var fred = {
 | 
					 | 
				
			||||||
    email: 'fred@zulip.com',
 | 
					 | 
				
			||||||
    user_id: 2,
 | 
					 | 
				
			||||||
    full_name: "Fred Flintstone",
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
var jill = {
 | 
					 | 
				
			||||||
    email: 'jill@zulip.com',
 | 
					 | 
				
			||||||
    user_id: 3,
 | 
					 | 
				
			||||||
    full_name: 'Jill Hill',
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
var mark = {
 | 
					 | 
				
			||||||
    email: 'mark@zulip.com',
 | 
					 | 
				
			||||||
    user_id: 4,
 | 
					 | 
				
			||||||
    full_name: 'Marky Mark',
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
var norbert = {
 | 
					 | 
				
			||||||
    email: 'norbert@zulip.com',
 | 
					 | 
				
			||||||
    user_id: 5,
 | 
					 | 
				
			||||||
    full_name: 'Norbert Oswald',
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
global.people.add(alice);
 | 
					 | 
				
			||||||
global.people.add(fred);
 | 
					 | 
				
			||||||
global.people.add(jill);
 | 
					 | 
				
			||||||
global.people.add(mark);
 | 
					 | 
				
			||||||
global.people.add(norbert);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
activity.presence_info = {};
 | 
					 | 
				
			||||||
activity.presence_info[alice.user_id] = {status: activity.IDLE};
 | 
					 | 
				
			||||||
activity.presence_info[fred.user_id] = {status: activity.ACTIVE};
 | 
					 | 
				
			||||||
activity.presence_info[jill.user_id] = {status: activity.ACTIVE};
 | 
					 | 
				
			||||||
activity.presence_info[mark.user_id] = {status: activity.IDLE};
 | 
					 | 
				
			||||||
activity.presence_info[norbert.user_id] = {status: activity.ACTIVE};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// console.info(activity.presence_info);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
(function test_presence_list_full_update() {
 | 
					 | 
				
			||||||
    var users = activity.update_users();
 | 
					 | 
				
			||||||
    assert.deepEqual(users, [
 | 
					 | 
				
			||||||
        { name: 'Fred Flintstone',
 | 
					 | 
				
			||||||
          user_id: fred.user_id,
 | 
					 | 
				
			||||||
          num_unread: 0,
 | 
					 | 
				
			||||||
          type: 'active',
 | 
					 | 
				
			||||||
          type_desc: 'is active',
 | 
					 | 
				
			||||||
          mobile: undefined },
 | 
					 | 
				
			||||||
        { name: 'Jill Hill',
 | 
					 | 
				
			||||||
          user_id: jill.user_id,
 | 
					 | 
				
			||||||
          num_unread: 0,
 | 
					 | 
				
			||||||
          type: 'active',
 | 
					 | 
				
			||||||
          type_desc: 'is active',
 | 
					 | 
				
			||||||
          mobile: undefined },
 | 
					 | 
				
			||||||
        { name: 'Norbert Oswald',
 | 
					 | 
				
			||||||
          user_id: norbert.user_id,
 | 
					 | 
				
			||||||
          num_unread: 0,
 | 
					 | 
				
			||||||
          type: 'active',
 | 
					 | 
				
			||||||
          type_desc: 'is active',
 | 
					 | 
				
			||||||
          mobile: undefined },
 | 
					 | 
				
			||||||
        { name: 'Alice Smith',
 | 
					 | 
				
			||||||
          user_id: alice.user_id,
 | 
					 | 
				
			||||||
          num_unread: 0,
 | 
					 | 
				
			||||||
          type: 'idle',
 | 
					 | 
				
			||||||
          type_desc: 'is not active',
 | 
					 | 
				
			||||||
          mobile: undefined },
 | 
					 | 
				
			||||||
        { name: 'Marky Mark',
 | 
					 | 
				
			||||||
          user_id: mark.user_id,
 | 
					 | 
				
			||||||
          num_unread: 0,
 | 
					 | 
				
			||||||
          type: 'idle',
 | 
					 | 
				
			||||||
          type_desc: 'is not active',
 | 
					 | 
				
			||||||
          mobile: undefined },
 | 
					 | 
				
			||||||
    ]);
 | 
					 | 
				
			||||||
}());
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
(function test_presence_list_partial_update() {
 | 
					 | 
				
			||||||
    activity.presence_info[alice.user_id] = {status: 'active'};
 | 
					 | 
				
			||||||
    activity.presence_info[mark.user_id] = {status: 'active'};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    var users = {};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    users[alice.user_id] = {status: 'active'};
 | 
					 | 
				
			||||||
    users = activity.update_users(users);
 | 
					 | 
				
			||||||
    assert.deepEqual(users, [
 | 
					 | 
				
			||||||
        { name: 'Alice Smith',
 | 
					 | 
				
			||||||
          user_id: alice.user_id,
 | 
					 | 
				
			||||||
          num_unread: 0,
 | 
					 | 
				
			||||||
          type: 'active',
 | 
					 | 
				
			||||||
          type_desc: 'is active',
 | 
					 | 
				
			||||||
          mobile: undefined },
 | 
					 | 
				
			||||||
    ]);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    // Test if user index in presence_info is the expected one
 | 
					 | 
				
			||||||
    var all_users = activity._filter_and_sort(activity.presence_info);
 | 
					 | 
				
			||||||
    assert.equal(all_users.indexOf(alice.user_id.toString()), 0);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    // Test another user
 | 
					 | 
				
			||||||
    users = {};
 | 
					 | 
				
			||||||
    users[mark.user_id] = {status: 'active'};
 | 
					 | 
				
			||||||
    users = activity.update_users(users);
 | 
					 | 
				
			||||||
    assert.deepEqual(users, [
 | 
					 | 
				
			||||||
        { name: 'Marky Mark',
 | 
					 | 
				
			||||||
          user_id: mark.user_id,
 | 
					 | 
				
			||||||
          num_unread: 0,
 | 
					 | 
				
			||||||
          type: 'active',
 | 
					 | 
				
			||||||
          type_desc: 'is active',
 | 
					 | 
				
			||||||
          mobile: undefined },
 | 
					 | 
				
			||||||
    ]);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    all_users = activity._filter_and_sort(activity.presence_info);
 | 
					 | 
				
			||||||
    assert.equal(all_users.indexOf(mark.user_id.toString()), 3);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
}());
 | 
					 | 
				
			||||||
		Reference in New Issue
	
	Block a user