mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-01-19 22:23:33 +01:00
915849b319
* lint: low hanging specs/alphabet.js * lint: low hanging specs/authorship_of_editions.js * lint: low hanging specs/bold.js * lint: low hanging specs/caret.js * lint: low hanging specs/change_user_color.js * lint: low hanging specs/change_user_name.js * lint: low hanging specs/chat.js * lint: low hanging specs/chat_load_messages.js * lint: low hanging specs/clear_authorship_colors.js * lint: low hanging specs/delete.js * lint: low hanging specs/drag_and_drop.js * lint: low hanging specs/embed_value.js * lint: low hanging specs/enter.js * lint: low hanging specs/font_type.js * lint: low hanging specs/helper.js * lint: low hanging specs/importexport.js * lint: low hanging specs/importindents.js * lint: low hanging specs/indentation.js * lint: low hanging specs/italic.js * lint: low hanging specs/language.js * lint: low hanging specs/multiple_authors_clear_authorship_colors.js * lint: low hanging specs/ordered_list.js * lint: low hanging specs/pad_modal.js * lint: low hanging specs/redo.js * lint: low hanging specs/responsiveness.js * lint: low hanging specs/select_formatting_buttons.js * lint: low hanging specs/strikethrough.js * lint: low hanging specs/timeslider.js * lint: low hanging specs/timeslider_labels.js * lint: low hanging specs/timeslider_numeric_padID.js * lint: low hanging specs/timeslider_revisions.js * lint: low hanging specs/undo.js * lint: low hanging specs/unordered_list.js * lint: low hanging specs/xxauto_reconnect.js * lint: attempt to do remote_runner.js * lint: helper linting * lint: rate limit linting * use constructor for Event to make eslint happier * for squash: lint fix refinements * for squash: lint fix refinements Co-authored-by: Richard Hansen <rhansen@rhansen.org>
135 lines
4 KiB
JavaScript
135 lines
4 KiB
JavaScript
'use strict';
|
|
|
|
describe('embed links', function () {
|
|
const objectify = function (str) {
|
|
const hash = {};
|
|
const parts = str.split('&');
|
|
for (let i = 0; i < parts.length; i++) {
|
|
const keyValue = parts[i].split('=');
|
|
hash[keyValue[0]] = keyValue[1];
|
|
}
|
|
return hash;
|
|
};
|
|
|
|
const checkiFrameCode = function (embedCode, readonly) {
|
|
// turn the code into an html element
|
|
const $embediFrame = $(embedCode);
|
|
|
|
// read and check the frame attributes
|
|
const width = $embediFrame.attr('width');
|
|
const height = $embediFrame.attr('height');
|
|
const name = $embediFrame.attr('name');
|
|
expect(width).to.be('100%');
|
|
expect(height).to.be('600');
|
|
expect(name).to.be(readonly ? 'embed_readonly' : 'embed_readwrite');
|
|
|
|
// parse the url
|
|
const src = $embediFrame.attr('src');
|
|
const questionMark = src.indexOf('?');
|
|
const url = src.substr(0, questionMark);
|
|
const paramsStr = src.substr(questionMark + 1);
|
|
const params = objectify(paramsStr);
|
|
|
|
const expectedParams = {
|
|
showControls: 'true',
|
|
showChat: 'true',
|
|
showLineNumbers: 'true',
|
|
useMonospaceFont: 'false',
|
|
};
|
|
|
|
// check the url
|
|
if (readonly) {
|
|
expect(url.indexOf('r.') > 0).to.be(true);
|
|
} else {
|
|
expect(url).to.be(helper.padChrome$.window.location.href);
|
|
}
|
|
|
|
// check if all parts of the url are like expected
|
|
expect(params).to.eql(expectedParams);
|
|
};
|
|
|
|
describe('read and write', function () {
|
|
// create a new pad before each test run
|
|
beforeEach(function (cb) {
|
|
helper.newPad(cb);
|
|
this.timeout(60000);
|
|
});
|
|
|
|
describe('the share link', function () {
|
|
it('is the actual pad url', function (done) {
|
|
const chrome$ = helper.padChrome$;
|
|
|
|
// open share dropdown
|
|
chrome$('.buttonicon-embed').click();
|
|
|
|
// get the link of the share field + the actual pad url and compare them
|
|
const shareLink = chrome$('#linkinput').val();
|
|
const padURL = chrome$.window.location.href;
|
|
expect(shareLink).to.be(padURL);
|
|
|
|
done();
|
|
});
|
|
});
|
|
|
|
describe('the embed as iframe code', function () {
|
|
it('is an iframe with the the correct url parameters and correct size', function (done) {
|
|
const chrome$ = helper.padChrome$;
|
|
|
|
// open share dropdown
|
|
chrome$('.buttonicon-embed').click();
|
|
|
|
// get the link of the share field + the actual pad url and compare them
|
|
const embedCode = chrome$('#embedinput').val();
|
|
|
|
checkiFrameCode(embedCode, false);
|
|
|
|
done();
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('when read only option is set', function () {
|
|
beforeEach(function (cb) {
|
|
helper.newPad(cb);
|
|
this.timeout(60000);
|
|
});
|
|
|
|
describe('the share link', function () {
|
|
it('shows a read only url', function (done) {
|
|
const chrome$ = helper.padChrome$;
|
|
|
|
// open share dropdown
|
|
chrome$('.buttonicon-embed').click();
|
|
chrome$('#readonlyinput').click();
|
|
chrome$('#readonlyinput:checkbox:not(:checked)').attr('checked', 'checked');
|
|
|
|
// get the link of the share field + the actual pad url and compare them
|
|
const shareLink = chrome$('#linkinput').val();
|
|
const containsReadOnlyLink = shareLink.indexOf('r.') > 0;
|
|
expect(containsReadOnlyLink).to.be(true);
|
|
|
|
done();
|
|
});
|
|
});
|
|
|
|
describe('the embed as iframe code', function () {
|
|
it('is an iframe with the the correct url parameters and correct size', function (done) {
|
|
const chrome$ = helper.padChrome$;
|
|
|
|
// open share dropdown
|
|
chrome$('.buttonicon-embed').click();
|
|
// check read only checkbox, a bit hacky
|
|
chrome$('#readonlyinput').click();
|
|
chrome$('#readonlyinput:checkbox:not(:checked)').attr('checked', 'checked');
|
|
|
|
|
|
// get the link of the share field + the actual pad url and compare them
|
|
const embedCode = chrome$('#embedinput').val();
|
|
|
|
checkiFrameCode(embedCode, true);
|
|
|
|
done();
|
|
});
|
|
});
|
|
});
|
|
});
|