blob: 4fac754b3c3c20a82bac98d27a864e1475fc113b [file] [log] [blame]
<!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>