t.me/atinfo_chat Telegram группа по автоматизации тестирования

Разбираемся в запуске тестов в Jenkins (+Maven +TestNG +WebDriver на Java) или туториал новичка

jenkins
testng
webdriver
java
maven
Теги: #<Tag:0x00007f9c4c3a0da0> #<Tag:0x00007f9c4c3a0be8> #<Tag:0x00007f9c4c3a0a30> #<Tag:0x00007f9c4c3a0850> #<Tag:0x00007f9c4c3a0648>

(johan) #21

 

ПРОБЛЕМА РЕШИЛАСь.
 
Спасибо большое furious_duck!
 
Решение которое помогло мне:
УДАЛИЛ НАХРЕН со своей машины Jenkins 1.478 (который шел через инсталяшку) , вместо этого поставил 1.473 которая запускается через .WAR файл. Сделал заново конфиг для Jenkinsa и для своего проекта -> запустил всё заработало.
 
Итого около 2 мин вместо 35мин!!!!!!!!!!! 
 
Всем спасибо.
 

(Alexander Petrovich) #22

Не забываем написать issue разработчикам :)


(Mykhailo Poliarush) #23

2 минуты это уже хорошо, рад что у вас все получилось


(Sergey Korol) #24

Jenkins 1.478 (as a win service) + Ant + TestNG + Java + Selenium Grid -> 25 тестов в 6 потоков за 2,5 мин. выполняются на удаленной тачке. Исходники из репозитария и то дольше вытягиваются, ибо стоит clean build. Проблема явно не в дженкинсе.


(Alexander Petrovich) #25

у вас таки нету maven. так что не факт


(Alexey Panashchenko) #26

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


(Mykhailo Poliarush) #27

тесты запускаются в бэкграунде, вы их просто не видите.

вам необходимо просмотривать как идут тесты, как открывается браузер и т.д.?


(Artem) #28

А как это сделать?

Поменять инициализацию браузера?


(Mykhailo Poliarush) #29

сделать что?


(von) #30

Если имел ввиду запуск теста на других браузерах, то просто добавляешь swith-case в метод SetUp, выбор браузера выносишь в конфигурационный файлик какой-нибудь, будь то проперти файл, xml и тд


(Kittyness) #31

А у меня что-то вообще мавеновские тесты не запускаются...

Исходная диспозиция: писанные не мной скрипты Java + Selenium II + Webdriver скрипты, которые запускаются через свиты TestNG.

Моя задача - запустить это безобразие на Дженкинсе. Но пока что я не могу его запустить даже локально через Эклипс.

[INFO] --- maven-compiler-plugin:2.3.2:testCompile (default-testCompile) @GUITest ---
[INFO] No sources to compile
[INFO]

 

Вопрос - какую директорию ему указывать (если я делаю  Run as configuration - Maven - test)? Скопировать пом файл туда, где лежат сорцы (коренная папка), или туда, где лежат testNG xml'ки? Что ему, вообще, компилить-то надо?!

 

ПыСы. Сорри за нубские вопросы - блондинкО.


(Mykhailo Poliarush) #32

я залил примерочный проект, для того чтобы посмотреть на содержание файлов

http://narod.ru/disk/64422895001.8eb62472602fbe1e635b2f31281cbf41/mavenTestNgProject.zip.html


(ivan_ochc) #33

При сборке maven’ом возникают ошибки.

[ERROR] \...\...\ec\AutomatTest\src\main\java\com\....\pages\Page.java:[13,17] error: package org.testng does not exist

[ERROR] \...\...\ec\AutomatTest\src\main\java\com\.....\pages\LoginPage.java:[8,29] error: package org.testng.annotations does not exist

Содержание pom.xml. Версии указаны правильные. Почему так - не могу понять.

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
                 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
                 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
        <groupId>Test</groupId>
        <artifactId>Test</artifactId>
        <version>1.0</version>
        <dependencies>
            <dependency>
                <groupId>org.testng</groupId>
                <artifactId>testng</artifactId>
                <version>6.8</version>
                <scope>test</scope>
            </dependency>
            <dependency>
                <groupId>org.seleniumhq.selenium</groupId>
                <artifactId>selenium-java</artifactId>
                <version>2.25.0</version>
            </dependency>
        </dependencies>
  <build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <configuration>
                <source>1.6</source>
                <target>1.6</target>
            </configuration>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-surefire-plugin</artifactId>
            <inherited>true</inherited>
            <configuration>
            <suiteXmlFiles>
            <suiteXmlFile>testng.xml</suiteXmlFile>
            </suiteXmlFiles>
            </configuration>
        </plugin>
    </plugins>
  </build>
</project>

После установки, плагин m2eclipse начал ругаться на первый тег <plugin>, неизвестно почему.


(Mykhailo Poliarush) #34

ну ошибка говорит о том, что в локальном репозитории у вас на машине нет testng

если он у вас уже был скачан до этого, но все таки ошибка возникает,

то тогда можно попробовать удалить локальный репозиторий и скачать зависимости еще раз


(ivan_ochc) #35

Удаление и повторная загрузка репозитория не помогла.

После того как закомментировал test - тест запустился, но не выполнился.

<dependency>
    <groupId>org.testng</groupId>
    <artifactId>testng</artifactId>
    <version>6.8</version>
<!--     <scope>test</scope> -->
</dependency>

Ошибки при запуске:

 T E S T S
------------------------------------------------------- Running TestSuite org.apache.maven.surefire.util.SurefireReflectionException: java.lang.reflect.In vocationTargetException; nested exception is java.lang.reflect.InvocationTargetE xception: null java.lang.reflect.InvocationTargetException
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl. java:57)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAcces sorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:601)
        at org.apache.maven.surefire.util.ReflectionUtils.invokeMethodWithArray( ReflectionUtils.java:164)

Через Eclipse тесты запускаются.


(ivan_ochc) #36

Удалось запустить тест без изощрений с тегом test

<dependency>
<groupId>org.testng</groupId>
<artifactId>testng</artifactId>
<version>6.8</version>
<scope>test</scope> 
</dependency>

Но ошибка осталась.

T E S T S
-------------------------------------------------------
Running TestSuite
org.apache.maven.surefire.util.SurefireReflectionException: java.lang.reflect.In
vocationTargetException; nested exception is java.lang.reflect.InvocationTargetE
xception: null
java.lang.reflect.InvocationTargetException
 
Caused by: org.testng.TestNGException:
Cannot instantiate class com.----.test.LoginTest

Вероятно, в этом причина. Теперь осталось разобраться как это исправить.
При запуске с Eclipse ошибок нету.


(ivan_ochc) #37

Похожую ошибку осуждали в этой теме - http://automated-testing.info/forum/sozadnie-testov-s-ispolzovanie-pagefactory. Но в Eclipse у меня все отлично, проблема только при запуске через maven. 


(Mykhailo Poliarush) #38

а тут надо уже исходники этой странцы

где с инициализацией объектов, что-то неправильно

хотя может быть еще что класс не скомпилировался, что тоже надо проверить


(ivan_ochc) #39

.

package com.-------.test;
 
import org.openqa.selenium.By;
import org.openqa.selenium.NoSuchElementException;
import org.openqa.selenium.support.PageFactory;
import org.testng.annotations.BeforeClass;
 
import org.testng.annotations.Test;
 
import com.kyivstar.pages.HomePage;
import com.kyivstar.pages.LoginPage;
 
public class LoginTest extends BasicTestCase {
    private LoginPage loginPage = PageFactory.initElements(getWebDriver(), LoginPage.class);
     
    private HomePage homePage;
     
    @Test
    public void testLogin() throws Exception {
        loginPage.open();
        StringBuilder result = new StringBuilder();
        homePage = loginPage.loginAs(admin);
        assertSoftFalse(homePage.checkError(), "Default error", result);
        assertSoftFalse(homePage.errorException(), "Exception", result);
        assertSoftFalse(homePage.errorAvailable(), "Unavailable", result);
        assertSoft(homePage.checkAccount(), "Account is null", result);
        assertSoft(homePage.checkBalance(), "Balance is null", result);
        assertEmpty(result);
    }
     
    @Test (dependsOnMethods = { "testLogin" }, priority = 1)
    public void testFeature() throws Exception {
        homePage.openFeatures();
        StringBuilder result = new StringBuilder();
        assertSoft(homePage.checkAccount(), "Account is null", result);
        assertSoftFalse(homePage.checkError(), "Default error", result);
        assertSoftFalse(homePage.errorException(), "Exception", result);
        assertSoftFalse(homePage.errorAvailable(), "Unavailable", result);
        assertSoftFalse(homePage.errorPrice(), "Error price -333", result);
        assertSoft(homePage.checkAccount(), "Account is null", result);
        assertSoft(homePage.checkFeatureOn(), "Feature state is invalid", result);
        assertSoft(homePage.checkFeatureChange(), "Change is unavailable", result);
        assertEmpty(result);
    }
     
    @Test (dependsOnMethods = { "testLogin" }, priority = 2)
        public void testStatement() throws Exception {
        homePage.openStatement();
        StringBuilder result = new StringBuilder();
        assertSoftFalse(homePage.checkError(), "Default error", result);
        assertSoftFalse(homePage.errorException(), "Exception", result);
        assertSoftFalse(homePage.errorAvailable(), "Unavailable", result);
        assertEmpty(result);
    }
     
    @Test (dependsOnMethods = { "testLogin" }, priority = 3)
        public void testStatement1() throws Exception {
        homePage.openStatementTr();
        StringBuilder result = new StringBuilder();
        assertSoftFalse(homePage.checkError(), "Default error", result);
        assertSoftFalse(homePage.errorException(), "Exception", result);
        assertSoftFalse(homePage.errorAvailable(), "Unavailable", result);
        assertEmpty(result);
    }
     
    @Test (dependsOnMethods = { "testLogin" }, priority = 4)
        public void testStatement2() throws Exception {
        homePage.openStatementDet();
        StringBuilder result = new StringBuilder();
        assertSoftFalse(homePage.checkError(), "Default error", result);
        assertSoftFalse(homePage.errorException(), "Exception", result);
        assertSoftFalse(homePage.errorAvailable(), "Unavailable", result);
        assertEmpty(result);
    }
     
    @Test (dependsOnMethods = { "testLogin" }, priority = 5)
        public void testStatement_Pay() throws Exception {
        homePage.openPayment();
        StringBuilder result = new StringBuilder();
        assertSoftFalse(homePage.checkError(), "Default error", result);
        assertSoftFalse(homePage.errorException(), "Exception", result);
        assertSoftFalse(homePage.errorAvailable(), "Unavailable", result);
        assertEmpty(result);
    }
     
    @Test (dependsOnMethods = { "testLogin" }, priority = 6)
        public void testStatement_Prof() throws Exception {
        homePage.openProfile();
        StringBuilder result = new StringBuilder();
        assertSoftFalse(homePage.checkError(), "Default error", result);
        assertSoftFalse(homePage.errorException(), "Exception", result);
        assertSoftFalse(homePage.errorAvailable(), "Unavailable", result);
        assertEmpty(result);
    }
 
}

Добавлял аннотацию @BeforeClass - не помогло
хотя может быть еще что класс не скомпилировался, что тоже надо проверить - как это проверить, не подскажите?


(Mykhailo Poliarush) #40

с исходников я особо ничего проблематичного не вижу

как проверить скомпилированные или нет? да просто зайти в этот проект, посмотреть папке target/classes есть ли там *.class файлы

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

это можно сделать с помощью следующих комманд

mvn clean

mvn compile

mvn test