2014-06-23 11:49:04 +00:00
|
|
|
package ethlog
|
|
|
|
|
|
|
|
import (
|
2014-06-26 17:45:57 +00:00
|
|
|
"fmt"
|
|
|
|
"io/ioutil"
|
2014-10-14 12:35:16 +00:00
|
|
|
"math/rand"
|
2014-06-26 17:45:57 +00:00
|
|
|
"os"
|
|
|
|
"testing"
|
2014-10-14 12:35:16 +00:00
|
|
|
"time"
|
2014-06-23 11:49:04 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type TestLogSystem struct {
|
2014-06-26 17:45:57 +00:00
|
|
|
Output string
|
|
|
|
level LogLevel
|
2014-06-23 11:49:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (t *TestLogSystem) Println(v ...interface{}) {
|
2014-06-26 17:45:57 +00:00
|
|
|
t.Output += fmt.Sprintln(v...)
|
2014-06-23 11:49:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (t *TestLogSystem) Printf(format string, v ...interface{}) {
|
2014-06-26 17:45:57 +00:00
|
|
|
t.Output += fmt.Sprintf(format, v...)
|
2014-06-23 11:49:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (t *TestLogSystem) SetLogLevel(i LogLevel) {
|
2014-06-26 17:45:57 +00:00
|
|
|
t.level = i
|
2014-06-23 11:49:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (t *TestLogSystem) GetLogLevel() LogLevel {
|
2014-06-26 17:45:57 +00:00
|
|
|
return t.level
|
2014-06-23 11:49:04 +00:00
|
|
|
}
|
|
|
|
|
2014-07-14 17:37:01 +00:00
|
|
|
func TestLoggerFlush(t *testing.T) {
|
2014-10-14 12:33:58 +00:00
|
|
|
Reset()
|
|
|
|
|
2014-07-14 17:37:01 +00:00
|
|
|
logger := NewLogger("TEST")
|
|
|
|
testLogSystem := &TestLogSystem{level: WarnLevel}
|
|
|
|
AddLogSystem(testLogSystem)
|
|
|
|
for i := 0; i < 5; i++ {
|
|
|
|
logger.Errorf(".")
|
|
|
|
}
|
|
|
|
Flush()
|
|
|
|
output := testLogSystem.Output
|
|
|
|
if output != "[TEST] .[TEST] .[TEST] .[TEST] .[TEST] ." {
|
|
|
|
t.Error("Expected complete logger output '[TEST] .[TEST] .[TEST] .[TEST] .[TEST] .', got ", output)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-06-23 11:49:04 +00:00
|
|
|
func TestLoggerPrintln(t *testing.T) {
|
2014-10-14 12:33:58 +00:00
|
|
|
Reset()
|
|
|
|
|
2014-06-26 17:45:57 +00:00
|
|
|
logger := NewLogger("TEST")
|
|
|
|
testLogSystem := &TestLogSystem{level: WarnLevel}
|
|
|
|
AddLogSystem(testLogSystem)
|
|
|
|
logger.Errorln("error")
|
|
|
|
logger.Warnln("warn")
|
|
|
|
logger.Infoln("info")
|
|
|
|
logger.Debugln("debug")
|
|
|
|
Flush()
|
|
|
|
output := testLogSystem.Output
|
|
|
|
if output != "[TEST] error\n[TEST] warn\n" {
|
2014-07-14 17:50:06 +00:00
|
|
|
t.Error("Expected logger output '[TEST] error\\n[TEST] warn\\n', got ", output)
|
2014-06-26 17:45:57 +00:00
|
|
|
}
|
2014-06-23 11:49:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestLoggerPrintf(t *testing.T) {
|
2014-10-14 12:33:58 +00:00
|
|
|
Reset()
|
|
|
|
|
2014-06-26 17:45:57 +00:00
|
|
|
logger := NewLogger("TEST")
|
|
|
|
testLogSystem := &TestLogSystem{level: WarnLevel}
|
|
|
|
AddLogSystem(testLogSystem)
|
|
|
|
logger.Errorf("error to %v\n", *testLogSystem)
|
|
|
|
logger.Warnf("warn")
|
|
|
|
logger.Infof("info")
|
|
|
|
logger.Debugf("debug")
|
|
|
|
Flush()
|
|
|
|
output := testLogSystem.Output
|
|
|
|
if output != "[TEST] error to { 2}\n[TEST] warn" {
|
2014-07-14 17:50:06 +00:00
|
|
|
t.Error("Expected logger output '[TEST] error to { 2}\\n[TEST] warn', got ", output)
|
2014-06-26 17:45:57 +00:00
|
|
|
}
|
2014-06-23 11:49:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestMultipleLogSystems(t *testing.T) {
|
2014-10-14 12:33:58 +00:00
|
|
|
Reset()
|
|
|
|
|
2014-06-26 17:45:57 +00:00
|
|
|
logger := NewLogger("TEST")
|
|
|
|
testLogSystem0 := &TestLogSystem{level: ErrorLevel}
|
|
|
|
testLogSystem1 := &TestLogSystem{level: WarnLevel}
|
|
|
|
AddLogSystem(testLogSystem0)
|
|
|
|
AddLogSystem(testLogSystem1)
|
|
|
|
logger.Errorln("error")
|
|
|
|
logger.Warnln("warn")
|
|
|
|
Flush()
|
|
|
|
output0 := testLogSystem0.Output
|
|
|
|
output1 := testLogSystem1.Output
|
|
|
|
if output0 != "[TEST] error\n" {
|
2014-07-14 17:50:06 +00:00
|
|
|
t.Error("Expected logger 0 output '[TEST] error\\n', got ", output0)
|
2014-06-26 17:45:57 +00:00
|
|
|
}
|
|
|
|
if output1 != "[TEST] error\n[TEST] warn\n" {
|
2014-07-14 17:50:06 +00:00
|
|
|
t.Error("Expected logger 1 output '[TEST] error\\n[TEST] warn\\n', got ", output1)
|
2014-06-26 17:45:57 +00:00
|
|
|
}
|
2014-06-23 11:49:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestFileLogSystem(t *testing.T) {
|
2014-10-14 12:33:58 +00:00
|
|
|
Reset()
|
|
|
|
|
2014-06-26 17:45:57 +00:00
|
|
|
logger := NewLogger("TEST")
|
|
|
|
filename := "test.log"
|
|
|
|
file, _ := os.OpenFile(filename, os.O_RDWR|os.O_CREATE, os.ModePerm)
|
|
|
|
testLogSystem := NewStdLogSystem(file, 0, WarnLevel)
|
|
|
|
AddLogSystem(testLogSystem)
|
|
|
|
logger.Errorf("error to %s\n", filename)
|
|
|
|
logger.Warnln("warn")
|
|
|
|
Flush()
|
|
|
|
contents, _ := ioutil.ReadFile(filename)
|
|
|
|
output := string(contents)
|
|
|
|
if output != "[TEST] error to test.log\n[TEST] warn\n" {
|
2014-07-05 17:36:22 +00:00
|
|
|
t.Error("Expected contents of file 'test.log': '[TEST] error to test.log\\n[TEST] warn\\n', got ", output)
|
2014-06-26 17:45:57 +00:00
|
|
|
} else {
|
|
|
|
os.Remove(filename)
|
|
|
|
}
|
2014-06-23 11:49:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestNoLogSystem(t *testing.T) {
|
2014-10-14 12:33:58 +00:00
|
|
|
Reset()
|
|
|
|
|
2014-06-26 17:45:57 +00:00
|
|
|
logger := NewLogger("TEST")
|
|
|
|
logger.Warnln("warn")
|
|
|
|
Flush()
|
2014-06-23 11:49:04 +00:00
|
|
|
}
|
2014-10-14 12:35:16 +00:00
|
|
|
|
|
|
|
func TestConcurrentAddSystem(t *testing.T) {
|
|
|
|
rand.Seed(time.Now().Unix())
|
|
|
|
Reset()
|
|
|
|
|
|
|
|
logger := NewLogger("TEST")
|
|
|
|
stop := make(chan struct{})
|
|
|
|
writer := func() {
|
|
|
|
select {
|
|
|
|
case <-stop:
|
|
|
|
return
|
|
|
|
default:
|
|
|
|
logger.Infof("foo")
|
|
|
|
Flush()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
go writer()
|
|
|
|
go writer()
|
|
|
|
|
|
|
|
stopTime := time.Now().Add(100 * time.Millisecond)
|
|
|
|
for time.Now().Before(stopTime) {
|
|
|
|
time.Sleep(time.Duration(rand.Intn(20)) * time.Millisecond)
|
|
|
|
AddLogSystem(&TestLogSystem{level: InfoLevel})
|
|
|
|
}
|
|
|
|
close(stop)
|
|
|
|
}
|