среда, 13 апреля 2016 г.

Selenium + Browser proxy : куда уходят запросы?

Всем привет.
Не так давно в работе мне пришла задачка - нужно было смотреть, сколько определенных запросов уходит при открытии страницы и при некоторых действиях на ней. Как же сделать? Первое, что приходит на ум - прокси. Browser Proxy - библиотека, которая уже давно живет где-то по соседству с selenium, да вот только с недавних пор она притерпела небольшую "пластику" и теперь с ней нужно общаться немного по другому. Как именно - я сейчас расскажу и покажу. asdf


Итак. Для начала - ссылочка на гитхаб с библиотекой - https://github.com/lightbody/browsermob-proxy
Там в readme уже есть неплохое описание, какие-то основные вещи можно понять и оттуда. Но я всё же расскажу еще раз в разрезе решаемой задачи.

Первое, что мы делаем - правильно - подключаем библиотечку к нашему проекту с помощью любимого maven:

<dependency>
    <groupId>net.lightbody.bmp</groupId>
    <artifactId>browsermob-core-littleproxy</artifactId>
    <version>2.1.0-beta-5</version>
</dependency>


И собственно пишем код для работы с прокси:

public class BrowserProxy {
    private BrowserMobProxy proxyServer;
    private boolean isServerStarted;

    public void startServer(DesiredCapabilities capabilities) {
        proxyServer = new BrowserMobProxyServer(0);
        try {
            proxyServer.start();
            isServerStarted = true;
        } catch (Exception e) {
            throw new RuntimeException("Can't start proxy-server on port: " + proxyServer.getPort(), e);
        }

        Proxy proxy = null;
        try {
            proxy = createHttpProxy(proxyServer.getPort());
        } catch (UnknownHostException e) {
            e.printStackTrace();
        }
        createNewHar();
        capabilities.setCapability(CapabilityType.PROXY, proxy);
    }

    private Proxy createHttpProxy(int port) throws UnknownHostException {
        Proxy proxy = new Proxy();
        proxy.setProxyType(Proxy.ProxyType.MANUAL);
        String proxyStr = String.format("%s:%d", InetAddress.getLocalHost().getCanonicalHostName(),  port);
        proxy.setHttpProxy(proxyStr);
        proxy.setSslProxy(proxyStr);
        return proxy;
    }

    public void createNewHar(){
        proxyServer.newHar();
    }

    public void stopServer() {
        if (isServerStarted) {
            try {
                proxyServer.stop();
            } catch (Exception e) {
                throw new RuntimeException("Can't stop proxy server", e);
            }

        }
    }


    public int getCallsCountByContainsKey(String key, boolean clearHistory) {
        int result = 0;
        Har har = proxyServer.getHar();
        if (har != null) {
            HarLog harLog = har.getLog();
            List<HarEntry> entries = harLog.getEntries();
            for (HarEntry entry : entries) {
                if (entry.getRequest().getUrl().contains(key)) {
                    result++;
                }

            }

        } else {
            return -1;
        }
        if(clearHistory) {
            createNewHar();
        }
        return result;
    }

    public Har getHar() {
        return proxyServer.getHar();
    }
}

Ну и теперь - всё, что нам нужно - это вызвать метод getCallsCountByContainsKey с желаемым урлом, который нам нужен. Второй параметр - clearHistory - нужен для того, чтобы можно было удалять по сути не нужную историю, чтоб при подсчете кол-ва вызовов не всегда проходить по огромному списку урлов.

Код, который получится у Вас в итоге:

public static void main(String[] args){
    BrowserProxy browserProxy = new BrowserProxy();
    DesiredCapabilities caps = getBrowserCapabilities(); //здесь мы в зависимости от браузера берем capabilities    browserProxy.startServer(caps);
    WebDriver webDriver = new RemoteWebDriver(caps);
    webDriver.get("http://yandex.ru");
    int callsCount = browserProxy.getCallsCountByContainsKey("coolUrl.com", false);
    assertTrue("Unexpected calls count",callsCount == 2);
    webDriver.quit();
}

Вот и всё. Проще простого!


четверг, 30 июля 2015 г.

IntelliJ Idea Selenium plugin with Selenide

Сегодня замечательный день - в IntelliJ Idea плагин для Selenium(я уже писал о нем ранее) добавлена поддержка очень интересной библиотеки - Selenide
Что такое selenide? Это по сути своей удобная обертка над selenium, позволяющая разрабатывать веб тесты не особенно задумываясь о таких вещах, как поднятие/закрытие браузера, ожидания и тп. 

В плагине добавлены следующие фичи:
  1. Возможность создания преднастроенного проекта для selenide, со всеми зависимостями и примерами тестов
  2. code complete для локаторов для $ методов
  3. проверка ошибок локаторов "на лету" для $ методов
  4. проверка существования элементов для $ методов

вторник, 7 апреля 2015 г.

Что за зверь, этот Selenium?

Уже достаточно давно огромную популярность и распространенность приобрела разработка автоматических тестов на веб. И правда - при этом мы проверяем поведение, по сути, как это делает пользователь - вводим значения в поля, нажимаем кнопочки, ждем контента. И практически на протяжении всего этого времени нам в нашем нелегком деле помогает Selenium (ссылка на официальный сайт) 

Что ж это за зверь такой, этот Selenium? 

понедельник, 30 марта 2015 г.

Рецепты приготовления JUnit и TestNG

В мире существует множество фреймворков, помогающих в разработке автоматических тестов на Java. Некоторые помогают во взаимодействии с браузерами, некоторые - с базами данных. Но при этом особняком стоят два "атланта" - TestNG и JUnit. Эти фреймворки предназначены для облегчения жизни рядовым разработчикам при написании автотестов. Изпользуя их, уже не нужно задумываться, а как запустить Ваши тесты? Как добавить настройки? Как объединить тесты в наборы? За Вас уже все продумали создатели этих чудесных библиотек, инструментов или фреймворков - каждый называет эти продукты как хочется.

Разумеется, и TestNG и JUnit обладают массой полезных и удобных фич, каждый по своему хорош. Уж сколько раз устраивались "холивары" по поводу того, кто же всё таки "круче"? Выбирать Вам, что для Вас удобно, что более оптимально.

В двух интересных статьях - о TestNG  и о JUnit - просто и доходчиво описаны основные и ключевые фичи того и другого продукта. Кажется, что они неплохо подойдут в качестве своеобразной методички для каждой из библиотек.

пятница, 20 марта 2015 г.

Allure - красивые и понятные отчеты к автотестам

Какими основными особенностями должны обладать хорошие автотесты? Основное - это конечно же простой, понятый, удобный для поддержки код. Без него никак. Если одно из перечисленных свойств отсутствует - уже сложно считать тесты "хорошими".

Но есть еще один пункт, о котором ни в коем случае нельзя забывать - это отчет. Если в результатах выполнения тестов может разобраться только человек, создавший их, то они никак не соответствуют определению "хорошие", не так ли?

Отчет должен быть понятным, и, что на мой взгляд важно, красивым. Так же система, с помощью которой мы работаем с этим отчетом из кода(добавление различных шагов, логов, скриншотов) должна быть по возможности как можно более простой и прозрачной.

Всеми перечисленными в предыдущем абзаце свойствами обладает allure. Основными его плюсами являются:

  1. Понятный для любого члена команды вид отчета - сразу видно разделение по функциональности, различные тестовые сьюты.
  2. Красивый и достаточно лакончиный UI, написанный с использованием последних технологий в веб разработке.
  3. Наличие поддержки различных языков программирования - Java, С#, python и библиотек - JUnit, TestNG, NUnit, PyTest.
  4. Удобное и достаточно гибкое API  - не составит сложности подключить отчеты к уже существующим тестам.
  5. Написанные плагины для различных CI инструментов.
  6. Продукт является opensource с очень дружественными разработчиками, готовыми к обсуждению и добавлению желаемой функциональности.
И это лишь малая часто того, что предоставляет нам allure.  
Внутри самого отчета так же очень хочется выделить возможность различного рода attach'ей, через которые можно расширять возможности отчета до беспредельных величин.

Более подробная инструкция о том, как же пользоваться инструментом - в нашей статье.



пятница, 13 марта 2015 г.

IntelliJ IDEA Selenium Pligin

При написании тестов на веб мы , зачастую, сталкиваемся с целом рядом проблем. В начале - это размышления о том, какую архитектуру фреймворка выбрать, как взаимодействовать с webdriver. В процессе написания кода возникают проблемы : а правильно ли написан локатор?Есть ли такой элемент на странице? 

С этими проблемами нам призван помочь разработанный недавно плагин для IntelliJ IDEA. Описание можно увидеть на сайте разработчиков. Из заявленных функций:


  1. Создание преднастроенного проекта для написания тестов. То есть в несколько кликов есть возможность создать уже рабочий проект, готовый для работы.
  2. Code complete для локаторов. Многие уже давно не могут жить без этого для обычного кода, а теперь такая возможность появилась так же и при составлении локаторов.
  3. Проверка правильности написания локаторов в коде. Ведь наверняка бывало, что из за случайно забытой одинарной кавычки в локаторе мы тратили драгоценное время, чтобы понять, где же все таки проблема?
  4. Проверка сущствования элементов на странице. Написали локатор, но не понятно, правильно ли мы это сделали? И сколько элементов может быть найдено по данному идентификатору?
  5. Возможность простой генерации полей для Page Object(те, что помечены аннотациями @FindBy). 

Набор полезных фишек неплохой, не так ли? Разработчики(в числе которых Ваш покорный слуга) плагина готовы слушать предложения и добавлять любые желанные "фишки". Сейчас продукт находится в активной фазе развития и мы верим, что в итоге должен получиться инструмент, который реально упростит жизнь разработчикам автоматических тестов на веб с использованием selenium.
Любые предложения, пожелания, комментарии ну и , разумеется, баг репорты, можно отправлять по форме обратной связи прямо на сайте.

пятница, 16 января 2015 г.

Thucydides или собственный фреймворк - что лучше?!

Совсем недавно тут мы проводили достаточно интересный опрос - А какой webdriver framework используете Вы? И правда - сейчас существует достаточно богатый выбор уже готовых решений, осталось только выбрать подходящий. Или может всё таки использовать что-то своё? 
В этой статье я постараюсь проанализировать результаты опроса, высказать свои мысли по поводу результатов и попробую на их основании ответить на следующие вопросы:
  1. Какими свойствами должен обладать фреймворк, чтобы быть на первом месте?
  2. Почему чаще всего всё же используется «самописные» библиотеки?
Начнем по порядку.
Еще раз приведу результаты, на основании которых я делал выводы:
Тут же хотелось бы немного разделить фреймворки следующим образом:
в первой группе будут - ThucydidesHtml Elements и Selenide
во второй - cucumber-jvm и jbehave.
Остальное пока оставим в стороне.
Я специально разделил их, так как всё-таки первые - это строго selenium фреймворки, а вторые - это фреймворки для BDD и их можно использовать как в связке с Webdriver, так и без нее.
Итак. Почему же результаты расположились именно таким образом? Анализ хотелось бы провести так же отдельно для разных групп.