blob: 598046ff98f9ddcef2578a0de59313210aeb5d43 [file] [log] [blame]
<!DOCTYPE html>
<title>IDBFactory.open() - error in upgradeneeded resets db</title>
<link rel="author" href="mailto:odinho@opera.com" title="Odin Hørthe Omdal">
<script src=/resources/testharness.js></script>
<script src=/resources/testharnessreport.js></script>
<script src=support.js></script>
<script>
var db, db2;
var open_rq = createdb(async_test(document.title, {timeout: 10000}), undefined, 9);
open_rq.onupgradeneeded = function(e) {
db = e.target.result;
var st = db.createObjectStore("store");
st.createIndex("index", "i");
assert_equals(db.version, 9, "first db.version");
assert_true(db.objectStoreNames.contains("store"), "objectStoreNames contains store");
assert_true(st.indexNames.contains("index"), "indexNames contains index");
st.add({i: "Joshua"}, 1);
st.add({i: "Jonas"}, 2);
};
open_rq.onsuccess = function(e) {
db.close();
var open_rq2 = window.indexedDB.open(db.name, 10);
open_rq2.onupgradeneeded = this.step_func(function(e) {
db2 = e.target.result;
db2.createObjectStore("store2");
var store = open_rq2.transaction.objectStore("store")
store.createIndex("index2", "i");
assert_equals(db2.version, 10, "db2.version");
assert_true(db2.objectStoreNames.contains("store"), "second objectStoreNames contains store");
assert_true(db2.objectStoreNames.contains("store2"), "second objectStoreNames contains store2");
assert_true(store.indexNames.contains("index"), "second indexNames contains index");
assert_true(store.indexNames.contains("index2"), "second indexNames contains index2");
store.add({i: "Odin"}, 3);
store.put({i: "Sicking"}, 2);
open_rq2.transaction.abort();
});
open_rq2.onerror = this.step_func(function(e) {
assert_equals(db2.version, 9, "db2.version after error");
assert_true(db2.objectStoreNames.contains("store"), "objectStoreNames contains store after error");
assert_false(db2.objectStoreNames.contains("store2"), "objectStoreNames not contains store2 after error");
var open_rq3 = window.indexedDB.open(db.name);
open_rq3.onsuccess = this.step_func(function(e) {
var db3 = e.target.result;
assert_true(db3.objectStoreNames.contains("store"), "third objectStoreNames contains store");
assert_false(db3.objectStoreNames.contains("store2"), "third objectStoreNames contains store2");
var st = db3.transaction("store").objectStore("store");
assert_equals(db3.version, 9, "db3.version");
assert_true(st.indexNames.contains("index"), "third indexNames contains index");
assert_false(st.indexNames.contains("index2"), "third indexNames contains index2");
st.openCursor(null, "prev").onsuccess = this.step_func(function(e) {
assert_equals(e.target.result.key, 2, "opencursor(prev) key");
assert_equals(e.target.result.value.i, "Jonas", "opencursor(prev) value");
});
st.get(3).onsuccess = this.step_func(function(e) {
assert_equals(e.target.result, undefined, "get(3)");
});
var idx = st.index("index");
idx.getKey("Jonas").onsuccess = this.step_func(function(e) {
assert_equals(e.target.result, 2, "getKey(Jonas)");
});
idx.getKey("Odin").onsuccess = this.step_func(function(e) {
assert_equals(e.target.result, undefined, "getKey(Odin)");
});
idx.getKey("Sicking").onsuccess = this.step_func(function(e) {
assert_equals(e.target.result, undefined, "getKey(Sicking)");
this.done();
});
});
});
};
</script>
<div id=log></div>