zulip/frontend_tests/node_tests/server_events.js

151 lines
4.0 KiB
JavaScript

const noop = function () {};
set_global('document', {});
set_global('addEventListener', noop);
global.stub_out_jquery();
zrequire('message_store');
zrequire('server_events_dispatch');
zrequire('server_events');
zrequire('sent_messages');
set_global('channel', {});
set_global('home_msg_list', {
select_id: noop,
selected_id: function () {return 1;},
});
set_global('page_params', {test_suite: false});
set_global('reload_state', {
is_in_progress: function () {return false;},
});
// we also directly write to pointer
set_global('pointer', {});
set_global('echo', {
process_from_server: function (messages) {
return messages;
},
update_realm_filter_rules: noop,
});
set_global('ui_report', {
hide_error: function () { return false; },
show_error: function () { return false; },
});
server_events.home_view_loaded();
run_test('message_event', () => {
const event = {
type: 'message',
message: {
content: 'hello',
},
flags: [],
};
let inserted;
set_global('message_events', {
insert_new_messages: function (messages) {
assert.equal(messages[0].content, event.message.content);
inserted = true;
},
});
server_events._get_events_success([event]);
assert(inserted);
});
run_test('pointer_event', () => {
const event = {
type: 'pointer',
pointer: 999,
};
global.pointer.furthest_read = 0;
global.pointer.set_furthest_read = function (value) {
this.furthest_read = value;
};
global.pointer.server_furthest_read = 0;
global.pointer.set_server_furthest_read = function (value) {
this.server_furthest_read = value;
};
server_events._get_events_success([event]);
assert.equal(global.pointer.furthest_read, event.pointer);
assert.equal(global.pointer.server_furthest_read, event.pointer);
});
// Start blueslip tests here
const setup = function () {
server_events.home_view_loaded();
set_global('message_events', {
insert_new_messages: function () {
throw Error('insert error');
},
update_messages: function () {
throw Error('update error');
},
});
set_global('stream_events', {
update_property: function () {
throw Error('subs update error');
},
});
};
run_test('event_dispatch_error', () => {
setup();
const data = {events: [{type: 'stream', op: 'update', id: 1, other: 'thing'}]};
global.channel.get = function (options) {
options.success(data);
};
blueslip.expect('error', 'Failed to process an event\nsubs update error');
server_events.restart_get_events();
const logs = blueslip.get_test_logs('error');
assert.equal(logs.length, 1);
assert.equal(logs[0].more_info.event.type, 'stream');
assert.equal(logs[0].more_info.event.op, 'update');
assert.equal(logs[0].more_info.event.id, 1);
assert.equal(logs[0].more_info.other, undefined);
blueslip.reset();
});
run_test('event_new_message_error', () => {
setup();
const data = {events: [{type: 'message', id: 1, other: 'thing', message: {}}]};
global.channel.get = function (options) {
options.success(data);
};
blueslip.expect('error', 'Failed to insert new messages\ninsert error');
server_events.restart_get_events();
const logs = blueslip.get_test_logs('error');
assert.equal(logs.length, 1);
assert.equal(logs[0].more_info, undefined);
blueslip.reset();
});
run_test('event_edit_message_error', () => {
setup();
const data = {events: [{type: 'update_message', id: 1, other: 'thing'}]};
global.channel.get = function (options) {
options.success(data);
};
blueslip.expect('error', 'Failed to update messages\nupdate error');
server_events.restart_get_events();
const logs = blueslip.get_test_logs('error');
assert.equal(logs.length, 1);
assert.equal(logs[0].more_info, undefined);
blueslip.reset();
});