File: handler_test.go

package info (click to toggle)
golang-go.cypherpunks-recfile 2.0.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 120 kB
  • sloc: makefile: 5
file content (108 lines) | stat: -rw-r--r-- 2,466 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
105
106
107
108
// recfile -- GNU recutils'es recfiles parser on pure Go
// Copyright (C) 2020-2024 Sergey Matveev <stargrave@stargrave.org>
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, version 3 of the License.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program.  If not, see <http://www.gnu.org/licenses/>.

package slog

import (
	"bytes"
	"context"
	"log/slog"
	"testing"
	"time"

	"go.cypherpunks.su/recfile/v2"
)

func TestBasic(t *testing.T) {
	var buf bytes.Buffer
	logger := slog.New(NewRecfileHandler(
		&buf,
		slog.LevelWarn,
		"Urgency",
		"Message",
		"Time",
	))
	if !logger.Enabled(context.TODO(), slog.LevelWarn) {
		t.FailNow()
	}
	logger.Info("won't catch me")
	logger.Warn("catch me")

	r := recfile.NewReader(&buf)
	m, err := r.NextMap()
	if err != nil {
		t.Fatal(err)
	}
	if m["Message"] != "catch me" {
		t.FailNow()
	}
	if m["Urgency"] != "WARN" {
		t.FailNow()
	}
	if _, err = time.Parse(time.RFC3339Nano, m["Time"]); err != nil {
		t.FailNow()
	}
}

func TestTrimmed(t *testing.T) {
	var buf bytes.Buffer
	logger := slog.New(NewRecfileHandler(&buf, slog.LevelWarn, "", "Message", ""))
	logger.Warn("catch me")
	r := recfile.NewReader(&buf)
	m, err := r.NextMap()
	if err != nil {
		t.Fatal(err)
	}
	if m["Message"] != "catch me" {
		t.FailNow()
	}
	if m["Urgency"] != "" {
		t.FailNow()
	}
	if m["Time"] != "" {
		t.FailNow()
	}
}

func TestFeatured(t *testing.T) {
	var buf bytes.Buffer
	logger := slog.New(NewRecfileHandler(&buf, slog.LevelInfo, "L", "M", "T"))
	logger.WithGroup("grou").WithGroup("py").With("foo", "bar").With("bar", "baz").Info(
		"catch me", "baz", []string{"multi", "line"},
	)
	r := recfile.NewReader(&buf)
	m, err := r.NextMap()
	if err != nil {
		t.Fatal(err)
	}
	if m["M"] != "catch me" {
		t.Fatal("M")
	}
	if m["L"] != "INFO" {
		t.Fatal("L")
	}
	if _, err = time.Parse(time.RFC3339Nano, m["T"]); err != nil {
		t.Fatal("T")
	}
	if m["grou_py_foo"] != "bar" {
		t.Fatal("foo")
	}
	if m["grou_py_bar"] != "baz" {
		t.Fatal("bar")
	}
	if m["grou_py_baz"] != "multi\nline" {
		t.Fatal("baz")
	}
}