Squeak.ru - шаблоны программирования

Ожидаемое условие транспортира для элемента, содержащего любой текст

Есть ли способ проверить, есть ли в элементе какой-либо текст? Я уже нашел textToBePresentInElement, но эта функция проверяет указанное значение и не возвращает правильную ошибку в случае сбоя.

Я заполняю элемент через API, и он загружается немного позже, поэтому я хочу, чтобы браузер ждал, пока в элементе не появится какая-либо информация, а затем проверял правильное значение.

В качестве альтернативы было бы очень полезно получить конкретное сообщение об ошибке при сбое EC:

browser.wait(EC.textToBePresentInElement(element(by.binding('myvar')), "expected"), 5000);

Ответы:


1

Третий аргумент browser.wait() — это пользовательское сообщение об ошибке:

browser.wait(EC.textToBePresentInElement(element(by.binding('myvar')), "expected"), 5000, "Text is not something I've expected");

Смотрите также:


Чтобы дождаться, когда элемент будет содержать какой-либо текст, вы можете написать собственное ожидаемое условие:

var EC = protractor.ExpectedConditions;

var anyTextToBePresentInElement = function(elementFinder) {
  var hasText = function() {
    return elementFinder.getText().then(function(actualText) {
      return actualText;
    });
  };
  return EC.and(EC.presenceOf(elementFinder), hasText);
};

И вот использование:

browser.wait(anyTextToBePresentInElement(element(by.binding('myvar'))), 5000);
13.05.2015
  • Спасибо за этот полезный ответ. Это прекрасно с третьим аргументом для функции browser.wait(). К сожалению, я не могу запустить пользовательское ожидаемое условие. Пишет неопределенная функция. Есть ли какая-либо документация для пользовательских ожидаемых условий? 15.05.2015
  • @abimelex ой, моя ошибка, я обновил ответ, проверьте его. Спасибо. 15.05.2015
  • Это было давно, но я думаю, что это правильное решение. 04.03.2016

  • 2

    Предыдущий фрагмент кода работает, но с небольшим обновлением: return actualText; должно быть логическим. Таким образом, весь код будет:

    var anyTextToBePresentInElement = function(elementFinder) {
      var EC = protractor.ExpectedConditions;
      var hasText = function() {
        return elementFinder.getText().then(function(actualText) {
          return !!actualText;
        });
      };
      return EC.and(EC.presenceOf(elementFinder), hasText);
    };
    

    Пример использования:

    var el = element(by.binding('myvar'));
    browser.wait(anyTextToBePresentInElement(el, 5000, 'Element still has no text');
    
    08.08.2017

    3

    Вы можете проверить это

            export function titleType(textReference, expectedText)
            {
                textReference.then(function(name)
                {
                    if (name == expectedText)
                    {
                        expect(textReference).toContain(expectedText);
                        expect(name).toEqual(expectedText);
                    }
                    else
                    {
                        throw new TypeError("Wrong " + expectedText + "  name " + name);
                    }
                });
            }
    
    26.02.2020
    Новые материалы

    Угловая структура архитектуры
    Обратите внимание, что эта статья устарела, я решил создать новую с лучшей структурой и с учетом автономных компонентов: https://medium.com/@marekpanti/angular-standalone-architecture-b645edd0d54a..

    «Данные, которые большинство людей используют для обучения своих моделей искусственного интеллекта, поставляются со встроенным…
    Первоначально опубликовано HalkTalks: https://hacktown.com.br/blog/blog/os-dados-que-a-maioria-das-pessoas-usa-para-treinar-seus-modelos-de-inteligencia-artificial- ja-vem-com-um-vies-embutido/..

    Сильный ИИ против слабого ИИ: различия парадигм искусственного интеллекта
    В последние годы изучению и развитию искусственного интеллекта (ИИ) уделяется большое внимание и прогресс. Сильный ИИ и Слабый ИИ — две основные парадигмы в области искусственного интеллекта...

    Правильный способ добавить Firebase в ваш проект React с помощью React Hooks
    React + Firebase - это мощная комбинация для быстрого и безопасного создания приложений, от проверки концепции до массового производства. Раньше (знаете, несколько месяцев назад) добавление..

    Создайте API с помощью Python FastAPI
    Создание API с помощью Python становится очень простым при использовании пакета FastAPI. После установки и импорта вы можете создать приложение FastAPI и указать несколько конечных точек. Каждой..

    Веселье с прокси-сервером JavaScript
    Прокси-серверы JavaScript — это чистый сахар, если вы хотите создать некоторую общую логику в своих приложениях, чтобы облегчить себе жизнь. Вот один пример: Связь клиент-сервер Мы..

    Получить бесплатный хостинг для разработчиков | Разместите свой сайт за несколько шагов 🔥
    Статические веб-сайты — это веб-страницы с фиксированным содержанием и его постоянным содержанием. Но теперь статические сайты также обрабатывают динамические данные с помощью API и запросов...