cryptpad/www/assert/main.js

351 lines
12 KiB
JavaScript
Raw Normal View History

define([
'jquery',
'/bower_components/hyperjson/hyperjson.js',
2016-04-21 13:05:41 +00:00
'json.sortify',
2017-06-08 16:14:31 +00:00
'/drive/tests.js',
2017-09-05 09:24:30 +00:00
'/common/test.js',
2017-11-13 15:32:40 +00:00
'/common/common-hash.js',
2017-09-05 09:24:30 +00:00
'/common/common-thumbnail.js',
'/common/flat-dom.js',
2017-11-27 12:45:40 +00:00
], function ($, Hyperjson, Sortify, Drive, Test, Hash, Thumb, Flat) {
window.Hyperjson = Hyperjson;
2016-04-21 13:05:41 +00:00
window.Sortify = Sortify;
var assertions = 0;
2016-04-13 14:10:38 +00:00
var failed = false;
var failedOn;
var failMessages = [];
var ASSERTS = [];
2017-05-10 09:54:21 +00:00
var runASSERTS = function (cb) {
var count = ASSERTS.length;
var successes = 0;
2017-05-10 13:36:34 +00:00
var done = function (err) {
2017-05-10 09:54:21 +00:00
count--;
if (err) { failMessages.push(err); }
else { successes++; }
if (count === 0) { cb(); }
};
ASSERTS.forEach(function (f, index) {
2017-05-10 09:54:21 +00:00
f(function (err) {
console.log("test " + index);
2017-05-10 09:54:21 +00:00
done(err, index);
}, index);
});
};
var assert = function (test, msg) {
2017-05-10 09:54:21 +00:00
ASSERTS.push(function (cb, i) {
test(function (result) {
if (result === true) {
assertions++;
cb();
} else {
failed = true;
failedOn = assertions;
cb({
test: i,
message: msg,
output: result,
});
}
});
});
};
2016-04-21 13:05:41 +00:00
var HJSON_list = [
'["DIV",{"id":"target"},[["P",{"class":" alice bob charlie has.dot","id":"bang"},["pewpewpew"]]]]',
2016-04-21 13:05:41 +00:00
'["DIV",{"id":"quot"},[["P",{},["\\"pewpewpew\\""]]]]',
2016-04-21 13:05:41 +00:00
'["DIV",{"id":"widget"},[["DIV",{"class":"cke_widget_wrapper cke_widget_block","contenteditable":"false","data-cke-display-name":"macro:velocity","data-cke-filter":"off","data-cke-widget-id":"0","data-cke-widget-wrapper":"1","tabindex":"-1"},[["DIV",{"class":"macro cke_widget_element","data-cke-widget-data":"%7B%22classes%22%3A%7B%22macro%22%3A1%7D%7D","data-cke-widget-keep-attr":"0","data-cke-widget-upcasted":"1","data-macro":"startmacro:velocity|-||-|Here is a macro","data-widget":"xwiki-macro"},[["P",{},["Here is a macro"]]]],["SPAN",{"class":"cke_reset cke_widget_drag_handler_container","style":"background: rgba(220, 220, 220, 0.5) url(\\"/customize/cryptofist_small.png\\") repeat scroll 0% 0%; top: -15px; left: 0px; display: block;"},[["IMG",{"class":"cke_reset cke_widget_drag_handler","data-cke-widget-drag-handler":"1","height":"15","src":"data:image/gif;base64,R0lGODlhAQABAPABAP///wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==","title":"Click and drag to move","width":"15"},[]]]]]]]]',
2016-04-21 13:05:41 +00:00
];
var elementFilter = function () {
// pass everything
return true;
};
var attributeFilter = function (h) {
// don't filter anything
return h;
};
var HJSON_equal = function (shjson) {
2017-05-10 09:54:21 +00:00
assert(function (cb) {
2016-04-21 13:05:41 +00:00
// parse your stringified Hyperjson
var hjson;
try {
hjson = JSON.parse(shjson);
} catch (e) {
console.log(e);
return false;
}
// turn it into a DOM
var DOM = Hyperjson.toDOM(hjson);
2016-04-21 13:05:41 +00:00
// turn it back into stringified Hyperjson, but apply filters
var shjson2 = Sortify(Hyperjson.fromDOM(DOM, elementFilter, attributeFilter));
2017-11-27 12:45:40 +00:00
return cb(shjson === shjson2);
2016-04-21 13:05:41 +00:00
}, "expected hyperjson equality");
};
HJSON_list.map(HJSON_equal);
var roundTrip = function (sel) {
var target = $(sel)[0];
2017-05-10 09:54:21 +00:00
assert(function (cb) {
var hjson = Hyperjson.fromDOM(target);
var cloned = Hyperjson.toDOM(hjson);
2017-11-27 12:45:40 +00:00
return cb(cloned.outerHTML === target.outerHTML);
}, "Round trip serialization introduced artifacts.");
};
2016-04-21 13:05:41 +00:00
var HTML_list = [
'#target',
'#widget',
2016-04-20 08:10:26 +00:00
'#quot',
2016-04-21 13:05:41 +00:00
];
HTML_list.forEach(roundTrip);
2016-04-13 14:10:38 +00:00
var strungJSON = function (orig) {
var result;
2017-05-10 09:54:21 +00:00
assert(function (cb) {
2016-04-13 14:10:38 +00:00
result = JSON.stringify(JSON.parse(orig));
2017-05-10 09:54:21 +00:00
return cb(result === orig);
2016-04-13 14:10:38 +00:00
}, "expected result (" + result + ") to equal original (" + orig + ")");
};
[ '{"border":"1","style":{"width":"500px"}}',
2016-04-21 13:05:41 +00:00
'{"style":"width: 500px;","border":"1"}',
2016-04-13 14:10:38 +00:00
].forEach(function (orig) {
strungJSON(orig);
});
2017-04-25 14:11:19 +00:00
// check that old hashes parse correctly
2017-05-10 09:54:21 +00:00
assert(function (cb) {
2017-11-13 15:32:40 +00:00
var secret = Hash.parsePadUrl('/pad/#67b8385b07352be53e40746d2be6ccd7XAYSuJYYqa9NfmInyHci7LNy');
2017-05-15 09:11:12 +00:00
return cb(secret.hashData.channel === "67b8385b07352be53e40746d2be6ccd7" &&
secret.hashData.key === "XAYSuJYYqa9NfmInyHci7LNy" &&
secret.hashData.version === 0);
2017-04-25 14:11:19 +00:00
}, "Old hash failed to parse");
// make sure version 1 hashes parse correctly
2017-05-10 09:54:21 +00:00
assert(function (cb) {
2017-11-13 15:32:40 +00:00
var secret = Hash.parsePadUrl('/pad/#/1/edit/3Ujt4F2Sjnjbis6CoYWpoQ/usn4+9CqVja8Q7RZOGTfRgqI');
2017-05-15 09:11:12 +00:00
return cb(secret.hashData.version === 1 &&
secret.hashData.mode === "edit" &&
secret.hashData.channel === "3Ujt4F2Sjnjbis6CoYWpoQ" &&
secret.hashData.key === "usn4+9CqVja8Q7RZOGTfRgqI" &&
!secret.hashData.present);
}, "version 1 hash (without present mode) failed to parse");
2017-04-25 14:11:19 +00:00
// test support for present mode in hashes
2017-05-10 09:54:21 +00:00
assert(function (cb) {
2017-11-13 15:32:40 +00:00
var secret = Hash.parsePadUrl('/pad/#/1/edit/CmN5+YJkrHFS3NSBg-P7Sg/DNZ2wcG683GscU4fyOyqA87G/present');
2017-05-15 09:11:12 +00:00
return cb(secret.hashData.version === 1
&& secret.hashData.mode === "edit"
&& secret.hashData.channel === "CmN5+YJkrHFS3NSBg-P7Sg"
&& secret.hashData.key === "DNZ2wcG683GscU4fyOyqA87G"
&& secret.hashData.present);
2017-04-25 14:11:19 +00:00
}, "version 1 hash failed to parse");
2017-05-10 09:54:21 +00:00
// test support for present mode in hashes
assert(function (cb) {
2017-11-13 15:32:40 +00:00
var secret = Hash.parsePadUrl('/pad/#/1/edit//CmN5+YJkrHFS3NSBg-P7Sg/DNZ2wcG683GscU4fyOyqA87G//present');
2017-05-15 09:11:12 +00:00
return cb(secret.hashData.version === 1
&& secret.hashData.mode === "edit"
&& secret.hashData.channel === "CmN5+YJkrHFS3NSBg-P7Sg"
&& secret.hashData.key === "DNZ2wcG683GscU4fyOyqA87G"
&& secret.hashData.present);
2017-05-10 09:54:21 +00:00
}, "Couldn't handle multiple successive slashes");
// test support for present & embed mode in hashes
assert(function (cb) {
2017-11-13 15:32:40 +00:00
var secret = Hash.parsePadUrl('/pad/#/1/edit//CmN5+YJkrHFS3NSBg-P7Sg/DNZ2wcG683GscU4fyOyqA87G/embed/present/');
return cb(secret.hashData.version === 1
&& secret.hashData.mode === "edit"
&& secret.hashData.channel === "CmN5+YJkrHFS3NSBg-P7Sg"
&& secret.hashData.key === "DNZ2wcG683GscU4fyOyqA87G"
&& secret.hashData.present
&& secret.hashData.embed);
}, "Couldn't handle multiple successive slashes");
// test support for present & embed mode in hashes
assert(function (cb) {
2017-11-13 15:32:40 +00:00
var secret = Hash.parsePadUrl('/pad/#/1/edit//CmN5+YJkrHFS3NSBg-P7Sg/DNZ2wcG683GscU4fyOyqA87G/present/embed');
return cb(secret.hashData.version === 1
&& secret.hashData.mode === "edit"
&& secret.hashData.channel === "CmN5+YJkrHFS3NSBg-P7Sg"
&& secret.hashData.key === "DNZ2wcG683GscU4fyOyqA87G"
&& secret.hashData.present
&& secret.hashData.embed);
}, "Couldn't handle multiple successive slashes");
// test support for embed mode in hashes
assert(function (cb) {
2017-11-13 15:32:40 +00:00
var secret = Hash.parsePadUrl('/pad/#/1/edit//CmN5+YJkrHFS3NSBg-P7Sg/DNZ2wcG683GscU4fyOyqA87G///embed//');
return cb(secret.hashData.version === 1
&& secret.hashData.mode === "edit"
&& secret.hashData.channel === "CmN5+YJkrHFS3NSBg-P7Sg"
&& secret.hashData.key === "DNZ2wcG683GscU4fyOyqA87G"
&& !secret.hashData.present
&& secret.hashData.embed);
}, "Couldn't handle multiple successive slashes");
2017-04-25 14:11:19 +00:00
// test support for trailing slash
2017-05-10 09:54:21 +00:00
assert(function (cb) {
2017-11-13 15:32:40 +00:00
var secret = Hash.parsePadUrl('/pad/#/1/edit/3Ujt4F2Sjnjbis6CoYWpoQ/usn4+9CqVja8Q7RZOGTfRgqI/');
2017-05-15 09:11:12 +00:00
return cb(secret.hashData.version === 1 &&
secret.hashData.mode === "edit" &&
secret.hashData.channel === "3Ujt4F2Sjnjbis6CoYWpoQ" &&
secret.hashData.key === "usn4+9CqVja8Q7RZOGTfRgqI" &&
!secret.hashData.present);
2017-04-25 14:11:19 +00:00
}, "test support for trailing slashes in version 1 hash failed to parse");
2017-05-10 09:54:21 +00:00
assert(function (cb) {
2017-11-13 15:32:40 +00:00
var secret = Hash.parsePadUrl('/invite/#/1/ilrOtygzDVoUSRpOOJrUuQ/e8jvf36S3chzkkcaMrLSW7PPrz7VDp85lIFNI26dTmr=/');
2017-10-30 13:40:43 +00:00
var hd = secret.hashData;
cb(hd.channel === "ilrOtygzDVoUSRpOOJrUuQ" &&
hd.pubkey === "e8jvf36S3chzkkcaMrLSW7PPrz7VDp85lIFNI26dTmr=" &&
hd.type === 'invite');
}, "test support for invite urls");
assert(function (cb) {
var url = '/pad/?utm_campaign=new_comment&utm_medium=email&utm_source=thread_mailer#/1/edit/3Ujt4F2Sjnjbis6CoYWpoQ/usn4+9CqVja8Q7RZOGTfRgqI/';
2017-11-20 11:22:26 +00:00
var secret = Hash.parsePadUrl(url);
return cb(secret.hashData.version === 1 &&
secret.hashData.mode === "edit" &&
secret.hashData.channel === "3Ujt4F2Sjnjbis6CoYWpoQ" &&
secret.hashData.key === "usn4+9CqVja8Q7RZOGTfRgqI" &&
!secret.hashData.present);
}, "test support for ugly tracking query paramaters in url");
assert(function (cb) {
2017-04-25 14:11:19 +00:00
// TODO
2017-05-10 09:54:21 +00:00
return cb(true);
2017-04-25 14:11:19 +00:00
}, "version 2 hash failed to parse correctly");
/*
2017-09-05 09:24:30 +00:00
assert(function (cb) {
var getBlob = function (url, cb) {
var xhr = new XMLHttpRequest();
xhr.open("GET", url, true);
xhr.responseType = "blob";
xhr.onload = function () {
cb(void 0, this.response);
};
xhr.send();
};
var $img = $('img#thumb-orig');
getBlob($img.attr('src'), function (e, blob) {
console.log(e, blob);
Thumb.fromImageBlob(blob, function (e, thumb) {
console.log(thumb);
var th = new Image();
th.src = URL.createObjectURL(thumb);
th.onload = function () {
$(document.body).append($(th).addClass('thumb'));
2017-09-05 09:26:41 +00:00
cb(th.width === Thumb.dimension && th.height === Thumb.dimension);
2017-09-05 09:24:30 +00:00
};
});
});
});
*/
2017-05-24 16:59:44 +00:00
Drive.test(assert);
assert(function (cb) {
// extract dom elements into a flattened JSON representation
var flat = Flat.fromDOM(document.body);
// recreate a _mostly_ equivalent DOM
var dom = Flat.toDOM(flat);
// assume we don't care about comments
2017-10-27 09:13:21 +00:00
var bodyText = document.body.outerHTML.replace(/<!\-\-[\s\S]*?\-\->/g, '');
// check for equality
cb(dom.outerHTML === bodyText);
});
2016-04-13 14:10:38 +00:00
var swap = function (str, dict) {
return str.replace(/\{\{(.*?)\}\}/g, function (all, key) {
return typeof dict[key] !== 'undefined'? dict[key] : all;
2016-04-13 14:10:38 +00:00
});
};
var multiline = function (f) {
var str;
f.toString().replace(/\/\*([\s\S]*)\*\//g, function (all, out) {
2016-04-13 14:10:38 +00:00
str = out;
});
return str || '';
2016-04-21 13:05:41 +00:00
};
2016-04-13 14:10:38 +00:00
2017-05-10 09:54:21 +00:00
var formatFailures = function () {
var template = multiline(function () { /*
2016-04-21 13:05:41 +00:00
<p class="error">
Failed on test number {{test}} with error message:
2016-04-21 13:44:56 +00:00
"{{message}}"
2016-04-21 13:05:41 +00:00
</p>
<p>
The test returned:
{{output}}
</p>
<br>
*/});
return failMessages.map(function (obj) {
console.log(obj);
return swap(template, obj);
}).join("\n");
};
2017-05-10 09:54:21 +00:00
runASSERTS(function () {
$("body").html(function (i, val) {
var dict = {
previous: val,
totalAssertions: ASSERTS.length,
passedAssertions: assertions,
plural: (assertions === 1? '' : 's'),
failMessages: formatFailures()
};
2016-04-13 14:10:38 +00:00
var SUCCESS = swap(multiline(function(){/*
<div class="report">{{passedAssertions}} / {{totalAssertions}} test{{plural}} passed.
{{failMessages}}
</div>
2016-04-13 14:10:38 +00:00
{{previous}}
*/}), dict);
2017-05-10 09:54:21 +00:00
var report = SUCCESS;
2016-04-13 14:10:38 +00:00
2017-05-10 09:54:21 +00:00
return report;
});
2016-04-13 14:10:38 +00:00
2017-05-10 09:54:21 +00:00
var $report = $('.report');
$report.addClass(failed?'failure':'success');
if (failed) {
Test.failed();
} else {
Test.passed();
}
2017-05-10 09:54:21 +00:00
});
});