blob: 55218cc057d469022be2a13ee0651ea7162a1349 [file] [log] [blame]
package com.mirantis.mk
/**
*
* Git functions
*
*/
/**
* Checkout single git repository
*
* @param path Directory to checkout repository to
* @param url Source Git repository URL
* @param branch Source Git repository branch
* @param credentialsId Credentials ID to use for source Git
*/
def checkoutGitRepository(path, url, branch, credentialsId = null){
checkout([
$class: 'GitSCM',
branches: [[name: "*/${branch}"]],
doGenerateSubmoduleConfigurations: false,
extensions: [[$class: 'RelativeTargetDirectory', relativeTargetDir: path]],
submoduleCfg: [],
userRemoteConfigs: [[url: url, credentialsId: credentialsId]]
])
dir(path) {
sh(returnStdout: true, script: 'git rev-parse HEAD').trim()
}
}
/**
* Parse HEAD of current directory and return commit hash
*/
def getGitCommit() {
git_commit = sh (
script: 'git rev-parse HEAD',
returnStdout: true
).trim()
return git_commit
}
/**
* Change actual working branch of repo
*
* @param path Path to the git repository
* @param branch Branch desired to switch to
*/
def changeGitBranch(path, branch) {
dir(path) {
git_cmd = sh (
script: "git checkout -b ${branch}",
returnStdout: true
).trim()
}
return git_cmd
}
/**
* Commit changes to the git repo
*
* @param path Path to the git repository
* @param message A commit message
*/
def commitGitChanges(path, message) {
dir(path) {
sh(
script: 'git add -A',
returnStdout: true
).trim()
git_cmd = sh(
script: "git commit -m '${message}'",
returnStdout: true
).trim()
}
return git_cmd
}
/**
* Push git changes to remote repo
*
* @param path Path to the git repository
* @param branch Branch on the remote git repository
* @param remote Name of the remote repository
*/
def pushGitChanges(path, branch = 'master', remote = 'origin') {
dir(path) {
git_cmd = sh(
script: "git push ${remote} ${branch}",
returnStdout: true
).trim()
}
return git_cmd
}
/**
* Checkout git repositories in parallel
*
* @param path Directory to checkout to
* @param url Git repository url
* @param branch Git repository branch
* @param credentialsId Credentials ID to use
* @param poll Poll automatically
* @param clean Clean status
*/
def checkoutGitParallel(path, url, branch, credentialsId = null, poll = true, clean = true) {
return {
print "Checking out ${url}, branch ${branch} into ${path}"
dir(path) {
git url: url,
branch: branch,
credentialsId: credentialsId,
poll: poll,
clean: clean
}
}
}
/**
* Mirror git repository
*/
def mirrorReporitory(sourceUrl, targetUrl, credentialsId, branches, followTags = false, gitEmail = 'jenkins@localhost', gitUsername = 'Jenkins') {
def ssl = new com.mirantis.mk.Ssl()
if (branches instanceof String) {
branches = branches.tokenize(',')
}
ssl.prepareSshAgentKey(credentialsId)
ssl.ensureKnownHosts(targetUrl)
sh "git remote | grep target || git remote add target ${targetUrl}"
agentSh "git remote update --prune"
for (i=0; i < branches.size; i++) {
branch = branches[i]
sh "git branch | grep ${branch} || git checkout -b ${branch} origin/${branch}"
sh "git branch | grep ${branch} && git checkout ${branch} && git reset --hard origin/${branch}"
sh "git config --global user.email '${gitEmail}'"
sh "git config --global user.name '${gitUsername}'"
sh "git ls-tree target/${branch} && git merge --no-edit --ff target/${branch} || echo 'Target repository is empty, skipping merge'"
followTagsArg = followTags ? "--follow-tags" : ""
agentSh "git push ${followTagsArg} target HEAD:${branch}"
}
}