Testcafe Проверка отсутствия элемента DOM - PullRequest
1 голос
/ 13 июля 2020

Я пытаюсь разобраться в Test Cafe, но сейчас застрял. У меня есть веб-приложение, которое я хочу протестировать, начиная с входа в систему и заканчивая выходом из системы. Когда я вхожу в систему с неправильными учетными данными, я отображаю элемент DOM с id = errorMsg.

В Test Cafe я хочу проверить, присутствует ли элемент DOM или нет.

Это мой тестовый сценарий , базовая c -страница-модель. js - это набор всех идентификаторов элементов DOM, используемых в тесте.

import Page from './basic-page-model';
import { Selector } from 'testcafe';

fixture `Full Test Run of Main Features Role User`
    .page `https://localhost:8443/login.jsp`;

const page = new Page();

const errorMessage= Selector('#errorMsg');
test('login test', async t => {
        
        await t
            .typeText(page.nameInput, 'user')
            .typeText(page.passInput, 'user') //correct password -> password 
            .click(page.login)
            .expect(errorMessage.exists).notOk();

});

Неважно, произойдет ли вход в систему или нет, это всегда возвращает тест пройден. Может кто-нибудь указать мне правильное направление?

1 Ответ

3 голосов
/ 14 июля 2020

Согласно вашему тестовому коду, у вас нет элемента #errorMsg DOM в обоих случаях: с правильными и неправильными учетными данными. Я создал простой пример, и он хорошо работает:

index. html (существует сообщение об ошибке)

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Error Message</title>
</head>
<body>
<div id="errorMsg">
    <p>Error Message</p>
</div>
</body>
</html>

no-message. html (без сообщения об ошибке)

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>No Error Message</title>
</head>
<body>
</body>
</html>

тест. js

import { Selector } from 'testcafe';

fixture `Error message`;

const errorMessage = Selector('#errorMsg').addCustomDOMProperties({
    outerHtml: el => el.outerHtml
});

test
    .page('localhost:8080/no-message')
    ('message should not exist', async t => {
       await t
           .expect(errorMessage.exists).notOk();
    });

test
    .page('localhost:8080')
    ('message should exist', async t => {
        await t
            .expect(errorMessage.exists).ok();
    });

Результат:

>testcafe chrome test.js
 Running tests in:
 - Chrome 83.0.4103.116 / Windows 10

 Error message
 √ message should not exist
 √ message should exist


 2 passed (0s)

Вы в вашем тесте может быть неправильное сообщение об ошибке id. Если приведенный выше пример не помогает, я предлагаю вам обновить свой вопрос простым проектом.

...