Получение ошибки permgen при запуске easyb \ selenium - PullRequest
1 голос
/ 20 января 2012

У меня в игре 6 технологий

easyB Селен Gradle Муравей Джава Дженкинс

Мы используем easyB для написания сценариев
Эти сценарии в свою очередь вызывают Селен
Наконец, мы используем Gradle , чтобы начать все истории. А так как у нас нет подключаемого модуля gradle для easyB, gradle действительно использует ant для запуска easyB.

Этот скрипт Gradle наконец-то выполняется с помощью Jenkins job

Полное выполнение занимает около 3-4 часа . На полпути мы получаем ошибку perm-gen

Я не уверен , какой процесс нуждается в увеличении в PermGen

EasyB? Муравей? Gradle


Сообщение об ошибке
[ant: easyb] значение повтора теперь: 2
[ant: easyb] objectID установлен в: 60868
[ant: easyb] перерыв после создания subjectID 60868
[ant: easyb] Создание визита >>>>>> Предварительная обработка
[ant: easyb] Создание группы изображений >>>>>> auto-gp1
[ant: easyb] Произошла ошибка при запуске вашей истории или спецификации easyb
[ant: easyb] java.lang.OutOfMemoryError: Пробел PermGen
[ant: easyb] easyb выполнение FAILED

FAILURE: сборка не удалась, исключение.


Сценарий Gradle

check << {
    def script = new GroovyShell()
    script.run(new File('InitializeReport.groovy'))

    ant.taskdef(name: "easyb", classname:"org.easyb.ant.BehaviorRunnerTask", classpath: sourceSets.test.runtimeClasspath.asPath)

    ant.easyb( classpath: sourceSets.test.runtimeClasspath.asPath, failureProperty:'easyb_failed' ,tags:tags) {
        report( location:"${project.testResultsDir}/story."+format, format:format )
        behaviors( dir: storiesHome ) {
            include( name:storyToBeExecuted )
        }
   }

    ant.fail( if:'easyb_failed', message: 'Failures in easyb stories' )
}

Это то, что я вижу на консоли Jenkins Обратите внимание, как параметры памяти передаются команде Gradle, а не команде Java, выполняющей сценарии easyB? Вот где- я думаю, что проблема в ...

[jenkins @ bil-dev-006v bin] $ ps -ef | grep gradle

Дженкинс 18420 4714 9 23:04? 00:00:16 /usr/java/jdk1.6.0_20/bin/java -XX: MaxPermSize = 700 м -milestone-1 / lib / gradle-launcher-1.0-milestone-1.jar -Dorg.gradle.appname = gradle org.gradle.launcher.GradleMain -PstoryName = -PstoriesHome = check -info

Дженкинс 18579 18420 13 23:04? 00:00:21 /usr/java/jdk1.6.0_20/jre/bin/java -classpath / jenkins / jobs / полная загрузка гелия / рабочая область / trunk / build / classes / main: / jenkins / jobs / helium- полный перспективе / рабочее пространство / багажник / Библиотека / Обще-Ланг-2.4.jar: /jenkins/jobs/helium-complete-run/workspace/trunk/lib/httpclient-4.1.1.jar: / Jenkins / работа / гелием полная перспектива / рабочее пространство / багажник / Библиотека / XML-apis.jar: /jenkins/jobs/helium-complete-run/workspace/trunk/lib/activation.jar: / Jenkins / работа / гелий-полная перспектива / рабочее пространство / багажник / Библиотека / xercesSamples.jar: /jenkins/jobs/helium-complete-run/workspace/trunk/lib/safe-client.jar: / Jenkins / работа / гелий-полная перспектива / рабочее пространство / багажник / Библиотека / безопасность. баночка: /jenkins/jobs/helium-complete-run/workspace/trunk/lib/json-lib-2.4-jdk15.jar: / Jenkins / работа / гелий-полная перспектива / рабочее место / багажник / Библиотека / HTTP-builder- 0.5.1.jar: /jenkins/jobs/helium-complete-run/workspace/trunk/lib/safe-import.jar: /jenkins/jobs/helium-complete-run/workspace/trunk/lib/mail.jar: /jenkins/jobs/helium-complete-run/workspace/trunk/lib/ojdbc14.jar:/jenkins/jobs/helium-complet е-бег / рабочее пространство / багажник / Библиотека / httpcore-4.1.jar: /jenkins/jobs/helium-complete-run/workspace/trunk/lib/xercesImpl.jar: / Jenkins / работа / гелий-полная перспектива / рабочее пространство / багажник / Библиотека / cacher.jar: /jenkins/jobs/helium-complete-run/workspace/trunk/lib/serializer.jar: /jenkins/jobs/helium-complete-run/workspace/trunk/lib/resolver.jar: /jenkins/jobs/helium-complete-run/workspace/trunk/lib/cache-verifier.jar:/opt/jenkins/.gradle/cache/org.easyb/easyb/jars/easyb-0.9.7.jar:/ выбрать / Jenkins / .gradle / кэш / Обще-CLI / Обще-CLI / банки / Обще-кли-1.1.jar: /opt/jenkins/.gradle/cache/org.codehaus.groovy/groovy-all/jars/groovy -все-1.7.2.jar: /opt/jenkins/.gradle/cache/org.seleniumhq.selenium.client-drivers/selenium-java-client-driver/jars/selenium-java-client-driver-1.0.1 .jar: /opt/jenkins/.gradle/cache/log4j/log4j/bundles/log4j-1.2.16.jar: /opt/jenkins/.gradle/cache/org.codehaus.groovy/groovy/jars/groovy-1.8 .2.jar: /opt/jenkins/.gradle/cache/antlr/antlr/jars/antlr-2.7.7.jar: /opt/jenkins/.gradle/cache/asm/asm/jars/asm-3.2.jar : / выбрать / Jenkins / .gradle / кэш / ASM / ASM-фонд / банки / ASM-Обще-3.2.jar: /opt/jenkins/.gradle/cache/asm/asm-tree/jars/asm-tree-3.2.jar : /opt/jenkins/.gradle/cache/asm/asm-util/jars/asm-util-3.2.jar: /opt/jenkins/.gradle/cache/asm/asm-analysis/jars/asm-analysis-3.2 .jar org.easyb.BehaviorRunner -outfail failed.txt -html /jenkins/jobs/helium-complete-run/workspace/trunk/build/test-results/storycaseassigment_inter-intra.html / jenkins / jobs / helium-complete-run /workspace/trunk/src/test/stories/caseassigment/inter-intra/ca_interintra.story

Ответы [ 2 ]

0 голосов
/ 20 января 2012

Как вы это реализовали, тесты easyB будут выполняться в «основной» JVM Gradle (если только задача easyB Ant не разветвляет новую JVM, в чем я сомневаюсь.) Один из способов передачи параметров JVM этому процессу - переменная окружения GRADLE_OPTS:

export GRADLE_OPTS="-XX:MaxPermSize=128m"

Другими способами установки этой опции являются properties.gradle (подробности см. Руководство пользователя Gradle ) или настройка скрипта gradlew (если вы используете оболочку Gradle).

0 голосов
/ 20 января 2012

Вам нужно увеличить пространство perm gen, вы можете сделать это, установив параметр max в настройках виртуальной машины.В командной строке запустите Java со следующей опцией:

-XX: MaxPermSize = 128 м

См. Также: http://www.freshblurbs.com/explaining-java-lang-outofmemoryerror-permgen-space

...