Selenium Webdriver для Java автоматизаторов
  • Introduction
  • Selenium Webdriver. Введение
    • WebDriver. Обзор и принцип работы
    • Основные методы Selenium Webdriver API
    • Типы локаторов
    • Ожидания
    • Пример использования Webdriver API
  • Selenium WebDriver. Сложные вопросы.
    • Локаторы. CSS, XPATH, JQUERY.
    • WebDriver API. Сложные взаимодействия.
    • Контроль за ходом теста. Кастомные ожидания, попапы, алерты, Iframes.
    • DDT подход
  • Page Object Pattern. Архитектура тестового проекта.
    • Использование паттерна Page Object.
    • Альтернативные Page Object подходы.
    • Вспомогательные инструменты.
    • Уровни абстракции. Создание кастомных элементов.
    • Архитектура. Основные элементы.
  • Selenium Grid и "headless" браузеры
    • Использование HtmlUnit драйвера в автотестировании
    • "Headless" тестирование с PhantomJS и SlimerJS
    • Grid. Настройка и использование.
  • Selenium Webdriver. Проблемные моменты
    • Вспомогательные инструменты
    • Basic Authentification Window
    • Загрузка файла
    • Отправление файла (upload)
    • Логгирование в Selenium Webdriver
    • Скриншоты элементов и работа с изображением
  • Selenium Webdriver. Тестирование HTML5 веб приложений
    • Автоматизация Canvas элементов.
    • Автоматизация видео плеера.
    • Работа с web storage.
  • Selenium Webdriver. Расширение инструмента
    • Selenium "обертки" и расширения
    • Thucydides
    • Geb
    • Selenide
    • Репортинг
  • Selenium Webdriver. Тестирование клиентской производительности
    • Navigation timing API
    • Browser Mob Proxy
    • DynaTrace
    • HttpWatch
  • Selenium Webdriver. Behavior-Driven Development.
    • Обзор методологии и инструментов на Java.
    • Cucumber JVM + Selenium Webdriver.
    • JBehave + Selenium Webdriver.
  • Selenium Webdriver. Тестирование на мобильных браузерах
    • Обзор инструментов
    • Установка и настройка Appium. Принципы и основы работы с инструментом
    • Запуск тестов на десктоп и мобильных браузерах
  • Облачные сервисы.
    • Обзор рынка облачных сервисов для тестирования.
    • SauceLabs. Услуги и планы.
    • Настройка тестов для запуска в SauceLabs.
    • Использование Sauce Connect и Travis CI.
  • Continuous Integration
    • Что такое Continuous Integration
    • Распространенные CI-серверы
    • Jenkins - установка и настройка
Powered by GitBook
On this page
  1. Selenium Webdriver. Тестирование клиентской производительности

Navigation timing API

PreviousSelenium Webdriver. Тестирование клиентской производительностиNextBrowser Mob Proxy

Last updated 6 years ago

Navigation timing - javascript API для измерения производительности веб приложений, утвержденный организацией W3C в качестве стандарта.

Navigation timing предоставляет простой и прямой способ получения точных данных о загрузке страницы (page navigation) и событиях при загрузке страницы (load events). Этот API доступен в IE 9, firefox, chrome и webkit-based браузерах.

Доступ к API можно получить через свойства интерфейса window.performance.timing с помощью javascript. Каждый атрибут объекта performance.timing хранит время того или иного навигационного события, когда был послан запрос на сервер (request), в милисекундах в формате UTC (в миллисекундах с первого января 1970 года). Ноль означает, что событие не произошло.

Очередность событий при загрузке страницы изображена на диаграмме:

Более подробно про эти события можно прочитать в самом стандарте Navigation Timing:

Пример:

@Test
public void testLogin() {
    Webdriver driver = new FirefoxDriver();
    driver.get(SOME_URL);
    JavascriptExecutor js = (JavascriptExecutor) driver;
    // Получаем время Load Event End (окончание загрузки страницы)
    long loadEventEnd = (Long) js.executeScript("return window.performance.timing.loadEventEnd;");
    // Получаем Navigation Event Start (начало перехода)
    long navigationStart = (Long) js.executeScript("return window.performance.timing.navigationStart;");
    // Разница между Load Event End и Navigation Event Start - это время загрузки страницы
    System.out.println("Page Load Time is " + (loadEventEnd - navigationStart)/1000 + " seconds.");
}
http://www.w3.org/TR/navigation-timing/