70 lines
1.2 KiB
Go
70 lines
1.2 KiB
Go
package flog
|
|
|
|
import (
|
|
"bytes"
|
|
|
|
"testing"
|
|
)
|
|
|
|
func TestInternalLogger_Highlightf(t *testing.T) {
|
|
|
|
tests := []struct{
|
|
Format string
|
|
Array []interface{}
|
|
Expected string
|
|
}{
|
|
{
|
|
Format: "",
|
|
Array: []interface{}(nil),
|
|
Expected: "[HIGHLIGHT] \n",
|
|
},
|
|
{
|
|
Format: "",
|
|
Array: []interface{}{},
|
|
Expected: "[HIGHLIGHT] \n",
|
|
},
|
|
|
|
|
|
|
|
{
|
|
Format: "hello world",
|
|
Array: []interface{}(nil),
|
|
Expected: "[HIGHLIGHT] hello world\n",
|
|
},
|
|
{
|
|
Format: "hello world",
|
|
Array: []interface{}{},
|
|
Expected: "[HIGHLIGHT] hello world\n",
|
|
},
|
|
|
|
|
|
|
|
{
|
|
Format: "hello %s",
|
|
Array: []interface{}{"Joe"},
|
|
Expected: "[HIGHLIGHT] hello Joe\n",
|
|
},
|
|
{
|
|
Format: "hello %s %s",
|
|
Array: []interface{}{"Joe", "Blow"},
|
|
Expected: "[HIGHLIGHT] hello Joe Blow\n",
|
|
},
|
|
}
|
|
|
|
for testNumber, test := range tests {
|
|
|
|
var buffer bytes.Buffer
|
|
|
|
logger := NewLogger(&buffer)
|
|
|
|
logger.Highlightf(test.Format, test.Array...)
|
|
|
|
if expected, actual := test.Expected, buffer.String(); expected != actual {
|
|
t.Errorf("For tst #%d, the actual result is not what was expected.", testNumber)
|
|
t.Logf("EXPECTED: %q", expected)
|
|
t.Logf("ACTUAL: %q", actual)
|
|
continue
|
|
}
|
|
}
|
|
}
|