summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/credential-management/fedcm-error-basic.https.html
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
commit26a029d407be480d791972afb5975cf62c9360a6 (patch)
treef435a8308119effd964b339f76abb83a57c29483 /testing/web-platform/tests/credential-management/fedcm-error-basic.https.html
parentInitial commit. (diff)
downloadfirefox-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.html74
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>