mirror of
https://github.com/servo/servo.git
synced 2025-08-06 06:00:15 +01:00
Update web-platform-tests to revision 093a97b6ecc6484c201d704d38b47bef1964d59d
This commit is contained in:
parent
16e4eb6964
commit
f9972c83e3
79 changed files with 1530 additions and 824 deletions
|
@ -1,92 +1,101 @@
|
|||
// META: title=StorageManager: estimate() for indexeddb
|
||||
|
||||
function indexedDbOpenRequest(t, dbname, upgrade_func) {
|
||||
return new Promise((resolve, reject) => {
|
||||
const openRequest = indexedDB.open(dbname);
|
||||
t.add_cleanup(() => {
|
||||
indexedDbDeleteRequest(dbname);
|
||||
});
|
||||
|
||||
openRequest.onerror = () => {
|
||||
reject(openRequest.error);
|
||||
};
|
||||
openRequest.onsuccess = () => {
|
||||
resolve(openRequest.result);
|
||||
};
|
||||
openRequest.onupgradeneeded = event => {
|
||||
upgrade_func(openRequest.result);
|
||||
};
|
||||
});
|
||||
}
|
||||
|
||||
function indexedDbDeleteRequest(name) {
|
||||
return new Promise((resolve, reject) => {
|
||||
const deleteRequest = indexedDB.deleteDatabase(name);
|
||||
deleteRequest.onerror = () => {
|
||||
reject(deleteRequest.error);
|
||||
};
|
||||
deleteRequest.onsuccess = () => {
|
||||
resolve();
|
||||
};
|
||||
});
|
||||
}
|
||||
|
||||
function transactionPromise(txn) {
|
||||
return new Promise((resolve, reject) => {
|
||||
txn.onabort = () => {
|
||||
reject(txn.error);
|
||||
};
|
||||
txn.oncomplete = () => {
|
||||
resolve();
|
||||
};
|
||||
});
|
||||
}
|
||||
|
||||
test(t => {
|
||||
assert_true('estimate' in navigator.storage);
|
||||
assert_equals(typeof navigator.storage.estimate, 'function');
|
||||
assert_true(navigator.storage.estimate() instanceof Promise);
|
||||
}, 'estimate() method exists and returns a Promise');
|
||||
|
||||
promise_test(t => {
|
||||
return navigator.storage.estimate().then(result => {
|
||||
assert_true(typeof result === 'object');
|
||||
assert_true('usage' in result);
|
||||
assert_equals(typeof result.usage, 'number');
|
||||
assert_true('quota' in result);
|
||||
assert_equals(typeof result.quota, 'number');
|
||||
});
|
||||
promise_test(async t => {
|
||||
const estimate = await navigator.storage.estimate();
|
||||
assert_true(typeof estimate === 'object');
|
||||
assert_true('usage' in estimate);
|
||||
assert_equals(typeof estimate.usage, 'number');
|
||||
assert_true('quota' in estimate);
|
||||
assert_equals(typeof estimate.quota, 'number');
|
||||
}, 'estimate() resolves to dictionary with members');
|
||||
|
||||
promise_test(t => {
|
||||
promise_test(async t => {
|
||||
const arraySize = 1e6;
|
||||
const objectStoreName = "storageManager";
|
||||
const dbname = this.window ? window.location.pathname :
|
||||
"estimate-worker.https.html";
|
||||
|
||||
let db;
|
||||
let usageBeforeCreate, usageAfterCreate, usageAfterPut;
|
||||
await indexedDbDeleteRequest(dbname);
|
||||
let estimate = await navigator.storage.estimate();
|
||||
|
||||
function deleteDB(name) {
|
||||
return new Promise((resolve, reject) => {
|
||||
let deleteRequest = indexedDB.deleteDatabase(name);
|
||||
deleteRequest.onerror = () => { reject(deleteRequest.error); };
|
||||
deleteRequest.onsuccess = () => { resolve(); };
|
||||
});
|
||||
const usageBeforeCreate = estimate.usage;
|
||||
const db = await indexedDbOpenRequest(t, dbname, (db_to_upgrade) => {
|
||||
db_to_upgrade.createObjectStore(objectStoreName);
|
||||
});
|
||||
|
||||
estimate = await navigator.storage.estimate();
|
||||
const usageAfterCreate = estimate.usage;
|
||||
|
||||
assert_greater_than(
|
||||
usageAfterCreate, usageBeforeCreate,
|
||||
'estimated usage should increase after object store is created');
|
||||
|
||||
const txn = db.transaction(objectStoreName, 'readwrite');
|
||||
const buffer = new ArrayBuffer(arraySize);
|
||||
const view = new Uint8Array(buffer);
|
||||
|
||||
for (let i = 0; i < arraySize; i++) {
|
||||
view[i] = Math.floor(Math.random() * 255);
|
||||
}
|
||||
|
||||
return deleteDB(dbname)
|
||||
.then(() => {
|
||||
return navigator.storage.estimate();
|
||||
})
|
||||
.then(estimate => {
|
||||
usageBeforeCreate = estimate.usage;
|
||||
return new Promise((resolve, reject) => {
|
||||
let openRequest = indexedDB.open(dbname);
|
||||
openRequest.onerror = () => { reject(openRequest.error); };
|
||||
openRequest.onupgradeneeded = event => {
|
||||
openRequest.result.createObjectStore(objectStoreName);
|
||||
};
|
||||
openRequest.onsuccess = () => { resolve(openRequest.result); };
|
||||
});
|
||||
})
|
||||
.then(connection => {
|
||||
db = connection;
|
||||
return navigator.storage.estimate();
|
||||
})
|
||||
.then(estimate => {
|
||||
usageAfterCreate = estimate.usage;
|
||||
assert_greater_than(
|
||||
usageAfterCreate, usageBeforeCreate,
|
||||
'estimated usage should increase after object store is created');
|
||||
const testBlob = new Blob([buffer], {type: "binary/random"});
|
||||
txn.objectStore(objectStoreName).add(testBlob, 1);
|
||||
|
||||
let txn = db.transaction(objectStoreName, 'readwrite');
|
||||
let buffer = new ArrayBuffer(arraySize);
|
||||
let view = new Uint8Array(buffer);
|
||||
await transactionPromise(txn);
|
||||
|
||||
for (let i = 0; i < arraySize; i++) {
|
||||
view[i] = parseInt(Math.random() * 255);
|
||||
}
|
||||
estimate = await navigator.storage.estimate();
|
||||
const usageAfterPut = estimate.usage;
|
||||
assert_greater_than(
|
||||
usageAfterPut, usageAfterCreate,
|
||||
'estimated usage should increase after large value is stored');
|
||||
|
||||
let testBlob = new Blob([buffer], {type: "binary/random"});
|
||||
txn.objectStore(objectStoreName).add(testBlob, 1);
|
||||
|
||||
return new Promise((resolve, reject) => {
|
||||
txn.onabort = () => { reject(txn.error); };
|
||||
txn.oncomplete = () => { resolve(); };
|
||||
});
|
||||
})
|
||||
.then(() => {
|
||||
return navigator.storage.estimate();
|
||||
})
|
||||
.then(estimate => {
|
||||
usageAfterPut = estimate.usage;
|
||||
assert_greater_than(
|
||||
usageAfterPut, usageAfterCreate,
|
||||
'estimated usage should increase after large value is stored');
|
||||
|
||||
db.close();
|
||||
return deleteDB(dbname);
|
||||
})
|
||||
.then(() => {
|
||||
t.done();
|
||||
});
|
||||
db.close();
|
||||
}, 'estimate() shows usage increase after large value is stored');
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue