forked from SAP/jenkins-library
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfatalHook.go
58 lines (50 loc) · 1.86 KB
/
fatalHook.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
package log
import (
"encoding/json"
"fmt"
"io/ioutil"
"path/filepath"
"github.com/sirupsen/logrus"
)
// FatalHook provides a logrus hook which persists details about a fatal error into the file system.
// This is helpful in order to transfer the error details to an orchestrating CI/CD system
// and by that make it possible to provide better error messages to the user.
type FatalHook struct {
Path string
CorrelationID string
}
// Levels returns the supported log level of the hook.
func (f *FatalHook) Levels() []logrus.Level {
return []logrus.Level{logrus.FatalLevel}
}
// Fire persists the error message of the fatal error as json file into the file system.
func (f *FatalHook) Fire(entry *logrus.Entry) error {
details := entry.Data
if details == nil {
details = logrus.Fields{}
}
details["message"] = entry.Message
details["error"] = fmt.Sprint(details["error"])
details["category"] = GetErrorCategory().String()
details["result"] = "failure"
details["correlationId"] = f.CorrelationID
details["time"] = entry.Time
fileName := "errorDetails.json"
if details["stepName"] != nil {
fileName = fmt.Sprintf("%v_%v", fmt.Sprint(details["stepName"]), fileName)
// ToDo: If step is called x times, and it fails multiple times the error is overwritten
}
filePath := filepath.Join(f.Path, fileName)
errDetails, _ := json.Marshal(&details)
// Logging information needed for error reporting - do not modify.
Entry().Infof("fatal error: errorDetails%v", string(errDetails))
// Sets the fatal error details in the logging framework to be consumed in the stepTelemetryData
SetFatalErrorDetail(errDetails)
_, err := ioutil.ReadFile(filePath)
if err != nil {
// do not overwrite file in case it already exists
// this helps to report the first error which occurred - instead of the last one
ioutil.WriteFile(filePath, errDetails, 0666)
}
return nil
}