Невозможно отобразить MOAL в тесте автоматизации пользовательского интерфейса в TestCafe, даже если те же шаги работают Javascript

Форум по Javascript
Ответить
Anonymous
 Невозможно отобразить MOAL в тесте автоматизации пользовательского интерфейса в TestCafe, даже если те же шаги работают

Сообщение Anonymous »

У меня есть проблема с отображением модала в моем тесте на автоматизацию TestCafe, если я не обновлю браузер, когда нахожусь на странице. Я объясню ситуацию. < /P>
Я пытаюсь воспроизвести, так это то, что если я войду в устройство, используя вызов API, когда я вхожу в систему в приложение через пользовательский интерфейс, модал появится, заявляя, что я вошел в систему как любая роль A или роль B, который был выбран на вызове API. Но когда я пытаюсь сделать то же самое с помощью автоматизации, модал не появляется после входа в UI, если я не обновлю страницу, а затем появляется, делая это: < /p>
await t.eval(() => location.reload());
< /code>
Однако я не могу написать тест, где я войду в пользовательский интерфейс, и нет модального, а затем обновить страницу и модаль появляется, так как это недопустимо. Вместо этого я надеялся, что если я обновлю страницу пользовательского интерфейса перед входом в систему, а затем вхожу в систему, то я надеялся увидеть модальный, но этого не произойдет.await t.navigateTo(config.ui.loginUrl); //navigate to page again to try to refresh

await t.eval(() => window.dispatchEvent(new Event('authStateChanged'))) //trigger event call

await wait (5000) //tried to wait between API login and UI login and included these waits after the above two methods as well
< /code>
Когда я консоль регистрирует innerhtml, модальный HTML -код просто не существует, если я не обновлю страницу после входа в систему. Это странно. Что еще я могу попробовать между входом в систему API и UI, чтобы попытаться заставить страницу UI работать и показать модал после входа в систему? ['ROLE A', 'ROLE B'].forEach((account: string) => {
test.only(`Validate application auto login with selected "${account}" role after role login in device`, async (t) => {
//create device below and use the device properties to perform api login
sessionCreated = true;
const device = await createDevice({
venueId: '888001',
accountType: account as ACCOUNT_TYPE,
requireLogin: false,
deviceIds: deviceIds,
createdUsers: createdUsers,
});
await apiLogin('test11', 'Test111', defaultDeviceHeaders(device), {
selectedRole: account,
});

await login.login('test11', 'Test111');
await t.eval(() => location.reload());

if (account === 'ROLE A') {
await t
.expect(roleSelection.roleAModalTitle.visible)
.ok('Logged in as role A modal not visible', { timeout: 5000 });
} else {
await t
.expect(roleSelection.roleBModalTitle.visible)
.ok('Logged in as role B modal not visible', { timeout: 5000 });
}
});
});
< /code>
Метод апилогина: < /p>
export function apiLogin(
username: string,
password: string,
headers?: {},
query: { selectedRole?: string } = {},
) {
return request(config.CONFIG.TOKEN_GENERATOR)
.post(`/login`)
.auth(username, password)
.set(headers)
.query(query);
}


Подробнее здесь: https://stackoverflow.com/questions/796 ... he-same-st
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Javascript»