forked from fgrehm/qmlunit
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathTestRunner.qml
More file actions
64 lines (48 loc) · 1.87 KB
/
TestRunner.qml
File metadata and controls
64 lines (48 loc) · 1.87 KB
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
import Qt 4.7
import "scripts/support.js" as Support
import "scripts/qmlunit.js" as QmlUnit
Item {
id: runner
function setTimeout(callback, timeout) {
var obj = Qt.createQmlObject('import Qt 4.7; Timer {running: false; repeat: false; interval: ' + timeout + '}', runner, "setTimeout");
obj.triggered.connect(callback);
obj.running = true;
return obj;
}
function clearTimeout(timer) {
timer.running = false;
timer.destroy(1);
return timer;
}
function initializeTests() {
testsInput.each(function(t){
var folder = t.substring(0, t.lastIndexOf('/'));
var testCase = t.substring(t.lastIndexOf('/') + 1, t.lastIndexOf('.qml'));
var relativeFilePath = t.replace(currentPath, "");
Qt.createQmlObject('import Qt 4.7; import "' + folder + '"; ' + testCase + ' { name: "' + relativeFilePath + '" }', runner, testCase);
});
}
Component.onCompleted: {
if (logger.registered)
QmlUnit.Runner.onTestCaseRegistered = logger.registered;
if(logger.testCaseStart)
QmlUnit.QUnit.moduleStart = logger.testCaseStart;
if(logger.testFinished)
QmlUnit.QUnit.testDone = logger.testFinished;
initializeTests();
QmlUnit.window.setTimeout = runner.setTimeout;
QmlUnit.window.clearTimeout = runner.clearTimeout;
QmlUnit.onCompleted();
if (logger.state)
logger.state = 'running';
QmlUnit.Runner.testCases.each(function(tc){
QmlUnit.QUnit.module(tc.name, tc.testEnvironment);
tc.tests.each(function(test){
if (test.length == 4)
QmlUnit.QUnit[test[0]](test[1], test[2], test[3]);
else
QmlUnit.QUnit[test[0]](test[1], test[2]);
});
});
}
}