aboutsummaryrefslogblamecommitdiffstats
path: root/ethlog/loggers_test.go
blob: fbfb2c99b3ace4a2f88201e1849413c922610e42 (plain) (tree)
1
2
3
4
5
6
7
8
9
10


              



                   


                           

                       


                                                   
                                      


                                                                 
                                             


                                                 
                   


                                                
                      

 
                                    

               






                                                         





                                                                                                                   
                                      

               








                                                         
                                                    
                                                                                               
         


                                     

               








                                                         
                                                          
                                                                                                    
         


                                           

               










                                                           
                                                                                    

                                                     
                                                                                                  
         


                                      

               









                                                                            
                                                                
                                                                                                                          


                                   


                                    

               


                                   
 
package ethlog

import (
    "fmt"
    "io/ioutil"
    "os"
    "testing"
)

type TestLogSystem struct {
    Output string
    level  LogLevel
}

func (t *TestLogSystem) Println(v ...interface{}) {
    t.Output += fmt.Sprintln(v...)
}

func (t *TestLogSystem) Printf(format string, v ...interface{}) {
    t.Output += fmt.Sprintf(format, v...)
}

func (t *TestLogSystem) SetLogLevel(i LogLevel) {
    t.level = i
}

func (t *TestLogSystem) GetLogLevel() LogLevel {
    return t.level
}

func TestLoggerFlush(t *testing.T) {
    Reset()

    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)
    }
}

func TestLoggerPrintln(t *testing.T) {
    Reset()

    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" {
        t.Error("Expected logger output '[TEST] error\\n[TEST] warn\\n', got ", output)
    }
}

func TestLoggerPrintf(t *testing.T) {
    Reset()

    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" {
        t.Error("Expected logger output '[TEST] error to { 2}\\n[TEST] warn', got ", output)
    }
}

func TestMultipleLogSystems(t *testing.T) {
    Reset()

    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" {
        t.Error("Expected logger 0 output '[TEST] error\\n', got ", output0)
    }
    if output1 != "[TEST] error\n[TEST] warn\n" {
        t.Error("Expected logger 1 output '[TEST] error\\n[TEST] warn\\n', got ", output1)
    }
}

func TestFileLogSystem(t *testing.T) {
    Reset()

    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" {
        t.Error("Expected contents of file 'test.log': '[TEST] error to test.log\\n[TEST] warn\\n', got ", output)
    } else {
        os.Remove(filename)
    }
}

func TestNoLogSystem(t *testing.T) {
    Reset()

    logger := NewLogger("TEST")
    logger.Warnln("warn")
    Flush()
}