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.
 
 
 
 

87 lines
2.1 KiB

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.innerText = 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;
fn(canvas.getContext('2d'));
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('image');
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);
}