2017-08-01 1 views
0

J'ai un travail Jenkins qui tire un repo git avec sous-module inclus dans le fichier .gitsubmodule. La première fois que j'ai tiré le repo, il n'y avait pas de problème, mais après avoir apporté quelques modifications au sous-module, Jenkins ne tire plus le repo sous-module mis à jour. Il tire seulement les changements effectués dans le repo principal.Jenkins - Impossible de trouver la révision d'origine/dev en cours dans le sous-module 'sous-module'

J'ai donc essayé "permettant aux sous-modules de suivi de mise à jour à la pointe de la branche" Option: enter image description here

Mais j'obtiens l'erreur suivante:

> /usr/bin/git submodule update --init --recursive --remote submodule-project 
FATAL: Command "/usr/bin/git submodule update --init --recursive --remote submodule-project" returned status code 1: 
stdout: 
stderr: fatal: Needed a single revision 
Unable to find current origin/dev revision in submodule path 'submodule-project' 

hudson.plugins.git.GitException: Command "/usr/bin/git submodule update --init --recursive --remote submodule-project" returned status code 1: 
stdout: 
stderr: fatal: Needed a single revision 
Unable to find current origin/dev revision in submodule path 'submodule-project' 

    at org.jenkinsci.plugins.gitclient.CliGitAPIImpl.launchCommandIn(CliGitAPIImpl.java:1924) 
    at org.jenkinsci.plugins.gitclient.CliGitAPIImpl.launchCommandWithCredentials(CliGitAPIImpl.java:1643) 
    at org.jenkinsci.plugins.gitclient.CliGitAPIImpl.access$300(CliGitAPIImpl.java:71) 
    at org.jenkinsci.plugins.gitclient.CliGitAPIImpl$7.execute(CliGitAPIImpl.java:1097) 
    at org.jenkinsci.plugins.gitclient.RemoteGitImpl$CommandInvocationHandler$1.call(RemoteGitImpl.java:153) 
    at org.jenkinsci.plugins.gitclient.RemoteGitImpl$CommandInvocationHandler$1.call(RemoteGitImpl.java:146) 
    at hudson.remoting.UserRequest.perform(UserRequest.java:120) 
    at hudson.remoting.UserRequest.perform(UserRequest.java:48) 
    at hudson.remoting.Request$2.run(Request.java:326) 
    at hudson.remoting.InterceptingExecutorService$1.call(InterceptingExecutorService.java:68) 
    at java.util.concurrent.FutureTask.run(FutureTask.java:266) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) 
    at java.lang.Thread.run(Thread.java:748) 
    at ......remote call to IS-MEAN_Slave(Native Method) 
    at hudson.remoting.Channel.attachCallSiteStackTrace(Channel.java:1416) 
    at hudson.remoting.UserResponse.retrieve(UserRequest.java:220) 
    at hudson.remoting.Channel.call(Channel.java:781) 
    at org.jenkinsci.plugins.gitclient.RemoteGitImpl$CommandInvocationHandler.execute(RemoteGitImpl.java:146) 
    at sun.reflect.GeneratedMethodAccessor442.invoke(Unknown Source) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:606) 
    at org.jenkinsci.plugins.gitclient.RemoteGitImpl$CommandInvocationHandler.invoke(RemoteGitImpl.java:132) 
    at com.sun.proxy.$Proxy65.execute(Unknown Source) 
    at hudson.plugins.git.extensions.impl.SubmoduleOption.onCheckoutCompleted(SubmoduleOption.java:107) 
    at hudson.plugins.git.GitSCM.checkout(GitSCM.java:1188) 
    at hudson.scm.SCM.checkout(SCM.java:485) 
    at hudson.model.AbstractProject.checkout(AbstractProject.java:1276) 
    at hudson.model.AbstractBuild$AbstractBuildExecution.defaultCheckout(AbstractBuild.java:607) 
    at jenkins.scm.SCMCheckoutStrategy.checkout(SCMCheckoutStrategy.java:86) 
    at hudson.model.AbstractBuild$AbstractBuildExecution.run(AbstractBuild.java:529) 
    at hudson.model.Run.execute(Run.java:1738) 
    at hudson.model.FreeStyleBuild.run(FreeStyleBuild.java:43) 
    at hudson.model.ResourceController.execute(ResourceController.java:98) 
    at hudson.model.Executor.run(Executor.java:410) 
Finished: FAILURE 

Mon. fichier gitmodule ressemble à ceci:

[submodule "submodule-project"] 
    path = submodule-project 
    url = <path-to-submodule-project>.git 
    branch = dev 

Toute idée comment résoudre ce problème?

Note: Je n'ai pas trouvé beaucoup de références pour la syntaxe du fichier .gitmodules, mais je pense que j'utilise correctement l'option branch. S'il vous plaît signaler pour toutes les erreurs.

Répondre

0

Je pense que vous devez indiquer le chemin de référence à utiliser lors de la mise à jour du sous-module.