Chromium Code Reviews| Index: third_party/WebKit/LayoutTests/external/wpt/storage/storagemanager-estimate.https.html |
| diff --git a/third_party/WebKit/LayoutTests/external/wpt/storage/storagemanager-estimate.https.html b/third_party/WebKit/LayoutTests/external/wpt/storage/storagemanager-estimate.https.html |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..88cbc9461a378cccb3fa93138ed90f2f9587492e |
| --- /dev/null |
| +++ b/third_party/WebKit/LayoutTests/external/wpt/storage/storagemanager-estimate.https.html |
| @@ -0,0 +1,68 @@ |
| +<!DOCTYPE html> |
| +<meta charset=utf-8> |
| +<title>StorageManager: estimate()</title> |
| +<meta name="help" href="https://storage.spec.whatwg.org/#dom-storagemanager-estimate"> |
| +<script src="/resources/testharness.js"></script> |
| +<script src="/resources/testharnessreport.js"></script> |
| +<script> |
| + |
| +test(function(t) { |
| + assert_true(navigator.storage.estimate() instanceof Promise); |
| +}, 'estimate() method returns a Promise'); |
| + |
| +promise_test(function(t) { |
| + return navigator.storage.estimate().then(function(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'); |
| + }); |
| +}, 'estimate() resolves to dictionary with members'); |
| + |
| +promise_test(function(t) { |
| + const large_value = new Uint8Array(1e6); |
| + const dbname = `db-${location}-${t.name}`; |
| + let db, before, after; |
| + |
| + indexedDB.deleteDatabase(dbname); |
| + return new Promise((resolve, reject) => { |
| + const open = indexedDB.open(dbname); |
|
pwnall
2017/04/04 21:08:34
I think you can remove some boilerplate by using c
jsbell
2017/04/05 15:57:27
Don't want a test in storage/ to depend on Indexed
|
| + open.onerror = () => { reject(open.error); }; |
| + open.onupgradeneeded = () => { |
| + const connection = open.result; |
| + connection.createObjectStore('store'); |
| + }; |
| + open.onsuccess = () => { |
| + const connection = open.result; |
| + t.add_cleanup(() => { |
| + connection.close(); |
| + indexedDB.deleteDatabase(dbname); |
| + }); |
| + resolve(connection); |
| + }; |
| + }) |
| + .then(connection => { |
| + db = connection; |
| + return navigator.storage.estimate(); |
| + }) |
| + .then(estimate => { |
| + before = estimate.usage; |
| + return new Promise((resolve, reject) => { |
| + const tx = db.transaction('store', 'readwrite'); |
| + tx.objectStore('store').put(large_value, 'key'); |
| + tx.onabort = () => { reject(tx.error); }; |
| + tx.oncomplete = () => { resolve(); }; |
| + }); |
| + }) |
| + .then(() => { |
| + return navigator.storage.estimate(); |
| + }) |
| + .then(estimate => { |
| + after = estimate.usage; |
| + assert_greater_than(after, before, |
| + 'estimated usage should increase'); |
| + }); |
| +}, 'estimate() shows usage increase after large IndexedDB record is stored'); |
|
pwnall
2017/04/04 21:08:34
large -> 1MB?
jsbell
2017/04/05 16:58:12
Done.
|
| + |
| +</script> |