mirror of https://github.com/zulip/zulip.git
node tests: Use stubs in lightbox tests.
We stub out jquery elements rather than giving the illusion of having real DOM. Also, we make it so that the message_store interaction has an assertion attached to it.
This commit is contained in:
parent
c4e3cfebb0
commit
8f0018ee7c
|
@ -2,10 +2,7 @@ zrequire('lightbox');
|
|||
|
||||
set_global('blueslip', global.make_zblueslip());
|
||||
|
||||
const _message_store = new Map();
|
||||
_message_store.set(1234, { sender_full_name: "Test User" });
|
||||
|
||||
set_global('message_store', _message_store);
|
||||
set_global('message_store', {});
|
||||
set_global('Image', class Image {});
|
||||
set_global('overlays', {
|
||||
close_overlay: () => {},
|
||||
|
@ -21,48 +18,59 @@ set_global('$', global.make_zjquery());
|
|||
run_test('pan_and_zoom', () => {
|
||||
$.clear_all_elements();
|
||||
|
||||
const img = '<img src="./image.png" data-src-fullsize="./original.png">';
|
||||
const link = '<a href="https://zulip.com"></a>';
|
||||
const img = $.create('img-stub');
|
||||
const link = $.create('link-stub');
|
||||
const msg = $.create('msg-stub');
|
||||
|
||||
/* Due to how zquery works, we have to use a literal [zid] in the element,
|
||||
since that's what the code looks for and we have to manually set the attr
|
||||
that should be returned from the store. */
|
||||
const msg = $('<div [zid]></div>');
|
||||
$(img).closest = () => [];
|
||||
|
||||
img.set_parent(link);
|
||||
link.closest = () => msg;
|
||||
msg.attr("zid", "1234");
|
||||
$(img).set_parent($(link));
|
||||
$(link).set_parent(msg);
|
||||
|
||||
let fetched_zid;
|
||||
|
||||
message_store.get = (zid) => {
|
||||
fetched_zid = zid;
|
||||
return 'message-stub';
|
||||
};
|
||||
|
||||
// Used by render_lightbox_list_images
|
||||
$.stub_selector('.focused_table .message_inline_image img', []);
|
||||
|
||||
lightbox.open(img);
|
||||
assert.equal(blueslip.get_test_logs('error').length, 0);
|
||||
lightbox.open('<img src="./image.png">');
|
||||
assert.equal(blueslip.get_test_logs('error').length, 0);
|
||||
|
||||
assert.equal(fetched_zid, 1234);
|
||||
});
|
||||
|
||||
run_test('open_url', () => {
|
||||
run_test('youtube', () => {
|
||||
$.clear_all_elements();
|
||||
|
||||
const url = 'https://youtube.com/1234';
|
||||
const img = '<img></img>';
|
||||
$(img).attr('src', "https://youtube.com/image.png");
|
||||
const link = '<a></a>';
|
||||
$(link).attr('href', url);
|
||||
const div = '<div class="youtube-video"></div>';
|
||||
/* Due to how zquery works, we have to use a literal [zid] in the element,
|
||||
since that's what the code looks for and we have to manually set the attr
|
||||
that should be returned from the store. */
|
||||
const msg = $('<div [zid]></div>');
|
||||
msg.attr("zid", "1234");
|
||||
$(img).set_parent($(link));
|
||||
$(link).set_parent($(div));
|
||||
$(div).set_parent(msg);
|
||||
const href = 'https://youtube.com/some-random-clip';
|
||||
const img = $.create('img-stub');
|
||||
const link = $.create('link-stub');
|
||||
const msg = $.create('msg-stub');
|
||||
|
||||
$(img).attr('src', href);
|
||||
|
||||
$(img).closest = (sel) => {
|
||||
if (sel === '.youtube-video') {
|
||||
// We just need a nonempty array to
|
||||
// set is_youtube_video to true.
|
||||
return ['whatever'];
|
||||
}
|
||||
return [];
|
||||
};
|
||||
|
||||
img.set_parent(link);
|
||||
link.closest = () => msg;
|
||||
link.attr('href', href);
|
||||
|
||||
// Used by render_lightbox_list_images
|
||||
$.stub_selector('.focused_table .message_inline_image img', []);
|
||||
|
||||
lightbox.open(img);
|
||||
assert.equal($('.image-actions .open').attr('href'), url);
|
||||
assert.equal($('.image-actions .open').attr('href'), href);
|
||||
assert.equal(blueslip.get_test_logs('error').length, 0);
|
||||
});
|
||||
|
|
Loading…
Reference in New Issue