2 <title>Blocked event</title>
3 <link rel="author" href="mailto:odinho@opera.com" title="Odin Hørthe Omdal">
4 <script src="../../../resources/testharness.js"></script>
5 <script src="../../../resources/testharnessreport.js"></script>
6 <script src="support.js"></script>
12 var db, db_got_versionchange, db2,
14 t = async_test(document.title, {timeout: 10000});
17 var openrq = indexedDB.open('db', 3);
20 openrq.onupgradeneeded = t.step_func(function(e) {
21 events.push("open." + e.type);
22 e.target.result.createObjectStore('store');
26 openrq.onsuccess = t.step_func(function(e) {
29 events.push("open." + e.type);
32 db.onversionchange = t.step_func(function(e) {
33 events.push("db." + e.type);
35 assert_equals(e.oldVersion, 3, "old version");
36 assert_equals(e.newVersion, 4, "new version");
37 // Do not close db here (as we should)
41 db.onerror = fail(t, "db.error");
42 db.abort = fail(t, "db.abort");
44 setTimeout(t.step_func(OpenSecond), 10);
48 openrq.onerror = fail(t, "open.error");
49 openrq.onblocked = fail(t, "open.blocked");
53 function OpenSecond (e) {
54 assert_equals(db2, undefined);
55 assert_equals(db + "", "[object IDBDatabase]");
56 assert_array_equals(db.objectStoreNames, [ "store" ]);
58 var openrq2 = indexedDB.open('db', 4);
61 openrq2.onblocked = t.step_func(function(e) {
62 events.push("open2." + e.type);
63 // We're closing connection from the other open()
68 openrq2.onupgradeneeded = t.step_func(function(e) {
69 db2 = e.target.result;
71 events.push("open2." + e.type);
73 assert_equals(db2 + "", "[object IDBDatabase]");
76 db2.onversionchange = fail(t, "db2.versionchange");
77 db2.onerror = fail(t, "db2.error");
78 db2.abort = fail(t, "db2.abort");
82 openrq2.onsuccess = t.step_func(function(e) {
83 events.push("open2." + e.type);
85 assert_array_equals(events,
86 [ "open.upgradeneeded",
90 "open2.upgradeneeded",
94 setTimeout(function() { t.done(); }, 10);
98 openrq2.onerror = fail(t, "open2.error");
103 add_completion_callback(function(tests) {
104 if (db2) db2.close();
105 indexedDB.deleteDatabase('db');