diff --git a/web-locks/query-order.tentative.https.any.js b/web-locks/query-order.tentative.https.any.js deleted file mode 100644 index 3317cd02eb9a15..00000000000000 --- a/web-locks/query-order.tentative.https.any.js +++ /dev/null @@ -1,110 +0,0 @@ -// META: title=Web Locks API: navigator.locks.query ordering -// META: script=resources/helpers.js -// META: global=window,dedicatedworker,sharedworker,serviceworker - -'use strict'; - -// Grab a lock and hold until a release function is called. Resolves -// to a release function. -function getLockAndHoldUntilReleased(name, options) { - let release; - const promise = new Promise(resolve => { release = resolve; }); - return new Promise(resolve => { - navigator.locks.request(name, options || {}, lock => { - resolve(release); - return promise; - }).catch(_ => {}); - }); -} - -promise_test(async t => { - const res1 = uniqueName(t); - const res2 = uniqueName(t); - const res3 = uniqueName(t); - - // These will never be released. - await Promise.all([ - getLockAndHoldUntilReleased(res1), - getLockAndHoldUntilReleased(res2), - getLockAndHoldUntilReleased(res3) - ]); - - // These requests should be blocked. - navigator.locks.request(res3, {mode: 'shared'}, lock => {}); - navigator.locks.request(res2, {mode: 'shared'}, lock => {}); - navigator.locks.request(res1, {mode: 'shared'}, lock => {}); - - const state = await navigator.locks.query(); - - const relevant_pending_names = state.pending.map(lock => lock.name) - .filter(name => [res1, res2, res3].includes(name)); - - assert_array_equals(relevant_pending_names, [res3, res2, res1], - 'Pending locks should appear in order.'); -}, 'Requests appear in state in order made'); - -promise_test(async t => { - const res1 = uniqueName(t); - const res2 = uniqueName(t); - const res3 = uniqueName(t); - - // These should be granted, and will be held until released. - const [release1, release2, release3] = await Promise.all([ - getLockAndHoldUntilReleased(res1), - getLockAndHoldUntilReleased(res2), - getLockAndHoldUntilReleased(res3) - ]); - - // These requests should be blocked. - const requests = [ - getLockAndHoldUntilReleased(res1), - getLockAndHoldUntilReleased(res2), - getLockAndHoldUntilReleased(res3) - ]; - - // Ensure the requests have had a chance to get queued by - // waiting for something else to make it through the queue. - await navigator.locks.request(uniqueName(t), lock => {}); - - // Now release the previous holders. - release2(); - release3(); - release1(); - - // Wait until the subsequent requests make it through. - await Promise.all(requests); - - const state = await navigator.locks.query(); - const relevant_held_names = state.held.map(lock => lock.name) - .filter(name => [res1, res2, res3].includes(name)); - - assert_array_equals(relevant_held_names, [res2, res3, res1], - 'Held locks should appear in granted order.'); -}, 'Held locks appear in state in order granted'); - -promise_test(async t => { - const res1 = uniqueName(t); - const res2 = uniqueName(t); - const res3 = uniqueName(t); - - // These should be granted, and will be held until stolen. - await Promise.all([ - getLockAndHoldUntilReleased(res1), - getLockAndHoldUntilReleased(res2), - getLockAndHoldUntilReleased(res3) - ]); - - // Steal in a different order. - await Promise.all([ - getLockAndHoldUntilReleased(res3, {steal: true}), - getLockAndHoldUntilReleased(res1, {steal: true}), - getLockAndHoldUntilReleased(res2, {steal: true}) - ]); - - const state = await navigator.locks.query(); - const relevant_held_names = state.held.map(lock => lock.name) - .filter(name => [res1, res2, res3].includes(name)); - - assert_array_equals(relevant_held_names, [res3, res1, res2], - 'Held locks should appear in granted order.'); -}, 'Held locks appear in state in order granted, including when stolen'); diff --git a/web-locks/query-ordering.tentative.https.html b/web-locks/query-ordering.tentative.https.html new file mode 100644 index 00000000000000..bbbee3880b7cc7 --- /dev/null +++ b/web-locks/query-ordering.tentative.https.html @@ -0,0 +1,130 @@ + + +Web Locks API: navigator.locks.query ordering + + + + + + diff --git a/web-locks/resources/helpers.js b/web-locks/resources/helpers.js index d6a4af45fa7199..9723ff4f1d8545 100644 --- a/web-locks/resources/helpers.js +++ b/web-locks/resources/helpers.js @@ -5,8 +5,8 @@ // test case name. This is useful to avoid lock interference between // test cases. let res_num = 0; - self.uniqueName = testCase => { - return `${self.location.pathname}-${testCase.name}-${++res_num}`; + self.uniqueName = (testCase, prefix) => { + return `${self.location.pathname}-${prefix}-${testCase.name}-${++res_num}`; }; // Inject an iframe showing the given url into the page, and resolve diff --git a/web-locks/resources/iframe.html b/web-locks/resources/iframe.html index d3799f44f96b34..ba63c77bae50d7 100644 --- a/web-locks/resources/iframe.html +++ b/web-locks/resources/iframe.html @@ -38,6 +38,15 @@ held.delete(e.data.lock_id); respond({ack: 'release', lock_id: e.data.lock_id}); break; + + case 'client_id': + navigator.locks.request(e.data.name, async lock => { + const lock_state = await navigator.locks.query(); + const held_lock = + lock_state.held.filter(l => l.name === lock.name)[0]; + respond({ack: 'client_id', client_id: held_lock.clientId}); + }); + break; } });