Bug 1852745 - modernize test_autocomplete_basic_form_related_realms - r=credential-management-reviewers,sgalich

Differential Revision: https://phabricator.services.mozilla.com/D188458
This commit is contained in:
Johannes J. Schmidt 2023-09-20 09:19:22 +00:00
Родитель 1431fa3406
Коммит d5da5575f3
4 изменённых файлов: 37 добавлений и 34 удалений

Просмотреть файл

@ -1178,3 +1178,9 @@ async function formAutofillResult(formId) {
);
});
}
function sendFakeAutocompleteEvent(element) {
const acEvent = document.createEvent("HTMLEvents");
acEvent.initEvent("DOMAutoComplete", true, false);
element.dispatchEvent(acEvent);
}

Просмотреть файл

@ -30,12 +30,6 @@ function restoreForm(form) {
form.uname.focus();
}
function sendFakeAutocompleteEvent(element) {
var acEvent = document.createEvent("HTMLEvents");
acEvent.initEvent("DOMAutoComplete", true, false);
element.dispatchEvent(acEvent);
}
add_setup(async () => {
listenForUnexpectedPopupShown();
});

Просмотреть файл

@ -30,12 +30,6 @@ function restoreForm(form) {
form.uname.focus();
}
function sendFakeAutocompleteEvent(element) {
var acEvent = document.createEvent("HTMLEvents");
acEvent.initEvent("DOMAutoComplete", true, false);
element.dispatchEvent(acEvent);
}
add_setup(async () => {
listenForUnexpectedPopupShown();
});

Просмотреть файл

@ -10,21 +10,19 @@
<link rel="stylesheet" href="/tests/SimpleTest/test.css"/>
</head>
<body>
Login Manager test: related realms autocomplete
<p id="display"></p>
<div id="content"></div>
<pre id="test">
<script class="testbody" type="text/javascript">
/** Test for Login Manager: related realms autocomplete. **/
Login Manager test: related realms autocomplete
function sendFakeAutocompleteEvent(element) {
var acEvent = document.createEvent("HTMLEvents");
acEvent.initEvent("DOMAutoComplete", true, false);
element.dispatchEvent(acEvent);
}
<script class="testbody" type="text/javascript">
const formTemplate = `<form id="form1" action="https://autocomplete:8888/formtest.js">
<input type="text" name="uname">
<input type="password" name="pword">
</form>`;
add_setup(async () => {
await setStoredLoginsAsync(
await setStoredLoginsDuringTest(
// Simple related domain relationship where example.com and other-example.com are in the related domains list
["https://other-example.com", "https://other-example.com", null, "relatedUser1", "relatedPass1", "uname", "pword"],
@ -37,19 +35,22 @@ add_setup(async () => {
listenForUnexpectedPopupShown();
});
add_task(async function test_form1_initial_empty() {
const form = createLoginForm();
await promiseFormsProcessedInSameProcess();
add_named_task("form is initially empty", async () => {
const form = setContentForTask(formTemplate);
const autofillResult = await formAutofillResult(form.id);
is(autofillResult, "no_saved_logins", "form has not been filled due to no saved logins");
// Make sure initial form is empty.
checkLoginForm(form.uname, "", form.pword, "");
is(form.uname.value, "", "username is empty");
is(form.pword.value, "", "password is empty");
const popupState = await getPopupState();
is(popupState.open, false, "Check popup is initially closed");
});
add_task(async function test_form_related_domain_menuitems() {
const form = createLoginForm();
await promiseFormsProcessedInSameProcess();
add_named_task("form related domain menuitems", async () => {
const form = setContentForTask(formTemplate);
const autofillResult = await formAutofillResult(form.id);
is(autofillResult, "no_saved_logins", "form has not been filled due to no saved logins");
form.uname.focus();
@ -71,12 +72,17 @@ add_task(async function test_form_related_domain_menuitems() {
checkLoginForm(form.uname, "", form.pword, ""); // value shouldn't update just by opening
synthesizeKey("KEY_ArrowDown"); // first item
checkLoginForm(form.uname, "", form.pword, ""); // value shouldn't update just by selecting
// value shouldn't update just by selecting
is(form.uname.value, "", "username is empty");
is(form.pword.value, "", "password is empty");
synthesizeKey("KEY_Enter");
await promiseFormsProcessedInSameProcess();
const autofillResult2 = await formAutofillResult(form.id);
is(autofillResult2, "filled", "form has been filled");
is(form.pword.value, "relatedPass1", "password should match the login that was selected");
checkLoginForm(form.uname, "relatedUser1", form.pword, "relatedPass1");
is(form.uname.value, "relatedUser1", "username is set");
is(form.pword.value, "relatedPass1", "password is set");
form.uname.value = "";
form.pword.value = "";
@ -86,12 +92,15 @@ add_task(async function test_form_related_domain_menuitems() {
synthesizeKey("KEY_ArrowDown"); // first item
synthesizeKey("KEY_ArrowDown"); // second item
checkLoginForm(form.uname, "", form.pword, ""); // value shouldn't update just by selecting
// value shouldn't update just by selecting
is(form.uname.value, "", "username is empty");
is(form.pword.value, "", "password is empty");
synthesizeKey("KEY_Enter");
await promiseFormsProcessedInSameProcess();
is(form.pword.value, "subPass1", "password should match the login that was selected");
checkLoginForm(form.uname, "subUser1", form.pword, "subPass1");
const autofillResult3 = await formAutofillResult(form.id);
is(autofillResult3, "filled", "form has been filled");
is(form.uname.value, "subUser1", "username is set");
is(form.pword.value, "subPass1", "password is set");
});
</script>
</pre>