2016-11-07 3 views
0

Я перемещаю некоторые сборки из бамбука в jenkins, используя тот же скрипт построения градиента для создания приложения. С Artifactory выключен, сборка прошла успешно, но при включении он терпит неудачу с:Jenkins/Artifactory - Невозможно найти метод create()

09:22:08.568 [ERROR] [org.gradle.BuildExceptionReporter] FAILURE: Build failed with an exception. 
09:22:08.569 [ERROR] [org.gradle.BuildExceptionReporter] 
09:22:08.569 [ERROR] [org.gradle.BuildExceptionReporter] * Where: 
09:22:08.569 [ERROR] [org.gradle.BuildExceptionReporter] Initialization script '/tmp/init-artifactory2218166479825929225gradle' line: 20 
09:22:08.570 [ERROR] [org.gradle.BuildExceptionReporter] 
09:22:08.570 [ERROR] [org.gradle.BuildExceptionReporter] * What went wrong: 
09:22:08.570 [ERROR] [org.gradle.BuildExceptionReporter] Failed to notify build listener. 
09:22:08.570 [ERROR] [org.gradle.BuildExceptionReporter] > Failed to notify build listener. 
09:22:08.571 [ERROR] [org.gradle.BuildExceptionReporter] > Could not find method create() for arguments [artifactoryPublish, class org.jfrog.gradle.plugin.artifactory.task.ArtifactoryTask] on task set. 

Сценарий инициализации создается с помощью Artifactory плагина и выглядит следующим образом:

import org.jfrog.gradle.plugin.artifactory.ArtifactoryPlugin 
import org.jfrog.gradle.plugin.artifactory.task.ArtifactoryTask 

initscript { 
    dependencies { 
     classpath fileTree('/var/lib/jenkins/cache/artifactory-plugin/2.7.2') 
    } 
} 

addListener(new BuildInfoPluginListener()) 
class BuildInfoPluginListener extends BuildAdapter { 

    def void projectsLoaded(Gradle gradle) { 
     gradle.startParameter.getProjectProperties().put("build.start", Long.toString(System.currentTimeMillis())) 
     Project root = gradle.getRootProject() 
     root.logger.debug("Artifactory plugin: projectsEvaluated: ${root.name}") 
     if (!"buildSrc".equals(root.name)) { 
      root.allprojects { 
       apply { 
        apply plugin: ArtifactoryPlugin 
       } 
      } 
     } 

     // Set the "archives" configuration to all Artifactory tasks. 
     for (Project p : root.getAllprojects()) { 
      Task t = p.getTasks().findByName(ArtifactoryTask.BUILD_INFO_TASK_NAME) 
      if (t != null) { 
       ArtifactoryTask task = (ArtifactoryTask)t 
       task.setAddArchivesConfigToTask(true) 
      } 
     } 
    } 
} 

Мы используем Gradle 1.5 для этого проекта, версия была объявлена ​​в build.gradle.

build.gradle:

apply plugin: 'groovy' 
apply from: 'scripts/wrapper.gradle' 
gradleVersion='1.5' 

group = 'com.company.build' 

task testBuildSingle(type: GradleBuild) { 
    buildFile = 'test/single/build.gradle' 
    tasks = ['clean', 'build'] 
} 

task testBuildMulti(type: GradleBuild) { 
    buildFile = 'test/multi/build.gradle' 
    tasks = ['clean', 'build'] 
} 

test.dependsOn('testBuildSingle') 

task dist(type: Copy) { 
    from 'scripts' 
    into("$buildDir/scripts") 
    eachFile({ 
     def file = file("scripts/${it.getPath()}") 
     println file 
     artifacts.add('archives', file) 
    }) 
} 

dist.dependsOn('test') 
+0

Как вы можете видеть на странице Jenkins Artifactory Plugin https://wiki.jenkins-ci.org/pages/viewpage.action?pageId=57182305. 'Artifactory Plugin 2.7.2' требует' Gradle 1.15'. Проблема может быть вызвана несовместимостью версии. –

+0

У меня есть плагин gradle 1.25, и я попытался построить w/different gradle v. In build scripting, но он не изменился. – James

+0

Вы можете поделиться с друзьями "gradle.build", пожалуйста? –

ответ

0

Вы используете последнюю версию плагина Artifactory и строить-инфо-экстрактор-Gradle но ваша Gradle версия устарела. Попробуйте использовать последнюю версию gradle 3.1

0

Если ваш скрипт класса уже применяет плагин «com.jfrog.artifactory», то в задании Jenkins вы должны установить, что «Project использует плагин Artifactory», чтобы убедиться, что Jenkins не использует добавьте скрипт инициализации. Бамбук имеет тот же флажок для задач Gradle Artifactory.

 Смежные вопросы

  • Нет связанных вопросов^_^