本文整理匯總了Golang中github.com/mediaFORGE/gol.LogMessage類的典型用法代碼示例。如果您正苦於以下問題:Golang LogMessage類的具體用法?Golang LogMessage怎麽用?Golang LogMessage使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了LogMessage類的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: Filter
func (f *InfoFilter) Filter(msg *gol.LogMessage) bool {
if s, err := msg.Severity(); err != nil {
// no severity
return true
} else {
return s < severity.Warning
}
}
示例2: Filter
// Filter performs a filter check on the given message.
// Returns whether or not a given message should be filtered.
func (f Severity) Filter(msg *gol.LogMessage) bool {
if s, err := msg.Severity(); err != nil {
// no severity
return true
} else {
return s > f.minimum
}
}
示例3: Format
// Format formats the log message.
func (f Text) Format(msg *gol.LogMessage) (string, error) {
lmsg := msg.FieldLength()
buffer := make([]string, lmsg, lmsg)
i := 0
for k, v := range *msg {
buffer[i] = fmt.Sprintf("%s=%s", k, v)
i += 1
}
return fmt.Sprintf("%s\n", strings.Join(buffer, " ")), nil
}
示例4: TestTimestamp
func (s *MessageTestSuite) TestTimestamp() {
var msg *gol.LogMessage
msg = &gol.LogMessage{"key": "value"}
v, err := msg.Timestamp()
assert.Equal(s.T(), fmt.Errorf("Message does not contain field timestamp"), err)
assert.Nil(s.T(), v)
msg = gol.NewInfo("key", "value")
v, err = msg.Timestamp()
assert.Nil(s.T(), err)
assert.True(s.T(), v.Before(time.Now()))
}
示例5: Filter
// Filter performs a filter check on the given message.
// Returns whether or not a given message should be filtered.
func (f Threshold) Filter(msg *gol.LogMessage) bool {
var start *time.Time
var stop *time.Time
var err error
if start, err = msg.Start(); err != nil {
return true
}
if stop, err = msg.Stop(); err != nil {
return true
}
return stop.Sub(*start) >= f.threshold
}
示例6: TestGet
func (s *MessageTestSuite) TestGet() {
msg := gol.LogMessage{
"key": "value",
}
assert.Equal(s.T(), msg["key"], "value")
v, err := msg.Get("key")
assert.Equal(s.T(), "value", v)
assert.Nil(s.T(), err)
v, err = msg.Get("unknown")
assert.Nil(s.T(), v)
assert.Equal(s.T(), fmt.Errorf("Message does not contain field unknown"), err)
}
示例7: Format
// Format formats the log message.
func (f Custom) Format(msg *gol.LogMessage) (string, error) {
lmsg := msg.FieldLength()
buffer := make([]string, lmsg, lmsg)
i := 0
for k, v := range *msg {
if k != fields.Severity && k != fields.Timestamp {
buffer[i] = fmt.Sprintf("%s:'%s'", k, v)
i += 1
}
}
t, _ := msg.Timestamp()
if severity, err := msg.Severity(); err != nil {
return fmt.Sprintf("%s UNKNOWN %s\n", t.String(), strings.Join(buffer, " ")), nil
} else {
switch severity >= field_severity.Error {
case true:
return fmt.Sprintf("%s %s %s\n", t.String(), color.RedString("%s", severity), strings.Join(buffer, " ")), nil
default:
return fmt.Sprintf("%s %s %s\n", t.String(), severity, strings.Join(buffer, " ")), nil
}
}
}
示例8: Send
// Send process log message.
func (l *Logger) Send(m *gol.LogMessage) (err error) {
if m == nil {
return
}
if l.Formatter() == nil {
return fmt.Errorf("log formatter is nil")
}
var msg string
if msg, err = l.Formatter().Format(m); err != nil {
return
}
var lvl severity.Type
if lvl, err = m.Severity(); err != nil {
return
}
switch lvl {
case severity.Emergency:
return l.writer.Emerg(msg)
case severity.Alert:
return l.writer.Alert(msg)
case severity.Critical:
return l.writer.Crit(msg)
case severity.Error:
return l.writer.Err(msg)
case severity.Warning:
return l.writer.Warning(msg)
case severity.Notice:
return l.writer.Notice(msg)
case severity.Info:
return l.writer.Info(msg)
case severity.Debug:
return l.writer.Debug(msg)
default:
return l.writer.Info(msg)
}
}
示例9: TestGetSetStop
func (s *MessageTestSuite) TestGetSetStop() {
msg := gol.LogMessage{
"key": "value",
}
v, err := msg.Stop()
assert.Equal(s.T(), &time.Time{}, v)
assert.Equal(s.T(), fmt.Errorf("Message does not contain field stop"), err)
stop := time.Now()
msg.SetStop(&stop)
v, err = msg.Stop()
assert.Equal(s.T(), &stop, v)
assert.Nil(s.T(), err)
}
示例10: TestGetSetSeverity
func (s *MessageTestSuite) TestGetSetSeverity() {
msg := gol.LogMessage{
"key": "value",
}
v, err := msg.Severity()
assert.Equal(s.T(), severity.Type(-1), v)
assert.Equal(s.T(), fmt.Errorf("Message does not contain field severity"), err)
lvl := severity.Type(severity.Emergency)
msg.SetSeverity(lvl)
v, err = msg.Severity()
assert.Equal(s.T(), lvl, v)
assert.Nil(s.T(), err)
}
示例11: TestFieldLength
func (s *MessageTestSuite) TestFieldLength() {
msg := gol.LogMessage{
"key": "value",
}
assert.Equal(s.T(), 1, msg.FieldLength())
}