Skip to content

Commit

Permalink
Cred Man: Add fully active checks (#46422)
Browse files Browse the repository at this point in the history
* Cred Man: Add fully active checks

* Update tests based on feedback
  • Loading branch information
marcoscaceres committed May 29, 2024
1 parent 06fc5f7 commit d6f348b
Showing 1 changed file with 69 additions and 0 deletions.
69 changes: 69 additions & 0 deletions credential-management/non-fully-active.https.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
<!DOCTYPE html>
<meta charset="utf-8" />
<title>Credential Management API Test: non-fully active document</title>
<link
rel="help"
href="https://github.com/w3c/webappsec-credential-management"
/>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/resources/testdriver.js"></script>
<script src="/resources/testdriver-vendor.js"></script>
<body>
<iframe></iframe>
</body>
<script>
promise_setup(async () => {
const iframe = document.querySelector("iframe");
await new Promise((resolve) => {
iframe.addEventListener("load", resolve, { once: true });
iframe.src = "about:blank";
document.body.appendChild(iframe);
});
});

promise_test(async (t) => {
const iframe = document.querySelector("iframe");

// The signal check happens after the fully active check.
// This allows us to confirm the the right error is thrown
// and in the right order.
const controller = new iframe.contentWindow.AbortController();
const signal = controller.signal;
controller.abort();

// Steal all the needed references.
const { credentials } = iframe.contentWindow.navigator;
const DOMExceptionCtor = iframe.contentWindow.DOMException;

// No longer fully active.
iframe.remove();

// Try to get credentials while not fully active...
await promise_rejects_dom(
t,
"NotAllowedError",
DOMExceptionCtor,
credentials.get({ signal }),
"Expected NotAllowedError for get() on non-fully-active document"
);

// Try to create credentials while not fully active...
await promise_rejects_dom(
t,
"NotAllowedError",
DOMExceptionCtor,
credentials.create({ signal }),
"Expected NotAllowedError for create() on non-fully-active document"
);

// Try to prevent silent access while not fully active...
await promise_rejects_dom(
t,
"NotAllowedError",
DOMExceptionCtor,
credentials.preventSilentAccess(),
"Expected NotAllowedError for preventSilentAccess() on non-fully-active document"
);
}, "non-fully active document behavior for CredentialsContainer");
</script>

0 comments on commit d6f348b

Please sign in to comment.