I am trying to get a prebuild merge to work inside a multibranch pipeline and I would like to avoid having to hardcode the git url in my pipeline script.
It seems like scm step must store the url somehow, but I cannot figure out how to access it.
I am trying to get a prebuild merge to work inside a multibranch pipeline and I would like to avoid having to hardcode the git url in my pipeline script.
It seems like scm step must store the url somehow, but I cannot figure out how to access it.
Inspired by a comment in answer by @BitwiseMan, I have found a (hacky) way to get the URL without RejectedAccessException:
Please note that it must be done after
checkout scm
. Basically, you must be in a checked out git repository (i.e. has.git/config
file in it)You have to store the git url inside your parent job and pass the parameter to the child phase
or you can simply clone the project on your root job and work form there.
Use the https://wiki.jenkins-ci.org/display/JENKINS/Git+Plugin its the Jenkins git plugin
You are correct, the
scm
object does have the information you need.When using git as the source control in a Pipeline project (or Multibranch Pipeline project), the
scm
global variable will be an instance of GitSCM. That means that `scm.getUserRemoteConfigs()' will return a list of UserRemoteConfig instances. Those instances have the git remote's name, url, and refspec. You can iterate over that list to find a matching remote, or just take the first one if your sure you only have one url.NOTES
RejectedAccessException - The
getUserRemoteConfigs
andgetUrl
methods will both throworg.jenkinsci.plugins.scriptsecurity.sandbox.RejectedAccessException
until you manually approve them, under "Manage Jenkins -> In-process Script Approval". The only way I've found to do this is to try running the script, have it throw an access exception, approve the one method that caused the exception, and repeat for each method until no more access exceptions are thrown. Happily the setting is server-wide, so you only have to do this once per jenkins controller, not for each pipeline job.GitHub - While testing with a GitHub-sourced multibranch pipeline,
getUserRemoteConfigs
returned two UserRemoteConfig instances, one for regular branches and another for pull requests. These had the same url so no big deal, but something to keep in mind. For example, in a project using an HTTPS-based connection: