diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
commit | 26a029d407be480d791972afb5975cf62c9360a6 (patch) | |
tree | f435a8308119effd964b339f76abb83a57c29483 /testing/web-platform/tests/credential-management/fedcm-endpoint-redirects.https.html | |
parent | Initial commit. (diff) | |
download | firefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz firefox-26a029d407be480d791972afb5975cf62c9360a6.zip |
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/credential-management/fedcm-endpoint-redirects.https.html')
-rw-r--r-- | testing/web-platform/tests/credential-management/fedcm-endpoint-redirects.https.html | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/testing/web-platform/tests/credential-management/fedcm-endpoint-redirects.https.html b/testing/web-platform/tests/credential-management/fedcm-endpoint-redirects.https.html new file mode 100644 index 0000000000..cff5036f39 --- /dev/null +++ b/testing/web-platform/tests/credential-management/fedcm-endpoint-redirects.https.html @@ -0,0 +1,47 @@ +<!DOCTYPE html> +<title>Federated Credential Management API network request tests.</title> +<link rel="help" href="https://fedidcg.github.io/FedCM"> +<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> + +<script type="module"> +import {request_options_with_mediation_required, + fedcm_test, + select_manifest, + mark_signed_in, + fedcm_get_dialog_type_promise, + fedcm_get_and_select_first_account} from './support/fedcm-helper.sub.js'; + +fedcm_test(async t => { + await mark_signed_in(); + + let test_options = request_options_with_mediation_required("manifest_redirect_accounts.json"); + await select_manifest(t, test_options); + + const cred = fedcm_get_and_select_first_account(t, test_options); + // We expect a mismatch dialog. + const type = await fedcm_get_dialog_type_promise(t); + assert_equals(type, 'ConfirmIdpLogin'); + window.test_driver.cancel_fedcm_dialog(); + return promise_rejects_dom(t, 'NetworkError', cred); +}, 'Test that promise is rejected if accounts endpoint redirects'); + +fedcm_test(async t => { + await mark_signed_in(); + + let test_options = request_options_with_mediation_required("manifest_redirect_token.json"); + await select_manifest(t, test_options); + + try { + const cred = await fedcm_get_and_select_first_account(t, test_options); + assert_unreached("An IdentityCredentialError exception should be thrown."); + } catch (e) { + assert_true(e instanceof DOMException); + assert_equals(e.name, "IdentityCredentialError"); + // 308 should not produce a valid error code + assert_equals(e.code, ""); + } +}, 'Test that token endpoint does not follow redirects'); +</script> |