blob: 8349dbae79fe36a7896439482305016b84e36db7 [file] [log] [blame]
<!DOCTYPE html>
<meta charset="utf-8">
<title>objectStoreNames and indexNames order</title>
<link rel="author" href="mailto:odinho@opera.com" title="Odin Hørthe Omdal">
<link rel=help href="http://dvcs.w3.org/hg/IndexedDB/raw-file/tip/Overview.html#widl-IDBDatabase-objectStoreNames">
<link rel=assert title="The list must be sorted in ascending order using the algorithm defined by step 4 of section 11.8.5, The Abstract Relational Comparison Algorithm of the ECMAScript Language Specification [ECMA-262].">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="support.js"></script>
<script>
function list_order(desc, unsorted, expected) {
var objStore, db,
t = async_test(document.title + " - " + desc);
var open_rq = createdb(t);
open_rq.onupgradeneeded = function(e) {
db = e.target.result;
for (var i = 0; i < unsorted.length; i++)
objStore = db.createObjectStore(unsorted[i]);
assert_equals(db.objectStoreNames.length, expected.length, "objectStoreNames length");
for (var i = 0; i < expected.length; i++)
assert_equals(db.objectStoreNames[i], expected[i], "objectStoreNames["+i+"]");
for (var i = 0; i < unsorted.length; i++)
objStore.createIndex(unsorted[i], "length");
assert_equals(objStore.indexNames.length, expected.length, "indexNames length");
for (var i = 0; i < expected.length; i++)
assert_equals(objStore.indexNames[i], expected[i], "indexNames["+i+"]");
};
open_rq.onsuccess = function(e) {
assert_equals(db.objectStoreNames.length, expected.length, "objectStoreNames length");
for (var i = 0; i < expected.length; i++)
assert_equals(db.objectStoreNames[i], expected[i], "objectStoreNames["+i+"]");
assert_equals(objStore.indexNames.length, expected.length, "indexNames length");
for (var i = 0; i < expected.length; i++)
assert_equals(objStore.indexNames[i], expected[i], "indexNames["+i+"]");
t.done();
};
}
list_order("numbers",
[123456, -12345, -123, 123, 1234, -1234, 0, 12345, -123456],
["-123", "-1234", "-12345", "-123456", "0", "123", "1234", "12345", "123456"]);
list_order("numbers 'overflow'",
[9, 1, 1000000000, 200000000000000000],
["1", "1000000000", "200000000000000000", "9"]);
list_order("lexigraphical string sort",
[ "cc", "c", "aa", "a", "bb", "b", "ab", "", "ac" ],
[ "", "a", "aa", "ab", "ac", "b", "bb", "c", "cc" ]);
</script>
<div id="log"></div>