Перейти к содержимому

Фотография

Через jenkins тесты валятся с java.lang.IncompatibleClassChangeError


  • Авторизуйтесь для ответа в теме
Сообщений в теме: 4

#1 prostooleg1

prostooleg1

    Активный участник

  • Members
  • PipPip
  • 94 сообщений
  • Город:Москва


Отправлено 14 ноября 2011 - 09:34

Ситуация такая, jenkins у нас стоит на сервере, и все тесты запускаличь через дженкинс нормально, иНО после того как я обновился селениума 9 на 12. И вроде как ничего больше не трогал. При запуске тестов через дженкинс стали происходить такие ошибки:

Started by user anonymous
Updating https://svn.lo.lan/t...t/selenium-test
U build.xml
At revision 55614
No emails were triggered.
[workspace] $ /home/jenkins/tools/ant_1.8.2/bin/ant run
Buildfile: /home/jenkins/jobs/mamba-uitest/workspace/build.xml

build-subprojects:

init:

build-project:
[echo] selenium-test: /home/jenkins/jobs/mamba-uitest/workspace/build.xml

build:

run:
[testng] [TestNG] Running:
[testng] /home/jenkins/jobs/mamba-uitest/workspace/lib/testng-customsuite.xml
[testng]
[testng] FAILED: LoginPageTestNg_test1
[testng] java.lang.IncompatibleClassChangeError
[testng] at com.example.tests.Test6.LoginPageTestNg_test1(Test6.java:40)
[testng] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
[testng] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:48)
[testng] at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
[testng] at java.lang.reflect.Method.invoke(Method.java:600)
[testng] at org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:76)
[testng] at org.testng.internal.Invoker.invokeMethod(Invoker.java:673)
[testng] at org.testng.internal.Invoker.invokeTestMethod(Invoker.java:846)
[testng] at org.testng.internal.Invoker.invokeTestMethods(Invoker.java:1170)
[testng] at org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:125)
[testng] at org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:109)
[testng] at org.testng.TestRunner.runWorkers(TestRunner.java:1147)
[testng] at org.testng.TestRunner.privateRun(TestRunner.java:749)
[testng] at org.testng.TestRunner.run(TestRunner.java:600)
[testng] at org.testng.SuiteRunner.runTest(SuiteRunner.java:317)
[testng] at org.testng.SuiteRunner.runSequentially(SuiteRunner.java:312)
[testng] at org.testng.SuiteRunner.privateRun(SuiteRunner.java:274)
[testng] at org.testng.SuiteRunner.run(SuiteRunner.java:223)
[testng] at org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:52)
[testng] at org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:86)
[testng] at org.testng.TestNG.runSuitesSequentially(TestNG.java:1039)
[testng] at org.testng.TestNG.runSuitesLocally(TestNG.java:964)
[testng] at org.testng.TestNG.run(TestNG.java:900)
[testng] at org.testng.TestNG.privateMain(TestNG.java:1182)
[testng] at org.testng.TestNG.main(TestNG.java:1146)
[testng]
[testng] FAILED: LoginPageTestNg_test10
[testng] java.lang.IncompatibleClassChangeError
[testng] at com.example.tests.Test6.LoginPageTestNg_test10(Test6.java:155)
[testng] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
[testng] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:48)
[testng] at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
[testng] at java.lang.reflect.Method.invoke(Method.java:600)
[testng] at org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:76)
[testng] at org.testng.internal.Invoker.invokeMethod(Invoker.java:673)
[testng] at org.testng.internal.Invoker.invokeTestMethod(Invoker.java:846)
[testng] at org.testng.internal.Invoker.invokeTestMethods(Invoker.java:1170)
[testng] at org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:125)
[testng] at org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:109)
[testng] at org.testng.TestRunner.runWorkers(TestRunner.java:1147)
[testng] at org.testng.TestRunner.privateRun(TestRunner.java:749)
[testng] at org.testng.TestRunner.run(TestRunner.java:600)
[testng] at org.testng.SuiteRunner.runTest(SuiteRunner.java:317)
[testng] at org.testng.SuiteRunner.runSequentially(SuiteRunner.java:312)
[testng] at org.testng.SuiteRunner.privateRun(SuiteRunner.java:274)
[testng] at org.testng.SuiteRunner.run(SuiteRunner.java:223)
[testng] at org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:52)
[testng] at org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:86)
[testng] at org.testng.TestNG.runSuitesSequentially(TestNG.java:1039)
[testng] at org.testng.TestNG.runSuitesLocally(TestNG.java:964)
[testng] at org.testng.TestNG.run(TestNG.java:900)
[testng] at org.testng.TestNG.privateMain(TestNG.java:1182)
[testng] at org.testng.TestNG.main(TestNG.java:1146)

Один знакмый автоматизтор мне сказал, что это может быть из-за различия версий джавы. Может ли это быть из-за того, что на сервере стоит более старая версия джавы а селениум использует более новую или я не знаю как еще выразиться? Локально все тесты запускаются. Просто я уже дома сам поставил дженкинс локально, репозиторий селениум и т д, запустил эти же тесты через дженкинс и тесты запускаются нормально.
  • 0

#2 barancev

barancev

    Администратор

  • Admin
  • PipPipPipPipPipPip
  • 6 872 сообщений
  • ФИО:Алексей Баранцев
  • Город:Россия, Москва


Отправлено 14 ноября 2011 - 09:36

Тесты надо скомпилировать, указав в качестве целевой ту версию Java, которая стоит на сервере (ну или более раннюю).
  • 0
Алексей Баранцев
Тренинги для тестировщиков (тестирование производительности, защищенности, тест-дизайн, автоматизация):
Линейка тренингов по Selenium

#3 prostooleg1

prostooleg1

    Активный участник

  • Members
  • PipPip
  • 94 сообщений
  • Город:Москва


Отправлено 14 ноября 2011 - 09:53

Тесты надо скомпилировать, указав в качестве целевой ту версию Java, которая стоит на сервере (ну или более раннюю).



Каким образом это сделать? Вот мой build файл:

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!-- WARNING: Eclipse auto-generated file.
Any modifications will be overwritten.
To include a user specific buildfile here, simply create one in the same
directory with the processing instruction <?eclipse.ant.import?>
as the first entry and export the buildfile again. -->

<project basedir="." default="build" name="selenium-test">
<property environment="env"/>
<property name="LIB_HOME" value="./lib"/>
<property name="SELENIUM_HOME" value="${LIB_HOME}/Selenium"/>
<property name="junit.output.dir" value="test-output"/>
<property name="debuglevel" value="source,lines,vars"/>
<property name="target" value="1.6"/>
<property name="source" value="1.6"/>
<path id="Selenium.userclasspath">
<fileset dir="${SELENIUM_HOME}">
<include name="**/*.jar"/>
</fileset>
</path>
<path id="selenium-test.classpath">
<pathelement location="bin"/>
<path refid="Selenium.userclasspath"/>
<pathelement location="${LIB_HOME}/testng-6.2.jar"/>
</path>

<target name="init">
<mkdir dir="bin"/>
<copy includeemptydirs="false" todir="bin">
<fileset dir="src">
<exclude name="**/*.java"/>
</fileset>
</copy>
</target>
<target name="clean">
<delete dir="bin"/>
</target>
<target depends="clean" name="cleanall"/>
<target depends="build-subprojects,build-project" name="build"/>
<target name="build-subprojects"/>
<target depends="init" name="build-project">
<echo message="${ant.project.name}: ${ant.file}"/>
<javac debug="true" debuglevel="${debuglevel}" destdir="bin" source="${source}" target="${target}" includeantruntime="false">
<src path="src"/>
<compilerarg line="-encoding utf-8"/>
<classpath refid="selenium-test.classpath"/>
</javac>
</target>
<target description="Build all projects which reference this project. Useful to propagate changes." name="build-refprojects"/>
<target name="com.example.tests">
<mkdir dir="${junit.output.dir}"/>
<junit fork="yes" printsummary="withOutAndErr">
<formatter type="xml"/>
<classpath refid="selenium-test.classpath"/>
</junit>

</target>


<target name="junitreport">
<junitreport todir="${junit.output.dir}">
<fileset dir="${junit.output.dir}">
<include name="TEST-*.xml"/>
</fileset>
<report format="frames" todir="${junit.output.dir}"/>
</junitreport>
</target>
<taskdef resource="testngtasks" classpath="${LIB_HOME}/testng-6.2.jar"></taskdef>
<target name="run" depends="build">
<testng>
<classpath refid="selenium-test.classpath"/>
<xmlfileset dir="${LIB_HOME}" includes="testng-customsuite.xml"/>
</testng>
</target>

</project>



Как я понимаю, компилим этим

<javac debug="true" debuglevel="${debuglevel}" destdir="bin" source="${source}" target="${target}" includeantruntime="false">
<src path="src"/>
<compilerarg line="-encoding utf-8"/>
<classpath refid="selenium-test.classpath"/>
</javac>

где <property name="debuglevel" value="source,lines,vars"/>
<property name="target" value="1.6"/>
<property name="source" value="1.6"/>

В дженкинсе стоит

JDK 1.6.0
JAVA_HOME: /usr/lib64/jvm/java-1_6_0-ibm-1.6.0

То есть как я понимаю версии джавы одинаковые. Раньше то тесты ходили без проблем, как только обновил селениум, то стали валиться с такой проблемой, сейчас попоробую обратно 9-ый поставить, псмотреть что получится.
  • 0

#4 barancev

barancev

    Администратор

  • Admin
  • PipPipPipPipPipPip
  • 6 872 сообщений
  • ФИО:Алексей Баранцев
  • Город:Россия, Москва


Отправлено 14 ноября 2011 - 10:50

Возможна ещё такая ситуация -- Ваши тесты использовали некоторые методы, которые были объявлены deprecated, а теперь вообще удалены из интерфейса Selenium.
Или ещё какое-то изменение произошло в интерфейсе. В общем-то, обычно в такой ситуации помогает простая перекомпиляция тестов.
  • 0
Алексей Баранцев
Тренинги для тестировщиков (тестирование производительности, защищенности, тест-дизайн, автоматизация):
Линейка тренингов по Selenium

#5 prostooleg1

prostooleg1

    Активный участник

  • Members
  • PipPip
  • 94 сообщений
  • Город:Москва


Отправлено 14 ноября 2011 - 12:14

Возможна ещё такая ситуация -- Ваши тесты использовали некоторые методы, которые были объявлены deprecated, а теперь вообще удалены из интерфейса Selenium.
Или ещё какое-то изменение произошло в интерфейсе. В общем-то, обычно в такой ситуации помогает простая перекомпиляция тестов.



Спасибо, так и сделал, тесты заработали.
  • 0


Количество пользователей, читающих эту тему: 1

0 пользователей, 1 гостей, 0 анонимных