You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
95 lines
2.2 KiB
95 lines
2.2 KiB
|
|
function log() {
|
|
if (window.console) console.log.apply(this, arguments);
|
|
}
|
|
|
|
window.onload = function(){
|
|
runTests();
|
|
get('run').addEventListener('click', runTests, false);
|
|
};
|
|
|
|
document.addEventListener('keypress', function(event){
|
|
if (114 == event.charCode) runTests();
|
|
}, false);
|
|
|
|
function get(id) {
|
|
return document.getElementById(id);
|
|
}
|
|
|
|
function create(type) {
|
|
return document.createElement(type);
|
|
}
|
|
|
|
function clearTests() {
|
|
var table = get('tests');
|
|
table.removeChild(table.children[1]);
|
|
}
|
|
|
|
function runTests() {
|
|
clearTests();
|
|
var table = get('tests')
|
|
, tbody = create('tbody');
|
|
for (var name in tests) {
|
|
var fn = tests[name]
|
|
, canvas = create('canvas')
|
|
, tr = create('tr')
|
|
, tds = [create('td'), create('td'), create('td')]
|
|
, src = create('pre');
|
|
src.appendChild(document.createTextNode(fn.toString()));
|
|
canvas.width = 200;
|
|
canvas.height = 200;
|
|
canvas.title = name;
|
|
tds[1].appendChild(canvas);
|
|
tds[2].appendChild(src);
|
|
tr.appendChild(tds[0]);
|
|
tr.appendChild(tds[1]);
|
|
tr.appendChild(tds[2]);
|
|
tbody.appendChild(tr);
|
|
table.appendChild(tbody);
|
|
runTest(name, canvas, tds[0]);
|
|
}
|
|
}
|
|
|
|
function runTest(name, canvas, dest) {
|
|
var fn = tests[name]
|
|
, start = new Date;
|
|
try {
|
|
fn(canvas.getContext('2d'), function(){});
|
|
} catch (err) {
|
|
log(err);
|
|
}
|
|
canvas.title += ' (rendered in ' + (new Date - start) + 'ms)';
|
|
renderOnServer(name, canvas, function(res){
|
|
if (res.error) {
|
|
var p = create('p');
|
|
p.innerText = res.error;
|
|
dest.appendChild(p);
|
|
} else if (res.data) {
|
|
var img = create('img');
|
|
img.src = res.data;
|
|
img.alt = img.title = name + ' (rendered in ' + res.duration + 'ms)';
|
|
dest.appendChild(img);
|
|
}
|
|
});
|
|
}
|
|
|
|
function renderOnServer(name, canvas, fn) {
|
|
var req = new XMLHttpRequest
|
|
, json = JSON.stringify({
|
|
fn: tests[name].toString()
|
|
, width: canvas.width
|
|
, height: canvas.height
|
|
});
|
|
req.open('POST', '/render');
|
|
req.setRequestHeader('Content-Type', 'application/json');
|
|
req.onreadystatechange = function(){
|
|
if (4 == req.readyState) {
|
|
try {
|
|
fn(JSON.parse(req.responseText));
|
|
} catch (err) {
|
|
fn({ error: err });
|
|
}
|
|
}
|
|
};
|
|
req.send(json);
|
|
}
|