2010-06-23 12:46:08 -07:00
|
|
|
<!--
|
|
|
|
Any copyright is dedicated to the Public Domain.
|
|
|
|
http://creativecommons.org/publicdomain/zero/1.0/
|
|
|
|
-->
|
|
|
|
<html>
|
|
|
|
<head>
|
|
|
|
<title>Indexed Database Property Test</title>
|
|
|
|
|
|
|
|
<script type="text/javascript" src="/MochiKit/packed.js"></script>
|
|
|
|
<script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
|
|
|
|
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
|
|
|
|
|
|
|
|
<script type="text/javascript;version=1.7">
|
|
|
|
function testSteps()
|
|
|
|
{
|
|
|
|
const name = window.location.pathname;
|
|
|
|
const description = "My Test Database";
|
|
|
|
const objectStoreName = "People";
|
|
|
|
|
|
|
|
const objectStoreData = [
|
|
|
|
{ key: "237-23-7732", value: { name: "Bob", height: 60, weight: 120 } },
|
|
|
|
{ key: "237-23-7733", value: { name: "Ann", height: 52, weight: 110 } },
|
|
|
|
{ key: "237-23-7734", value: { name: "Ron", height: 73, weight: 180 } },
|
|
|
|
{ key: "237-23-7735", value: { name: "Sue", height: 58, weight: 130 } },
|
|
|
|
{ key: "237-23-7736", value: { name: "Joe", height: 65, weight: 150 } },
|
|
|
|
{ key: "237-23-7737", value: { name: "Pat", height: 65 } }
|
|
|
|
];
|
|
|
|
|
|
|
|
const indexData = [
|
2010-12-21 08:02:01 -08:00
|
|
|
{ name: "name", keyPath: "name", options: { unique: true } },
|
|
|
|
{ name: "height", keyPath: "height", options: { unique: false } },
|
|
|
|
{ name: "weight", keyPath: "weight", options: { unique: false } }
|
2010-06-23 12:46:08 -07:00
|
|
|
];
|
|
|
|
|
|
|
|
const objectStoreDataNameSort = [
|
|
|
|
{ key: "237-23-7733", value: { name: "Ann", height: 52, weight: 110 } },
|
|
|
|
{ key: "237-23-7732", value: { name: "Bob", height: 60, weight: 120 } },
|
|
|
|
{ key: "237-23-7736", value: { name: "Joe", height: 65, weight: 150 } },
|
|
|
|
{ key: "237-23-7737", value: { name: "Pat", height: 65 } },
|
|
|
|
{ key: "237-23-7734", value: { name: "Ron", height: 73, weight: 180 } },
|
|
|
|
{ key: "237-23-7735", value: { name: "Sue", height: 58, weight: 130 } }
|
|
|
|
];
|
|
|
|
|
|
|
|
const objectStoreDataWeightSort = [
|
|
|
|
{ key: "237-23-7733", value: { name: "Ann", height: 52, weight: 110 } },
|
|
|
|
{ key: "237-23-7732", value: { name: "Bob", height: 60, weight: 120 } },
|
|
|
|
{ key: "237-23-7735", value: { name: "Sue", height: 58, weight: 130 } },
|
|
|
|
{ key: "237-23-7736", value: { name: "Joe", height: 65, weight: 150 } },
|
|
|
|
{ key: "237-23-7734", value: { name: "Ron", height: 73, weight: 180 } }
|
|
|
|
];
|
|
|
|
|
|
|
|
const objectStoreDataHeightSort = [
|
|
|
|
{ key: "237-23-7733", value: { name: "Ann", height: 52, weight: 110 } },
|
|
|
|
{ key: "237-23-7735", value: { name: "Sue", height: 58, weight: 130 } },
|
|
|
|
{ key: "237-23-7732", value: { name: "Bob", height: 60, weight: 120 } },
|
|
|
|
{ key: "237-23-7736", value: { name: "Joe", height: 65, weight: 150 } },
|
|
|
|
{ key: "237-23-7737", value: { name: "Pat", height: 65 } },
|
|
|
|
{ key: "237-23-7734", value: { name: "Ron", height: 73, weight: 180 } }
|
|
|
|
];
|
|
|
|
|
2011-01-03 12:03:06 -08:00
|
|
|
let request = mozIndexedDB.open(name, description);
|
2010-06-23 12:46:08 -07:00
|
|
|
request.onerror = errorHandler;
|
|
|
|
request.onsuccess = grabEventAndContinueHandler;
|
|
|
|
let event = yield;
|
|
|
|
|
2011-01-06 22:21:36 -08:00
|
|
|
let db = event.target.result;
|
2010-06-23 12:46:08 -07:00
|
|
|
|
2010-10-19 10:58:52 -07:00
|
|
|
request = db.setVersion("1");
|
2010-06-23 12:46:08 -07:00
|
|
|
request.onerror = errorHandler;
|
|
|
|
request.onsuccess = grabEventAndContinueHandler;
|
|
|
|
event = yield;
|
|
|
|
|
2010-12-21 08:02:01 -08:00
|
|
|
let objectStore = db.createObjectStore(objectStoreName);
|
2010-06-23 12:46:08 -07:00
|
|
|
|
|
|
|
// First, add all our data to the object store.
|
|
|
|
let addedData = 0;
|
|
|
|
for (let i in objectStoreData) {
|
|
|
|
request = objectStore.add(objectStoreData[i].value,
|
|
|
|
objectStoreData[i].key);
|
|
|
|
request.onerror = errorHandler;
|
|
|
|
request.onsuccess = function(event) {
|
|
|
|
if (++addedData == objectStoreData.length) {
|
|
|
|
testGenerator.send(event);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
event = yield;
|
2010-10-19 10:58:52 -07:00
|
|
|
ok(true, "1");
|
2010-06-23 12:46:08 -07:00
|
|
|
|
2010-10-19 10:58:52 -07:00
|
|
|
// Now create the indexes.
|
2010-06-23 12:46:08 -07:00
|
|
|
for (let i in indexData) {
|
2010-10-19 10:58:52 -07:00
|
|
|
objectStore.createIndex(indexData[i].name, indexData[i].keyPath,
|
2010-12-21 08:02:01 -08:00
|
|
|
indexData[i].options);
|
2010-06-23 12:46:08 -07:00
|
|
|
}
|
2010-10-19 10:58:52 -07:00
|
|
|
|
|
|
|
is(objectStore.indexNames.length, indexData.length, "Good index count");
|
|
|
|
continueToNextStep();
|
2010-06-23 12:46:08 -07:00
|
|
|
yield;
|
|
|
|
|
2010-10-19 10:58:52 -07:00
|
|
|
ok(true, "2");
|
2010-10-19 10:58:49 -07:00
|
|
|
objectStore = db.transaction(objectStoreName)
|
|
|
|
.objectStore(objectStoreName);
|
2010-06-23 12:46:08 -07:00
|
|
|
|
2010-12-15 13:21:02 -08:00
|
|
|
request = objectStore.index("height").getAllKeys(65);
|
2010-06-23 12:46:08 -07:00
|
|
|
request.onerror = errorHandler;
|
|
|
|
request.onsuccess = grabEventAndContinueHandler;
|
|
|
|
event = yield;
|
2010-10-19 10:58:52 -07:00
|
|
|
ok(true, "3");
|
2010-06-23 12:46:08 -07:00
|
|
|
|
2011-01-06 22:21:36 -08:00
|
|
|
is(event.target.result instanceof Array, true, "Got an array object");
|
|
|
|
is(event.target.result.length, 2, "Correct length");
|
2010-06-23 12:46:08 -07:00
|
|
|
|
2011-01-06 22:21:36 -08:00
|
|
|
for (let i in event.target.result) {
|
|
|
|
is(event.target.result[i], objectStoreDataHeightSort[parseInt(i) + 3].key,
|
2010-06-23 12:46:08 -07:00
|
|
|
"Correct key");
|
|
|
|
}
|
|
|
|
|
2010-12-15 13:21:02 -08:00
|
|
|
request = objectStore.index("height").getAllKeys();
|
2010-06-23 12:46:08 -07:00
|
|
|
request.onerror = errorHandler;
|
|
|
|
request.onsuccess = grabEventAndContinueHandler;
|
|
|
|
event = yield;
|
2010-10-19 10:58:52 -07:00
|
|
|
ok(true, "4");
|
2010-06-23 12:46:08 -07:00
|
|
|
|
2011-01-06 22:21:36 -08:00
|
|
|
is(event.target.result instanceof Array, true, "Got an array object");
|
|
|
|
is(event.target.result.length, objectStoreDataHeightSort.length,
|
2010-06-23 12:46:08 -07:00
|
|
|
"Correct length");
|
|
|
|
|
2011-01-06 22:21:36 -08:00
|
|
|
for (let i in event.target.result) {
|
|
|
|
is(event.target.result[i], objectStoreDataHeightSort[i].key, "Correct key");
|
2010-06-23 12:46:08 -07:00
|
|
|
}
|
|
|
|
|
2010-12-15 13:21:02 -08:00
|
|
|
request = objectStore.index("height").getAllKeys(null, 4);
|
2010-06-23 12:46:08 -07:00
|
|
|
request.onerror = errorHandler;
|
|
|
|
request.onsuccess = grabEventAndContinueHandler;
|
|
|
|
event = yield;
|
|
|
|
|
2010-10-19 10:58:52 -07:00
|
|
|
ok(true, "5");
|
2011-01-06 22:21:36 -08:00
|
|
|
is(event.target.result instanceof Array, true, "Got an array object");
|
|
|
|
is(event.target.result.length, 4, "Correct length");
|
2010-06-23 12:46:08 -07:00
|
|
|
|
2011-01-06 22:21:36 -08:00
|
|
|
for (let i in event.target.result) {
|
|
|
|
is(event.target.result[i], objectStoreDataHeightSort[i].key, "Correct key");
|
2010-06-23 12:46:08 -07:00
|
|
|
}
|
|
|
|
|
2010-12-15 13:21:02 -08:00
|
|
|
request = objectStore.index("height").getAllKeys(65, 1);
|
2010-06-23 12:46:08 -07:00
|
|
|
request.onerror = errorHandler;
|
|
|
|
request.onsuccess = grabEventAndContinueHandler;
|
|
|
|
event = yield;
|
|
|
|
|
2010-10-19 10:58:52 -07:00
|
|
|
ok(true, "6");
|
2011-01-06 22:21:36 -08:00
|
|
|
is(event.target.result instanceof Array, true, "Got an array object");
|
|
|
|
is(event.target.result.length, 1, "Correct length");
|
2010-06-23 12:46:08 -07:00
|
|
|
|
2011-01-06 22:21:36 -08:00
|
|
|
for (let i in event.target.result) {
|
|
|
|
is(event.target.result[i], objectStoreDataHeightSort[parseInt(i) + 3].key,
|
2010-06-23 12:46:08 -07:00
|
|
|
"Correct key");
|
|
|
|
}
|
|
|
|
|
|
|
|
finishTest();
|
|
|
|
yield;
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
<script type="text/javascript;version=1.7" src="helpers.js"></script>
|
|
|
|
|
|
|
|
</head>
|
|
|
|
|
|
|
|
<body onload="runTest();"></body>
|
|
|
|
|
|
|
|
</html>
|