| Index: LayoutTests/http/tests/serviceworker/indexeddb.html
|
| diff --git a/LayoutTests/http/tests/serviceworker/indexeddb.html b/LayoutTests/http/tests/serviceworker/indexeddb.html
|
| index 3766f376b11e49f23401cb7e069d48c658911a49..81d592ae7fbec05aa2f83d1f90ad746d15af63b2 100644
|
| --- a/LayoutTests/http/tests/serviceworker/indexeddb.html
|
| +++ b/LayoutTests/http/tests/serviceworker/indexeddb.html
|
| @@ -1,57 +1,35 @@
|
| <!DOCTYPE html>
|
| -<script src="/js-test-resources/js-test.js"></script>
|
| +<title>Service Worker: Indexed DB</title>
|
| +<script src="../resources/testharness.js"></script>
|
| +<script src="../resources/testharnessreport.js"></script>
|
| <script>
|
| +var test = async_test('Verify Indexed DB operation in a Service Worker');
|
| +test.step(function() {
|
|
|
| -description("Verify that IndexedDB is functional in a ServiceWorker");
|
| -var jsTestIsAsync = true;
|
| + navigator.serviceWorker.register('resources/indexeddb-worker.js').then(
|
| + test.step_func(function(worker) {
|
| + var messageChannel = new MessageChannel();
|
| + messageChannel.port1.onmessage = test.step_func(onMessage);
|
|
|
| -evalAndLog("messageChannel = new MessageChannel()");
|
| -evalAndLog("messageChannel.port1.onmessage = onMessageHandler");
|
| + worker.postMessage({port: messageChannel.port2}, [messageChannel.port2]);
|
| + }),
|
| + test.step_func(function(reason) {
|
| + assert_unreached('Registration should succeed, but failed: ' + reason.name);
|
| + }));
|
|
|
| -debug("");
|
| -evalAndLog("navigator.serviceWorker.register('indexeddb-worker.js')").then(
|
| - function(result) {
|
| - serviceWorker = result;
|
| - evalAndLog("serviceWorker.postMessage({port: messageChannel.port2}, [messageChannel.port2])");
|
| - },
|
| - function(reason) {
|
| - testFailed(reason.name);
|
| - finishJSTest();
|
| - });
|
| -
|
| -function onMessageHandler(e) {
|
| - var prefix = "[ServiceWorker] ";
|
| - message = e.data;
|
| - switch (message.action) {
|
| - case 'log':
|
| - debug(prefix + message.text);
|
| - break;
|
| - case 'pass':
|
| - testPassed(prefix + message.text);
|
| - break;
|
| - case 'fail':
|
| - testFailed(prefix + message.text);
|
| - break;
|
| - case 'quit':
|
| - verifyDatabase();
|
| - break;
|
| + function onMessage() {
|
| + var openRequest = indexedDB.open('db');
|
| + openRequest.onsuccess = test.step_func(function() {
|
| + var db = openRequest.result;
|
| + var tx = db.transaction('store');
|
| + var store = tx.objectStore('store');
|
| + var getRequest = store.get('key');
|
| + getRequest.onsuccess = test.step_func(function() {
|
| + assert_equals(getRequest.result, 'value',
|
| + 'The get() result should match what the worker put().');
|
| + test.done();
|
| + });
|
| + });
|
| }
|
| -}
|
| -
|
| -function verifyDatabase() {
|
| - debug("");
|
| - debug("Verifying the database from the page");
|
| - debug("");
|
| - evalAndLog("request = indexedDB.open('db')");
|
| - request.onsuccess = function() {
|
| - evalAndLog("db = request.result");
|
| - evalAndLog("tx = db.transaction('store')");
|
| - evalAndLog("store = tx.objectStore('store')");
|
| - evalAndLog("request = store.get('key')");
|
| - request.onsuccess = function() {
|
| - shouldBe("request.result", "'value'");
|
| - finishJSTest();
|
| - };
|
| - };
|
| -}
|
| +});
|
| </script>
|
|
|