feature/21176 #1
|
@ -1,9 +1,11 @@
|
||||||
|
def agent_root_folder = '/var/lib/jenkins/.m2'
|
||||||
def projects2artifacts = [:]
|
def projects2artifacts = [:]
|
||||||
def artifacts2projects = [:]
|
def artifacts2projects = [:]
|
||||||
def modules2deps = [:]
|
def modules2deps = [:]
|
||||||
def alreadyInTheTree = []
|
def alreadyInTheTree = []
|
||||||
def inputProject = params.jenkins_project.trim()
|
def inputProject = params.jenkins_project.trim()
|
||||||
def report = [:]
|
def report = [:]
|
||||||
|
|
||||||
report['project'] = inputProject
|
report['project'] = inputProject
|
||||||
|
|
||||||
pipeline {
|
pipeline {
|
||||||
|
@ -14,7 +16,7 @@ pipeline {
|
||||||
environment {
|
environment {
|
||||||
AGENT_ROOT_FOLDER = "${agent_root_folder}"
|
AGENT_ROOT_FOLDER = "${agent_root_folder}"
|
||||||
PIPELINE_BUILD_NUMBER = "${env.BUILD_NUMBER}"
|
PIPELINE_BUILD_NUMBER = "${env.BUILD_NUMBER}"
|
||||||
WALKER_NOTES = "${agent_root_folder}/walker_notes.${pipeline_build_number}.md"
|
WALKER_NOTES = "${agent_root_folder}/walker_notes.${inputProject}.md"
|
||||||
manuele.simi marked this conversation as resolved
Outdated
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -83,7 +85,7 @@ pipeline {
|
||||||
script {
|
script {
|
||||||
sh '''
|
sh '''
|
||||||
cp $WALKER_NOTES ./walker_notes.${PIPELINE_BUILD_NUMBER}.md
|
cp $WALKER_NOTES ./walker_notes.${PIPELINE_BUILD_NUMBER}.md
|
||||||
cat ./$WALKER_NOTES
|
cat ./walker_notes.${PIPELINE_BUILD_NUMBER}.md
|
||||||
'''
|
'''
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -180,43 +182,16 @@ def printReport(report) {
|
||||||
text += "\n"
|
text += "\n"
|
||||||
}
|
}
|
||||||
println text
|
println text
|
||||||
|
appendNotes(text)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// print the final report
|
def appendNotes(report) {
|
||||||
manuele.simi marked this conversation as resolved
manuele.simi
commented
You don't need the shebang here. You don't need the shebang here.
roberto.cirillo
commented
Are you referring to the bash shell? I've used the bash shell otherwise the Is there an easier way to do that? Are you referring to the bash shell?
I've used the bash shell otherwise the `echo -e` option doesn't work.
Is there an easier way to do that?
manuele.simi
commented
But if it does work for you, leave like that. It's a detail. `echo` (without -e) works for sure without the shebang.
But if it does work for you, leave like that. It's a detail.
roberto.cirillo
commented
Yes it works but without the "-e" option the backslashes are not escapes. The result is an unreadable file. > `echo` (without -e) works for sure without the shebang.
>
> But if it does work for you, leave like that. It's a detail.
>
Yes it works but without the "-e" option the backslashes are not escapes. The result is an unreadable file.
|
|||||||
def saveReport(report) {
|
sh("""
|
||||||
def text = ''
|
echo "${report}" >> $WALKER_NOTES
|
||||||
def indent = '\t'
|
""")
|
||||||
text += "Dependency Report for ${report['project']}"
|
|
||||||
text += "\n\n"
|
|
||||||
text += "|--Project Maven Modules\n"
|
|
||||||
report['downstream_modules'].each { depth, artifacts ->
|
|
||||||
artifacts.each { name, data ->
|
|
||||||
text += "${indent}|--Module: ${name}\n"
|
|
||||||
text += "${indent * 2}|--Deepest Dependency Level: ${depth}\n"
|
|
||||||
text += "${indent * 2}|--Used by (Maven Modules)\n"
|
|
||||||
data['dependencies'].each { d ->
|
|
||||||
text += "${indent * 3}|--${d}"
|
|
||||||
text += "\n"
|
|
||||||
}
|
|
||||||
text += "${indent * 2}|--Referred by (Jenkins Projects)\n"
|
|
||||||
data['projects'].each { p ->
|
|
||||||
text += "${indent * 3}|--${p}"
|
|
||||||
text += "\n"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
text += "\n\n"
|
|
||||||
text += "|--All Downstream Projects\n"
|
|
||||||
report['downstream_projects'].unique().sort()
|
|
||||||
report['downstream_projects'].each { p ->
|
|
||||||
text += "${indent}|--${p}"
|
|
||||||
text += "\n"
|
|
||||||
}
|
|
||||||
text > WALKER_NOTES
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// debug job
|
// debug job
|
||||||
def printJob(job) {
|
def printJob(job) {
|
||||||
println("fullname ${job.fullName}")
|
println("fullname ${job.fullName}")
|
||||||
|
|
Loading…
Reference in New Issue
PIPELINE_BUILD_NUMBER
instead ofinputProject
to make the notes' filename unique..txt
.Thanks Manuele for your feedback!
In order to preserve an unique filename as you suggest, I can add to the current filename, the
PIPELINE_BUILD_NUMBER
.WALKER_NOTES = "${agent_root_folder}/walker_notes.${inputProject}.${PIPELINE_BUILD_NUMBER}.md"
WALKER_NOTES = "${agent_root_folder}/walker_notes.${inputProject}.${PIPELINE_BUILD_NUMBER}.txt"
Well, it's a filename attached to an email with a subject related to the component. I mean, the filename should not really matter. And you could have issues with the component name in the filename.
Neverthlees, adding the pipeline number will make it unique.
OK I'm going to remove the component name from the filename