1
0
mirror of https://github.com/SAP/jenkins-library.git synced 2025-01-18 05:18:24 +02:00

Add Checkmarx failure message to Piper error log (#3716)

This commit is contained in:
Adrien 2022-05-03 17:34:14 +02:00 committed by GitHub
parent 3f54eb74bc
commit 9d56cda0f9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -408,20 +408,20 @@ func pollScanStatus(sys checkmarx.System, scan checkmarx.Scan) error {
status := "Scan phase: New"
pastStatus := status
log.Entry().Info(status)
stepDetail := "..."
stageDetail := "..."
for true {
stepDetail := "..."
stageDetail := "..."
var detail checkmarx.ScanStatusDetail
status, detail = sys.GetScanStatusAndDetail(scan.ID)
if status == "Finished" || status == "Canceled" || status == "Failed" {
break
}
if len(detail.Stage) > 0 {
stageDetail = detail.Stage
}
if len(detail.Step) > 0 {
stepDetail = detail.Step
}
if status == "Finished" || status == "Canceled" || status == "Failed" {
break
}
status = fmt.Sprintf("Scan phase: %v (%v / %v)", status, stageDetail, stepDetail)
if pastStatus != status {
@ -436,7 +436,10 @@ func pollScanStatus(sys checkmarx.System, scan checkmarx.Scan) error {
return fmt.Errorf("scan canceled via web interface")
}
if status == "Failed" {
return fmt.Errorf("scan failed, please check the Checkmarx UI for details")
if strings.Contains(stageDetail, "<ErrorCode>17033</ErrorCode>") { // Translate a cryptic XML error into a human-readable message
stageDetail = "Failed to start scanning due to one of following reasons: source folder is empty, all source files are of an unsupported language or file format"
}
return fmt.Errorf("Checkmarx scan failed with the following error: %v", stageDetail)
}
return nil
}