File: handler_test.go

package info (click to toggle)
golang-github-olekukonko-ll 0.1.2-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 592 kB
  • sloc: makefile: 2
file content (104 lines) | stat: -rw-r--r-- 3,606 bytes parent folder | download | duplicates (2)
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
package tests

import (
	"bytes"
	"encoding/json"
	"github.com/olekukonko/ll"
	"github.com/olekukonko/ll/lh"
	"github.com/olekukonko/ll/lx"
	"log/slog"
	"strings"
	"testing"
)

// TestHandlers verifies the behavior of all log handlers (Text, Colorized, JSON, Slog, Multi).
func TestHandlers(t *testing.T) {
	// Test TextHandler for plain text output
	t.Run("TextHandler", func(t *testing.T) {
		buf := &bytes.Buffer{}
		logger := ll.New("test").Enable().Handler(lh.NewTextHandler(buf))
		logger.Fields("key", "value").Infof("Test text")
		if !strings.Contains(buf.String(), "[test] INFO: Test text [key=value]") {
			t.Errorf("Expected %q to contain %q", buf.String(), "[test] INFO: Test text [key=value]")
		}
	})

	// Test ColorizedHandler for ANSI-colored output
	t.Run("ColorizedHandler", func(t *testing.T) {
		buf := &bytes.Buffer{}
		logger := ll.New("test").Enable().Handler(lh.NewColorizedHandler(buf))
		logger.Fields("key", "value").Infof("Test color")
		// Check for namespace presence, ignoring ANSI codes
		if !strings.Contains(buf.String(), "[test]") {
			t.Errorf("Expected %q to contain %q", buf.String(), "[test] INFO: Test color [key=value]")
		}
	})

	// Test JSONHandler for structured JSON output
	t.Run("JSONHandler", func(t *testing.T) {
		buf := &bytes.Buffer{}
		logger := ll.New("test").Enable().Handler(lh.NewJSONHandler(buf))
		logger.Fields("key", "value").Infof("Test JSON")
		// Parse JSON output and verify fields
		var data lh.JsonOutput
		if err := json.Unmarshal(buf.Bytes(), &data); err != nil {
			t.Errorf("Expected no error, got %v", err)
		}
		if data.Level != lx.LevelInfo.String() {
			t.Errorf("Expected level=%q, got %q", "INFO", data.Level)
		}
		if data.Msg != "Test JSON" {
			t.Errorf("Expected message=%q, got %q", "Test JSON", data.Msg)
		}
		if data.Namespace != "test" {
			t.Errorf("Expected namespace=%q, got %q", "test", data.Namespace)
		}
		f := data.Fields
		if f["key"] != "value" {
			t.Errorf("Expected key=%q, got %q", "value", f["key"])
		}
	})

	// Test SlogHandler for compatibility with slog
	t.Run("SlogHandler", func(t *testing.T) {
		buf := &bytes.Buffer{}
		logger := ll.New("test").Enable().Handler(lh.NewSlogHandler(slog.NewTextHandler(buf, nil)))
		logger.Fields("key", "value").Infof("Test slog")
		output := buf.String()
		if !strings.Contains(output, "level=INFO") {
			t.Errorf("Expected %q to contain %q", output, "level=INFO")
		}
		if !strings.Contains(output, "msg=\"Test slog\"") {
			t.Errorf("Expected %q to contain %q", output, "msg=\"Test slog\"")
		}
		if !strings.Contains(output, "namespace=test") {
			t.Errorf("Expected %q to contain %q", output, "namespace=test")
		}
		if !strings.Contains(output, "key=value") {
			t.Errorf("Expected %q to contain %q", output, "key=value")
		}
	})

	// Test MultiHandler for combining multiple handlers
	t.Run("MultiHandler", func(t *testing.T) {
		buf1 := &bytes.Buffer{}
		buf2 := &bytes.Buffer{}
		logger := ll.New("test").Enable().Handler(lh.NewMultiHandler(
			lh.NewTextHandler(buf1),
			lh.NewJSONHandler(buf2),
		))
		logger.Fields("key", "value").Infof("Test multi")
		// Verify TextHandler output
		if !strings.Contains(buf1.String(), "[test] INFO: Test multi [key=value]") {
			t.Errorf("Expected %q to contain %q", buf1.String(), "[test] INFO: Test multi [key=value]")
		}
		// Verify JSONHandler output
		var data map[string]interface{}
		if err := json.Unmarshal(buf2.Bytes(), &data); err != nil {
			t.Errorf("Expected no error, got %v", err)
		}
		if data["msg"] != "Test multi" {
			t.Errorf("Expected message=%q, got %q", "Test multi", data["msg"])
		}
	})
}