Тайм-аут приемного теста Ember-Cli при ожидании click (); Ошибка qunit: Uncaught (в обещании) Ошибка: pushFailure () - PullRequest
3 голосов
/ 21 июня 2019

Я пытаюсь создать приемочный тест для страницы входа в веб-приложение. Все почти работает, кроме обещания await click(element) никогда не разрешается:

import { module, test } from 'qunit';
import { visit, currentURL, fillIn, click, waitFor, getSettledState } from '@ember/test-helpers';
import { setupApplicationTest } from 'ember-qunit';
import { invalidateSession } from 'ember-simple-auth/test-support';
import { setupMirage } from 'ember-cli-mirage/test-support';

module('Acceptance | login', function(hooks) {
  setupApplicationTest(hooks);
  setupMirage(hooks);

  test('login page | login success', async function(assert) {
    assert.timeout(5000);

    console.log('start', getSettledState());

    await visit('/login');
    assert.equal(currentURL(), '/login');

    await waitFor('.btn-primary:disabled');

    await fillIn('input[type="text"]', 'mirage');
    await fillIn('input[type="password"]', 'password1234');

    await waitFor('.btn-primary:not([disabled])', 2000);
    console.log('btn enabled');

    let btnSubmit = document.querySelector('.btn-primary');
    assert.equal(btnSubmit.disabled, false);

    await click(btnSubmit);
    console.log('await btn click');

    await waitFor('.nav-tabs', 4000);
    console.log('nav complete');

    assert.equal(currentURL(), '/login-success');
    console.log('finished', getSettledState());
  });
});

Если я запускаю этот тест «как есть», «await btn click» не входит в консоль, пока не истечет время ожидания. Я также получаю ошибку qunit "Uncaught (in обещание) Ошибка: утверждение pushFailure () вне контекста теста, в ___ at internalStart" (подчеркивание добавлено мной)

ОДНАКО, если я удаляю часть await вызова click(btnSubmit), тест завершается успешно, НО, последняя проверка getSettledState () возвращает это:

hasPendingRequests: true
hasPendingTimers: true
hasPendingWaiters: false
hasRunLoop: true
pendingRequestCount: 1

Поскольку ожидающие запросы и таймеры существуют, время теста все еще истекло, хотя все вызовы assert() были успешными.

Похоже, что если я запускаю тест правильно с await click(btnSubmit), тест срабатывает по нажатию кнопки (), но если я просто вызываю click(btnSubmit), тесты завершаются успешно, хотя testem или qunit не знает все выполненные тесты. Что я делаю не так?

конечная точка входа в систему mirage:

this.post('/login', function(db, request) {
    let formData = JSON.parse(request.requestBody);
    let auth = this.serialize(db.profiles.all());
    if (formData.identification !== auth.data[0].attributes.loginid || formData.password !== auth.data[0].attributes.password) {
      return new Response(401, {some: 'header', 'Content-Type': 'application/json'}, {
        error_code: "err_loginAuthenticationFail"
      });
    }
    let profile = this.serialize(db.profiles.all());
    profile.data[0].attributes.id = profile.data[0].attributes.localid
    delete profile.data[0].attributes.localid;
    return { ...longAccessTokenObject }
});

Конечная точка mirage работает правильно, она аутентифицирует одну комбо-систему пользователя / pw, которую я настроил, в тестах или вручную, используя страницу / login в Chrome.

1 Ответ

3 голосов
/ 24 июня 2019

NullVoxPopuli был на 100% правильным.Я следил за вашими подозрениями, и в кодовой базе была задача параллельного выполнения сценариев, о которой я не знал, что она не решалась.

...