forked from subtleGradient/tilde-bin
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathrun-jasmine.js
More file actions
executable file
·88 lines (80 loc) · 3.74 KB
/
run-jasmine.js
File metadata and controls
executable file
·88 lines (80 loc) · 3.74 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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#!/usr/bin/env phantomjs
/**
* Wait until the test condition is true or a timeout occurs. Useful for waiting
* on a server response or for a ui change (fadeIn, etc.) to occur.
*
* @param testFx javascript condition that evaluates to a boolean,
* it can be passed in as a string (e.g.: "1 == 1" or "$('#bar').is(':visible')" or
* as a callback function.
* @param onReady what to do when testFx condition is fulfilled,
* it can be passed in as a string (e.g.: "1 == 1" or "$('#bar').is(':visible')" or
* as a callback function.
* @param timeOutMillis the max amount of time to wait. If not specified, 3 sec is used.
*/
function waitFor(testFx, onReady, timeOutMillis) {
var maxtimeOutMillis = timeOutMillis ? timeOutMillis : 3001, //< Default Max Timout is 3s
start = +new Date,
condition = false,
interval = setInterval(function() {
if ( (+new Date - start < maxtimeOutMillis) && !condition ) {
// If not time-out yet and condition not yet fulfilled
condition = (typeof(testFx) === "string" ? eval(testFx) : testFx()); //< defensive code
} else {
if(!condition) {
// If condition still not fulfilled (timeout but condition is 'false')
console.log("'waitFor()' timeout");
phantom.exit(1);
} else {
// Condition fulfilled (timeout and/or condition is 'true')
// console.log("'waitFor()' finished in " + (new Date().getTime() - start) + "ms.");
typeof(onReady) === "string" ? eval(onReady) : onReady(); //< Do what it's supposed to do once the condition is fulfilled
clearInterval(interval); //< Stop this interval
}
}
}, 100); //< repeat check every 250ms
};
if (phantom.args.length === 0 || phantom.args.length > 2) {
console.log('Usage: run-jasmine.js URL');
phantom.exit();
}
var page = new WebPage();
// Route "console.log()" calls from within the Page context to the main Phantom context (i.e. current "this")
page.onConsoleMessage = function(msg) {
console.log(msg);
};
page.open(phantom.args[0], function(status){
if (status !== "success") {
console.log("Unable to access network");
phantom.exit();
} else {
waitFor(function(){
return page.evaluate(function(){
if (document.body.querySelector('.statusMessage.failed, .statusMessage.passed')) {
return true;
}
return false;
});
}, function(){
page.evaluate(function(){
console.log(document.body.querySelector('.statusMessage.failed, .statusMessage.passed').innerText);
// console.log(document.documentElement.outerHTML)
Array.prototype.slice.call(document.querySelectorAll('.suite.failed, .spec.failed')).forEach(function(node){
var indent = '';
var index = parseFloat(node.style.paddingLeft) / 6;
while (index-- > 0) indent += ' ';
console.log(node.innerText.replace(/^/gm, indent));
})
// list = document.body.querySelectorAll('div.jasmine_reporter > div.suite.failed');
// for (i = 0; i < list.length; ++i) {
// el = list[i];
// desc = el.querySelectorAll('.description');
// console.log('');
// for (j = 0; j < desc.length; ++j) {
// console.log(desc[j].innerText);
// }
// }
});
phantom.exit();
});
}
});