1
0
Fork 0
firefox/testing/web-platform/tests/subresource-integrity/signatures/tentative/accept-signature.window.js
Daniel Baumann 5e9a113729
Adding upstream version 140.0.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
2025-06-25 09:37:52 +02:00

58 lines
2.5 KiB
JavaScript

// META: script=helper.js
//
// The following tests verify that `accept-signature` headers are sent when
// requesting resources via `<script>` elements.
let test_cases = [
{
integrity: `ed25519-${kValidKeys['rfc']}`,
header: `sig0=("unencoded-digest";sf);keyid="${kValidKeys['rfc']}";tag="ed25519-integrity"`,
},
{
integrity: `ed25519-${kValidKeys['rfc']} malformed-thing`,
header: `sig0=("unencoded-digest";sf);keyid="${kValidKeys['rfc']}";tag="ed25519-integrity"`,
},
{
integrity: `ed25519-${kValidKeys['rfc']} ed25519-${kValidKeys['rfc']}`,
header: `sig0=("unencoded-digest";sf);keyid="${kValidKeys['rfc']}";tag="ed25519-integrity"`,
},
{
integrity: `ed25519-${kValidKeys['arbitrary']} ed25519-${kValidKeys['rfc']}`,
header: `sig0=("unencoded-digest";sf);keyid="${kValidKeys['arbitrary']}";tag="ed25519-integrity", ` +
`sig1=("unencoded-digest";sf);keyid="${kValidKeys['rfc']}";tag="ed25519-integrity"`,
},
{
integrity: `ed25519-${kValidKeys['rfc']} ed25519-${kValidKeys['arbitrary']}`,
header: `sig0=("unencoded-digest";sf);keyid="${kValidKeys['rfc']}";tag="ed25519-integrity", ` +
`sig1=("unencoded-digest";sf);keyid="${kValidKeys['arbitrary']}";tag="ed25519-integrity"`,
},
{
integrity: `ed25519-${kValidKeys['arbitrary']} malformed-thing ed25519-${kValidKeys['rfc']}`,
header: `sig0=("unencoded-digest";sf);keyid="${kValidKeys['arbitrary']}";tag="ed25519-integrity", ` +
`sig1=("unencoded-digest";sf);keyid="${kValidKeys['rfc']}";tag="ed25519-integrity"`,
},
{
integrity: `ed25519-${kValidKeys['rfc']} malformed-thing ed25519-${kValidKeys['arbitrary']}`,
header: `sig0=("unencoded-digest";sf);keyid="${kValidKeys['rfc']}";tag="ed25519-integrity", ` +
`sig1=("unencoded-digest";sf);keyid="${kValidKeys['arbitrary']}";tag="ed25519-integrity"`,
},
];
let test_counter = 0;
for (let test of test_cases) {
test_counter++;
async_test(t => {
let s = document.createElement('script');
let resource = new URL("/subresource-integrity/signatures/accept-signature-script.py", self.location);
resource.searchParams.set("header", test.header);
resource.searchParams.set("counter", test_counter); // Just to force independent requests.
s.src = resource;
s.integrity = test.integrity;
s.onload = t.step_func_done(e => {
assert_equals(s.getAttribute('matched'), 'true');
});
s.onerror = t.unreached_func("Script should not fail.");
document.body.appendChild(s);
}, test.integrity)
}