summaryrefslogtreecommitdiffstats
path: root/LayoutTests/storage/statement-success-callback-isolated-world.html
blob: 4fac754b3c3c20a82bac98d27a864e1475fc113b (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
51
52
<!DOCTYPE html>
<html>
<body>
This test tests that the statement success callback is called in the right world.
<div id="console"></div>
<script>
var statementSuccessCallbacksInvoked = 0;
function done()
{
    if ((++statementSuccessCallbacksInvoked == 2) && (window.layoutTestController))
        layoutTestController.notifyDone();
}

function statementSuccessCallback1(tx, data)
{
    alert("FAIL: Visible in isolated world.");
    done();
}

function statementSuccessCallback2(tx, data)
{
    alert(document.body.bar);
    done();
}

document.body.foo = "FAIL: document.body.foo visible in isolated world.";
document.body.bar = "PASS: document.body.bar visible in a callback created in this world.";

if (window.layoutTestController) {
    layoutTestController.clearAllDatabases();
    layoutTestController.dumpAsText();
    layoutTestController.waitUntilDone();
    layoutTestController.evaluateScriptInIsolatedWorld(
        0,
        "function statementSuccessCallback1(tx, data)\n" +
        "{\n" +
        "    alert(document.body.foo);\n" +
        "    window.location='javascript:done()';\n" +
        "}\n" +
        "var db1 = openDatabase('StatementSuccessCallbackIsolatedWorld1', '1.0', '', 1);\n" +
        "db1.transaction(function(tx) {\n" +
        "    tx.executeSql('CREATE TABLE IF NOT EXISTS Test (Foo INT)', [], statementSuccessCallback1);\n" +
        "});");

    var db2 = openDatabase('StatementSuccessCallbackIsolatedWorld2', '1.0', '', 1);
    db2.transaction(function(tx) {
        tx.executeSql('CREATE TABLE IF NOT EXISTS Test (Foo INT)', [], statementSuccessCallback2);
    });
}
</script>
</body>
</html>