<!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>