-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathlog_test.go
More file actions
51 lines (43 loc) · 1.25 KB
/
log_test.go
File metadata and controls
51 lines (43 loc) · 1.25 KB
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
package log
import (
"bytes"
"io"
"os"
"testing"
"github.com/arschles/assert"
)
var (
world = "world"
)
func getWriters() (io.Writer, *bytes.Buffer, io.Writer, *bytes.Buffer) {
var out, err bytes.Buffer
stdout, stderr := io.MultiWriter(os.Stdout, &out), io.MultiWriter(os.Stderr, &err)
return stdout, &out, stderr, &err
}
func TestMsg(t *testing.T) {
stdout, _, stderr, _ := getWriters()
lg := NewLogger(stdout, stderr, true)
lg.Msg("hello %s", world)
}
func TestErr(t *testing.T) {
stdout, _, stderr, _ := getWriters()
lg := NewLogger(stdout, stderr, true)
lg.Err("hello %s", world)
}
func TestInfo(t *testing.T) {
stdout, _, stderr, err := getWriters()
lg := NewLogger(stdout, stderr, true)
lg.Info("hello %s", world)
assert.Equal(t, err.Len(), 0, "stderr buffer length")
}
func TestDebug(t *testing.T) {
stdout, out, stderr, err := getWriters()
lgOn := NewLogger(stdout, stderr, true)
lgOff := NewLogger(stdout, stderr, false)
lgOff.Debug("hello %s", world)
assert.Equal(t, out.Len(), 0, "stdout buffer length")
assert.Equal(t, err.Len(), 0, "stderr buffer length")
lgOn.Debug("hello %s", world)
assert.Equal(t, err.Len(), 0, "stderr buffer length")
assert.True(t, out.Len() > 0, "stdout buffer was empty, expected it to have debug output")
}