feature/21176 #1
|
@ -1,9 +1,11 @@
|
|||
def agent_root_folder = '/var/lib/jenkins/.m2'
|
||||
def projects2artifacts = [:]
|
||||
def artifacts2projects = [:]
|
||||
def modules2deps = [:]
|
||||
def alreadyInTheTree = []
|
||||
def inputProject = params.jenkins_project.trim()
|
||||
def report = [:]
|
||||
|
||||
report['project'] = inputProject
|
||||
|
||||
pipeline {
|
||||
|
@ -14,7 +16,7 @@ pipeline {
|
|||
environment {
|
||||
AGENT_ROOT_FOLDER = "${agent_root_folder}"
|
||||
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 {
|
||||
sh '''
|
||||
cp $WALKER_NOTES ./walker_notes.${PIPELINE_BUILD_NUMBER}.md
|
||||
cat ./$WALKER_NOTES
|
||||
cat ./walker_notes.${PIPELINE_BUILD_NUMBER}.md
|
||||
'''
|
||||
}
|
||||
}
|
||||
|
@ -180,42 +182,15 @@ def printReport(report) {
|
|||
text += "\n"
|
||||
}
|
||||
println text
|
||||
appendNotes(text)
|
||||
|
||||
}
|
||||
|
||||
// print the final report
|
||||
def saveReport(report) {
|
||||
def text = ''
|
||||
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"
|
||||
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.
|
||||
sh("""
|
||||
echo "${report}" >> $WALKER_NOTES
|
||||
""")
|
||||
}
|
||||
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
|
||||
def printJob(job) {
|
||||
|
|
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