2021-06-11 05:05:43 +08:00
|
|
|
package testutil
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"fmt"
|
2022-10-26 18:06:08 +08:00
|
|
|
"log"
|
2021-06-11 05:05:43 +08:00
|
|
|
|
|
|
|
|
"github.com/influxdata/telegraf"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
var _ telegraf.Logger = &CaptureLogger{}
|
|
|
|
|
|
|
|
|
|
// CaptureLogger defines a logging structure for plugins.
|
|
|
|
|
type CaptureLogger struct {
|
|
|
|
|
Name string // Name is the plugin name, will be printed in the `[]`.
|
|
|
|
|
LastError string
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Errorf logs an error message, patterned after log.Printf.
|
|
|
|
|
func (l *CaptureLogger) Errorf(format string, args ...interface{}) {
|
|
|
|
|
s := fmt.Sprintf("E! ["+l.Name+"] "+format, args...)
|
|
|
|
|
l.LastError = s
|
|
|
|
|
log.Print(s)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Error logs an error message, patterned after log.Print.
|
|
|
|
|
func (l *CaptureLogger) Error(args ...interface{}) {
|
|
|
|
|
s := fmt.Sprint(append([]interface{}{"E! [" + l.Name + "] "}, args...)...)
|
|
|
|
|
l.LastError = s
|
|
|
|
|
log.Print(s)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Debugf logs a debug message, patterned after log.Printf.
|
|
|
|
|
func (l *CaptureLogger) Debugf(format string, args ...interface{}) {
|
|
|
|
|
log.Printf("D! ["+l.Name+"] "+format, args...)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Debug logs a debug message, patterned after log.Print.
|
|
|
|
|
func (l *CaptureLogger) Debug(args ...interface{}) {
|
|
|
|
|
log.Print(append([]interface{}{"D! [" + l.Name + "] "}, args...)...)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Warnf logs a warning message, patterned after log.Printf.
|
|
|
|
|
func (l *CaptureLogger) Warnf(format string, args ...interface{}) {
|
|
|
|
|
log.Printf("W! ["+l.Name+"] "+format, args...)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Warn logs a warning message, patterned after log.Print.
|
|
|
|
|
func (l *CaptureLogger) Warn(args ...interface{}) {
|
|
|
|
|
log.Print(append([]interface{}{"W! [" + l.Name + "] "}, args...)...)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Infof logs an information message, patterned after log.Printf.
|
|
|
|
|
func (l *CaptureLogger) Infof(format string, args ...interface{}) {
|
|
|
|
|
log.Printf("I! ["+l.Name+"] "+format, args...)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Info logs an information message, patterned after log.Print.
|
|
|
|
|
func (l *CaptureLogger) Info(args ...interface{}) {
|
|
|
|
|
log.Print(append([]interface{}{"I! [" + l.Name + "] "}, args...)...)
|
|
|
|
|
}
|