-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathmain.js
171 lines (143 loc) · 5.2 KB
/
main.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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
(function() {
var widgets = require("sdk/widget");
var data = require("sdk/self").data;
var timers = require("sdk/timers");
var commonUtil = require('./commonUtil.js');
var eventBreakConfigs = require('./search/eventBreakConfigs.js');
// disable strict mode (some Jalangi-instrumented files aren't compliant)
require("sdk/preferences/service").set("javascript.options.strict", false);
// give scripts more time (Jalangi slowdown will trigger pop-up otherwise, default=10)
require("sdk/preferences/service").set("dom.max_script_run_time", 60); // seconds
var config = require('./config.js');
var busy = require('./busy.js');
busy.attachToMostRecentWindow();
var driver = require("./driver.js");
driver.registerTriggerReturn(triggerReturn);
// var search = require("./search/random_search.js");
var search = require("./search/perfGuidedSearch.js");
// var search = require("./search/highlighterSearch.js");
// var search = require("./search/swiftHandSearch.js");
// var search = require("./search/prioritySearch.js");
search.init(driver);
// var manual = require('./manualTesting.js');
// manual.init(driver);
// require('./loops.js');
// require('./typeAnalysis.js');
var manualEventSelection = require('./manualEventSelection.js');
manualEventSelection.setSearch(search);
manualEventSelection.setDriver(driver);
var benchmarks = require("./benchmarks.js");
benchmarks.init(driver, busy, playPauseClicked, setSearch);
var costTracer = require("./costTracer.js");
var eventTriggeringEnabled = false;
function setSearch(s) {
search = s;
search.init(driver);
}
function playPauseClicked() {
if (eventTriggeringEnabled === undefined)
throw "Error: eventTriggeringEnabled should always be defined";
eventTriggeringEnabled = !eventTriggeringEnabled;
if (eventTriggeringEnabled) {
initiateNextEvent();
}
}
function oneEventClicked() {
if (!eventTriggeringEnabled) {
initiateNextEvent();
}
}
function tryToTrigger() {
if (busy.isBusy()) {
timers.setTimeout(tryToTrigger, config.delayWhenBusy);
} else {
if (eventTriggeringEnabled) {
initiateNextEvent();
}
}
}
function nextEvent() {
search.doNextEvent();
}
var initiateNextEvent = function() {
if (benchmarks.isRunning()) {
benchmarks.preEvent(nextEvent);
} else {
nextEvent();
}
};
var lastTriggerReturn;
function triggerReturn() {
lastTriggerReturn = new Date().getTime();
console.log("Receiving triggerReturn in main.js");
if (eventTriggeringEnabled) {
var interval = config.getMaxDelayBetweenEvents() - config.getMinDelayBetweenEvents();
var randFromInterval = commonUtil.randInt(interval + 1);
var delay = config.getMinDelayBetweenEvents() + randFromInterval;
console.log("Will trigger next event after " + delay + " ms");
timers.setTimeout(tryToTrigger, delay);
}
}
function startTriggerReturnIfHanging() {
timers.setInterval(function() {
if (eventTriggeringEnabled) {
var now = new Date().getTime();
console.log("Checking if triggerReturn is hanging: now=" + now + ", lastTriggerReturn=" + lastTriggerReturn);
if (!lastTriggerReturn || (lastTriggerReturn + (1000 * 2)) < now) {
console.log("Seems to hang -- calling triggerReturn()");
timers.setTimeout(triggerReturn, 0);
}
}
}, 1000 * 1);
}
if (eventBreakConfigs.getConfig().triggerIfHanging) {
startTriggerReturnIfHanging();
}
widgets.Widget({
id:"controller",
label:"Play/Pause WebAppWalker",
contentURL:data.url("play.png"),
onClick:playPauseClicked
});
widgets.Widget({
id:"oneEven",
label:"Trigger one event",
contentURL:data.url("one.png"),
onClick:oneEventClicked
});
widgets.Widget({
id:"coverageMany",
label:"Run coverage experiments",
contentURL:data.url("test.png"),
onClick:function() {
benchmarks.runManyCoverageExperiments(0);
}
});
widgets.Widget({
id:"coverageSnapshot",
label:"Take coverage snapshot (for manual testing)",
contentURL:data.url("snap.png"),
onClick:function() {
manual.coverageSnapshot();
}
});
widgets.Widget({
id:"getAndResetCost",
label:"Get and reset cost",
contentURL:data.url("coin.png"),
onClick:function() {
driver.getAndResetCost(function(cost, costTrace) {
console.log("Cost since last reset: " + cost);
costTracer.addCostTrace(costTrace);
});
}
});
widgets.Widget({
id:"prepareEventLogging",
label:"Prepare for logging events from manual testing",
contentURL:data.url("pen.png"),
onClick:function() {
driver.prepareEventLogging();
}
});
})();