blob: f0e36cb524f2e176bf0622020c1cb0f6b4a9e38d (
plain)
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
|
var pages = [
"<!DOCTYPE html>" +
"<html><body>" +
"<form>" +
"<input name='a' type='radio' checked><input name='a' type='radio'><input name='a' type='radio'>" +
"</form>" +
"</body></html>",
"<!DOCTYPE html>" +
"<html><body>" +
"<form>" +
"<input name='a' type='radio'><input name='a' type='radio' checked><input name='a' type='radio'>" +
"</form>" +
"</body></html>",
];
/**
* This SJS is going to send the same page the two first times it will be called
* and another page the two following times. After that, the response will have
* no content.
* The use case is to have two iframes using this SJS and both being reloaded
* once.
*/
function handleRequest(request, response)
{
var counter = +getState("counter"); // convert to number; +"" === 0
response.setStatusLine(request.httpVersion, 200, "Ok");
response.setHeader("Content-Type", "text/html");
response.setHeader("Cache-Control", "no-cache");
switch (counter) {
case 0:
case 1:
response.write(pages[0]);
break;
case 2:
case 3:
response.write(pages[1]);
break;
}
// When we finish the test case we need to reset the counter
if (counter == 3) {
setState("counter", "0");
} else {
setState("counter", "" + ++counter);
}
}
|