/
compileBench.js
109 lines (99 loc) · 2.84 KB
/
compileBench.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
(function() {
var jslitmus, _, doU, doT,
data = { f1: 1, f2: 2, f3: 3},
snippet = "<h1>Just static text</h1>\
<p>Here is a simple {{=it.f1}} </p>\
<div>test {{=it.f2}}\
<div>{{=it.f3}}</div>\
</div>";
if (typeof module !== 'undefined' && module.exports) {
runTests();
} else {
window.onload = runTestsInBrowser;
}
function testsetup(snippet) {
jslitmus.test('doU.js', function() {
doU.template(snippet);
});
jslitmus.test('doU.js - looping', function(count) {
while (count--) {
doU.template(snippet);
}
});
jslitmus.test('doT.js - using this', function() {
doT.template(snippet);
});
jslitmus.test('doT.js - using this - looping', function(count) {
while (count--) {
doT.template(snippet);
}
});
}
function runTests() {
//var sys = require('sys');
jslitmus = require('./jslitmus.js');
doU = require('./templating/doU.js');
doT = require('./templating/doT.js');
var passOne = 0;
console.log("*** Compilation speed test");
console.log("*** Small template length: " + snippet.length);
testsetup(snippet);
// Log the test results
jslitmus.on('complete', function(test) {
//console.log(sys.inspect(process.memoryUsage()));
console.log(test.toString());
});
// 'all_complete' fires when all tests have finished.
jslitmus.on('all_complete', function() {
switch (passOne) {
case 0:
passOne++;
for(var i=0; i<5; i++) { snippet += snippet; }
console.log("*** Medium template length: " + snippet.length);
break;
case 1:
passOne++;
for(var i=0; i<3; i++) { snippet += snippet; }
console.log("*** Large template length: " + snippet.length);
break;
default:
return;
}
jslitmus.clearAll();
testsetup(snippet);
jslitmus.runAll();
});
// Run it!
jslitmus.runAll();
}
function runTestsInBrowser() {
jslitmus = window.jslitmus;doU = window.doU;doT = window.doT;
var resultTmpl = doT.template("<h3>Template length : {{=it.size}} </h3> <img src='{{=it.url}}'/>");
var currentSet = document.getElementById('small');
testsetup(snippet);
// 'complete' fires for each test when it finishes.
jslitmus.on('complete', function(test) {
// Output test results
currentSet.innerHTML += test + '<br/>';
});
// 'all_complete' fires when all tests have finished.
jslitmus.on('all_complete', function() {
// Get the results image URL
var url = jslitmus.getGoogleChart();
if (currentSet.id === 'small') {
currentSet.innerHTML += resultTmpl({size: snippet.length, url: url});
setTimeout(function() {
jslitmus.clearAll();
currentSet = document.getElementById('large');
for(var i=0; i<8; i++) { snippet += snippet; }
testsetup(snippet);
jslitmus.runAll();
}, 10);
} else {
currentSet.innerHTML += resultTmpl({size: snippet.length, url: url});
}
});
// Run it!
jslitmus.runAll();
}
})();