gecko-dev/testing/web-platform/tests/web-locks/resource-names.tentative.https.any.js
Joshua Bell d9c00fd14d Bug 1488977 [wpt PR 12860] - Web Locks API: Run tests in additional globals, a=testonly
Automatic update from web-platform-testsWeb Locks API: Run tests in additional globals

Use the "META: global=" annotation to run the web-locks/ tests in
shared and service workers, as appropriate.

Change-Id: I1d6acd9b4e2932bf3a60b1e41285cbe74e3cb8ff
Reviewed-on: https://chromium-review.googlesource.com/1208447
Commit-Queue: Victor Costan <pwnall@chromium.org>
Reviewed-by: Victor Costan <pwnall@chromium.org>
Cr-Commit-Position: refs/heads/master@{#590265}

--

wpt-commits: 7d538d126b49411702cdd88354f520cdf9a65702
wpt-pr: 12860

--HG--
extra : rebase_source : 125cfaf5b02d72d5746aaeb894d27ef8da08c929
extra : source : 703c030316ba169ade809c83d901a58f1881677c
2018-09-13 02:53:08 +00:00

56 lines
1.7 KiB
JavaScript

// META: title=Web Locks API: Resources DOMString edge cases
// META: global=window,dedicatedworker,sharedworker,serviceworker
'use strict';
function code_points(s) {
return [...s]
.map(c => '0x' + c.charCodeAt(0).toString(16).toUpperCase())
.join(' ');
}
[
'', // Empty strings
'abc\x00def', // Embedded NUL
'\uD800', // Unpaired low surrogage
'\uDC00', // Unpaired high surrogage
'\uDC00\uD800', // Swapped surrogate pair
'\uFFFF' // Non-character
].forEach(string => {
promise_test(async t => {
await navigator.locks.request(string, lock => {
assert_equals(lock.name, string,
'Requested name matches granted name');
});
}, 'DOMString: ' + code_points(string));
});
promise_test(async t => {
// '\uD800' treated as a USVString would become '\uFFFD'.
await navigator.locks.request('\uD800', async lock => {
assert_equals(lock.name, '\uD800');
// |lock| is held for the duration of this name. It
// Should not block acquiring |lock2| with a distinct
// DOMString.
await navigator.locks.request('\uFFFD', lock2 => {
assert_equals(lock2.name, '\uFFFD');
});
// If we did not time out, this passed.
});
}, 'Resource names that are not valid UTF-16 are not mangled');
promise_test(async t => {
for (const name of ['-', '-foo']) {
await promise_rejects(
t, 'NotSupportedError',
navigator.locks.request(name, lock => {}),
'Names starting with "-" should be rejected');
}
let got_lock = false;
await navigator.locks.request('x-anything', lock => {
got_lock = true;
});
assert_true(got_lock, 'Names with embedded "-" should be accepted');
}, 'Names cannot start with "-"');