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

Improve logging for ABAP steps (#4316)

* Fix logs

* Increase number of entries
This commit is contained in:
Daniel Mieg 2023-04-04 12:46:03 +02:00 committed by GitHub
parent 549b32c675
commit 7147209e3e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 54 additions and 39 deletions

View File

@ -6,6 +6,7 @@ import (
"io/ioutil" "io/ioutil"
"reflect" "reflect"
"sort" "sort"
"strconv"
"strings" "strings"
"time" "time"
@ -15,7 +16,7 @@ import (
) )
const failureMessageClonePull = "Could not pull the Repository / Software Component " const failureMessageClonePull = "Could not pull the Repository / Software Component "
const numberOfEntriesPerPage = 100 const numberOfEntriesPerPage = 100000
const logOutputStatusLength = 10 const logOutputStatusLength = 10
const logOutputTimestampLength = 29 const logOutputTimestampLength = 29
@ -45,11 +46,7 @@ func PollEntity(repositoryName string, connectionDetails ConnectionDetailsHTTP,
func PrintLogs(repositoryName string, connectionDetails ConnectionDetailsHTTP, client piperhttp.Sender) { func PrintLogs(repositoryName string, connectionDetails ConnectionDetailsHTTP, client piperhttp.Sender) {
connectionDetails.URL = connectionDetails.URL + "?$expand=to_Log_Overview" connectionDetails.URL = connectionDetails.URL + "?$expand=to_Log_Overview"
entity, _, err := GetStatus(failureMessageClonePull+repositoryName, connectionDetails, client) entity, _, err := GetStatus(failureMessageClonePull+repositoryName, connectionDetails, client)
if err != nil { if err != nil || len(entity.ToLogOverview.Results) == 0 {
return
}
if len(entity.ToLogOverview.Results) == 0 {
// return if no logs are available // return if no logs are available
return return
} }
@ -59,11 +56,7 @@ func PrintLogs(repositoryName string, connectionDetails ConnectionDetailsHTTP, c
return entity.ToLogOverview.Results[i].Index < entity.ToLogOverview.Results[j].Index return entity.ToLogOverview.Results[i].Index < entity.ToLogOverview.Results[j].Index
}) })
logOutputPhaseLength, logOutputLineLength := calculateLenghts(entity) printOverview(entity)
printOverview(logOutputLineLength, logOutputPhaseLength, entity)
dashedLine(logOutputLineLength)
// Print Details // Print Details
for _, logEntryForDetails := range entity.ToLogOverview.Results { for _, logEntryForDetails := range entity.ToLogOverview.Results {
@ -74,14 +67,22 @@ func PrintLogs(repositoryName string, connectionDetails ConnectionDetailsHTTP, c
return return
} }
func printOverview(logOutputLineLength int, logOutputPhaseLength int, entity PullEntity) { func printOverview(entity PullEntity) {
logOutputPhaseLength, logOutputLineLength := calculateLenghts(entity)
log.Entry().Infof("\n") log.Entry().Infof("\n")
dashedLine(logOutputLineLength)
printDashedLine(logOutputLineLength)
log.Entry().Infof("| %-"+fmt.Sprint(logOutputPhaseLength)+"s | %"+fmt.Sprint(logOutputStatusLength)+"s | %-"+fmt.Sprint(logOutputTimestampLength)+"s |", "Phase", "Status", "Timestamp") log.Entry().Infof("| %-"+fmt.Sprint(logOutputPhaseLength)+"s | %"+fmt.Sprint(logOutputStatusLength)+"s | %-"+fmt.Sprint(logOutputTimestampLength)+"s |", "Phase", "Status", "Timestamp")
dashedLine(logOutputLineLength)
printDashedLine(logOutputLineLength)
for _, logEntry := range entity.ToLogOverview.Results { for _, logEntry := range entity.ToLogOverview.Results {
log.Entry().Infof("| %-"+fmt.Sprint(logOutputPhaseLength)+"s | %"+fmt.Sprint(logOutputStatusLength)+"s | %-"+fmt.Sprint(logOutputTimestampLength)+"s |", logEntry.Name, logEntry.Status, ConvertTime(logEntry.Timestamp)) log.Entry().Infof("| %-"+fmt.Sprint(logOutputPhaseLength)+"s | %"+fmt.Sprint(logOutputStatusLength)+"s | %-"+fmt.Sprint(logOutputTimestampLength)+"s |", logEntry.Name, logEntry.Status, ConvertTime(logEntry.Timestamp))
} }
printDashedLine(logOutputLineLength)
} }
func calculateLenghts(entity PullEntity) (int, int) { func calculateLenghts(entity PullEntity) (int, int) {
@ -96,46 +97,57 @@ func calculateLenghts(entity PullEntity) (int, int) {
return phaseLength, lineLength return phaseLength, lineLength
} }
func dashedLine(i int) { func printDashedLine(i int) {
log.Entry().Infof(strings.Repeat("-", i)) log.Entry().Infof(strings.Repeat("-", i))
} }
func printLog(logEntry LogResultsV2, connectionDetails ConnectionDetailsHTTP, client piperhttp.Sender) { func printLog(logOverviewEntry LogResultsV2, connectionDetails ConnectionDetailsHTTP, client piperhttp.Sender) {
readNextLogEntries := true
page := 0 page := 0
printHeader(logEntry) printHeader(logOverviewEntry)
for { for {
query := getLogProtocolQuery(page) connectionDetails.URL = logOverviewEntry.ToLogProtocol.Deferred.URI + getLogProtocolQuery(page)
connectionDetails.URL = logEntry.ToLogProtocol.Deferred.URI + query
entity, err := GetProtocol(failureMessageClonePull, connectionDetails, client) entity, err := GetProtocol(failureMessageClonePull, connectionDetails, client)
if (err != nil || reflect.DeepEqual(entity, LogProtocolResults{})) {
readNextLogEntries = false
}
sort.SliceStable(entity.Results, func(i, j int) bool {
return entity.Results[i].ProtocolLine < entity.Results[j].ProtocolLine
})
if logEntry.Status != `Success` { printLogProtocolEntries(logOverviewEntry, entity)
for _, entry := range entity.Results {
log.Entry().Info(entry.Description)
}
} else {
for _, entry := range entity.Results {
log.Entry().Debug(entry.Description)
}
}
page += 1 page += 1
if !readNextLogEntries { if allLogsHaveBeenPrinted(entity, page, err) {
break break
} }
} }
} }
func printLogProtocolEntries(logEntry LogResultsV2, entity LogProtocolResults) {
sort.SliceStable(entity.Results, func(i, j int) bool {
return entity.Results[i].ProtocolLine < entity.Results[j].ProtocolLine
})
if logEntry.Status != `Success` {
for _, entry := range entity.Results {
log.Entry().Info(entry.Description)
}
} else {
for _, entry := range entity.Results {
log.Entry().Debug(entry.Description)
}
}
}
func allLogsHaveBeenPrinted(entity LogProtocolResults, page int, err error) bool {
allPagesHaveBeenRead := false
numberOfProtocols, errConversion := strconv.Atoi(entity.Count)
if errConversion == nil {
allPagesHaveBeenRead = numberOfProtocols <= page*numberOfEntriesPerPage
}
return (err != nil || allPagesHaveBeenRead || reflect.DeepEqual(entity.Results, LogProtocolResults{}))
}
func printHeader(logEntry LogResultsV2) { func printHeader(logEntry LogResultsV2) {
if logEntry.Status != `Success` { if logEntry.Status != `Success` {
log.Entry().Infof("\n") log.Entry().Infof("\n")
@ -154,7 +166,7 @@ func getLogProtocolQuery(page int) string {
skip := page * numberOfEntriesPerPage skip := page * numberOfEntriesPerPage
top := numberOfEntriesPerPage top := numberOfEntriesPerPage
return fmt.Sprintf("?$skip=%s&$top=%s", fmt.Sprint(skip), fmt.Sprint(top)) return fmt.Sprintf("?$skip=%s&$top=%s&$inlinecount=allpages", fmt.Sprint(skip), fmt.Sprint(top))
} }
func GetStatus(failureMessage string, connectionDetails ConnectionDetailsHTTP, client piperhttp.Sender) (body PullEntity, status string, err error) { func GetStatus(failureMessage string, connectionDetails ConnectionDetailsHTTP, client piperhttp.Sender) (body PullEntity, status string, err error) {
@ -384,6 +396,7 @@ type URI struct {
type LogProtocolResults struct { type LogProtocolResults struct {
Results []LogProtocol `json:"results"` Results []LogProtocol `json:"results"`
Count string `json:"__count"`
} }
type LogProtocol struct { type LogProtocol struct {

View File

@ -4,6 +4,7 @@ import (
"encoding/json" "encoding/json"
"fmt" "fmt"
"io/ioutil" "io/ioutil"
"math"
"os" "os"
"testing" "testing"
@ -15,6 +16,7 @@ var executionLogString string
func init() { func init() {
executionLog := LogProtocolResults{ executionLog := LogProtocolResults{
Count: fmt.Sprint(math.Round(numberOfEntriesPerPage * 1.5)),
Results: []LogProtocol{ Results: []LogProtocol{
{ {
ProtocolLine: 1, ProtocolLine: 1,
@ -37,7 +39,7 @@ func TestPollEntity(t *testing.T) {
logResultSuccess := fmt.Sprintf(`{"d": { "sc_name": "/DMO/SWC", "status": "S", "to_Log_Overview": { "results": [ { "log_index": 1, "log_name": "Main Import", "type_of_found_issues": "Success", "timestamp": "/Date(1644332299000+0000)/", "to_Log_Protocol": { "results": [ { "log_index": 1, "index_no": "1", "log_name": "", "type": "Info", "descr": "Main import", "timestamp": null, "criticality": 0 } ] } } ] } } }`) logResultSuccess := fmt.Sprintf(`{"d": { "sc_name": "/DMO/SWC", "status": "S", "to_Log_Overview": { "results": [ { "log_index": 1, "log_name": "Main Import", "type_of_found_issues": "Success", "timestamp": "/Date(1644332299000+0000)/", "to_Log_Protocol": { "results": [ { "log_index": 1, "index_no": "1", "log_name": "", "type": "Info", "descr": "Main import", "timestamp": null, "criticality": 0 } ] } } ] } } }`)
client := &ClientMock{ client := &ClientMock{
BodyList: []string{ BodyList: []string{
`{"d" : [] }`, `{"d" : ` + executionLogString + `}`,
`{"d" : ` + executionLogString + `}`, `{"d" : ` + executionLogString + `}`,
logResultSuccess, logResultSuccess,
`{"d" : { "status" : "S" } }`, `{"d" : { "status" : "S" } }`,
@ -77,7 +79,7 @@ func TestPollEntity(t *testing.T) {
logResultError := fmt.Sprintf(`{"d": { "sc_name": "/DMO/SWC", "status": "S", "to_Log_Overview": { "results": [ { "log_index": 1, "log_name": "Main Import", "type_of_found_issues": "Error", "timestamp": "/Date(1644332299000+0000)/", "to_Log_Protocol": { "results": [ { "log_index": 1, "index_no": "1", "log_name": "", "type": "Info", "descr": "Main import", "timestamp": null, "criticality": 0 } ] } } ] } } }`) logResultError := fmt.Sprintf(`{"d": { "sc_name": "/DMO/SWC", "status": "S", "to_Log_Overview": { "results": [ { "log_index": 1, "log_name": "Main Import", "type_of_found_issues": "Error", "timestamp": "/Date(1644332299000+0000)/", "to_Log_Protocol": { "results": [ { "log_index": 1, "index_no": "1", "log_name": "", "type": "Info", "descr": "Main import", "timestamp": null, "criticality": 0 } ] } } ] } } }`)
client := &ClientMock{ client := &ClientMock{
BodyList: []string{ BodyList: []string{
`{"d" : [] }`, `{"d" : ` + executionLogString + `}`,
`{"d" : ` + executionLogString + `}`, `{"d" : ` + executionLogString + `}`,
logResultError, logResultError,
`{"d" : { "status" : "E" } }`, `{"d" : { "status" : "E" } }`,