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-error-basic.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-error-basic.https.html')
-rw-r--r-- | testing/web-platform/tests/credential-management/fedcm-error-basic.https.html | 74 |
1 files changed, 74 insertions, 0 deletions
diff --git a/testing/web-platform/tests/credential-management/fedcm-error-basic.https.html b/testing/web-platform/tests/credential-management/fedcm-error-basic.https.html new file mode 100644 index 0000000000..49d6ea50df --- /dev/null +++ b/testing/web-platform/tests/credential-management/fedcm-error-basic.https.html @@ -0,0 +1,74 @@ +<!DOCTYPE html> +<title>Federated Credential Management API Error API 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, + manifest_origin, + select_manifest, + fedcm_get_and_select_first_account, + fedcm_error_dialog_dismiss, + fedcm_error_dialog_click_button} from './support/fedcm-helper.sub.js'; + +const url_prefix = manifest_origin + '/credential-management/support/fedcm/'; + +fedcm_test(async t => { + let test_options = + request_options_with_mediation_required("manifest_id_assertion_endpoint_returns_error.json"); + await select_manifest(t, test_options); + + try { + const cred = await fedcm_get_and_select_first_account(t, test_options); + fedcm_error_dialog_dismiss(t); + await cred; + assert_unreached("An IdentityCredentialError exception should be thrown."); + } catch (e) { + assert_true(e instanceof DOMException); + assert_equals(e.name, "IdentityCredentialError"); + assert_equals(e.code, "unauthorized_client"); + assert_equals(e.url, url_prefix + "error.html"); + } +}, 'Test that the promise is rejected with proper error details when dialog is dismissed'); + +fedcm_test(async t => { + let test_options = + request_options_with_mediation_required("manifest_id_assertion_endpoint_returns_error.json"); + await select_manifest(t, test_options); + + try { + const cred = await fedcm_get_and_select_first_account(t, test_options); + fedcm_error_dialog_click_button(t, "ErrorGotIt"); + await cred; + assert_unreached("An IdentityCredentialError exception should be thrown."); + } catch (e) { + assert_true(e instanceof DOMException); + assert_equals(e.name, "IdentityCredentialError"); + assert_equals(e.code, "unauthorized_client"); + assert_equals(e.url, url_prefix + "error.html"); + } +}, 'Test that the promise is rejected with proper error details when got it is clicked'); + +fedcm_test(async t => { + let test_options = + request_options_with_mediation_required("manifest_id_assertion_endpoint_returns_error.json"); + await select_manifest(t, test_options); + + try { + const cred = await fedcm_get_and_select_first_account(t, test_options); + fedcm_error_dialog_click_button(t, "ErrorMoreDetails"); + await cred; + assert_unreached("An IdentityCredentialError exception should be thrown."); + } catch (e) { + assert_true(e instanceof DOMException); + assert_equals(e.name, "IdentityCredentialError"); + assert_equals(e.code, "unauthorized_client"); + assert_equals(e.url, url_prefix + "error.html"); + } +}, 'Test that the promise is rejected with proper error details when more details is clicked'); + +</script> |