1
0
mirror of https://github.com/regclient/regclient.git synced 2025-04-18 22:44:00 +03:00
regclient/regclient_test.go
Brandon Mitchell 1eb1ea4b34
Feat: Refactor logging to use log/slog
This updates the regclient Go library.
Existing users of logrus will continue to work using a logrus handler to slog.
Updates to the various commands will be made in a future commit.

Signed-off-by: Brandon Mitchell <git@bmitch.net>
2024-11-10 17:14:57 -05:00

105 lines
2.2 KiB
Go

package regclient
import (
"log/slog"
"os"
"testing"
"github.com/regclient/regclient/scheme/reg"
)
func TestNew(t *testing.T) {
t.Parallel()
logPtr := slog.New(slog.NewTextHandler(os.Stderr, &slog.HandlerOptions{Level: slog.LevelWarn}))
tt := []struct {
name string
opts []Opt
expect RegClient
}{
{
name: "default",
opts: []Opt{},
expect: RegClient{},
},
{
name: "regOpt",
opts: []Opt{
WithRegOpts(
reg.WithBlobLimit(1234),
reg.WithBlobSize(64, 128),
),
},
expect: RegClient{
regOpts: []reg.Opts{
reg.WithBlobLimit(1234),
reg.WithBlobSize(64, 128),
},
},
},
{
name: "regOpt separate",
opts: []Opt{
WithRegOpts(reg.WithBlobLimit(1234)),
WithRegOpts(reg.WithBlobSize(64, 128)),
},
expect: RegClient{
regOpts: []reg.Opts{
reg.WithBlobLimit(1234),
reg.WithBlobSize(64, 128),
},
},
},
{
name: "log",
opts: []Opt{
WithSlog(logPtr),
},
expect: RegClient{
slog: logPtr,
},
},
{
name: "userAgent",
opts: []Opt{
WithUserAgent("unit-test"),
},
expect: RegClient{
userAgent: "unit-test",
},
},
}
defaultRegOptCount := 4
for _, tc := range tt {
t.Run(tc.name, func(t *testing.T) {
result := New(tc.opts...)
if tc.expect.hosts != nil {
if result.hosts == nil {
t.Errorf("host is nil")
} else {
for name := range tc.expect.hosts {
if _, ok := result.hosts[name]; !ok {
t.Errorf("host entry missing for %s", name)
}
}
}
}
if tc.expect.slog != nil {
if result.slog == nil {
t.Errorf("slog is nil")
} else if result.slog != tc.expect.slog {
t.Errorf("slog pointer mismatch")
}
}
if len(tc.expect.regOpts) > 0 {
if len(tc.expect.regOpts)+defaultRegOptCount != len(result.regOpts) {
t.Errorf("regOpts length mismatch, expected %d, received %d", len(tc.expect.regOpts)+defaultRegOptCount, len(result.regOpts))
}
// TODO: can content of each regOpt be compared?
}
if tc.expect.userAgent != "" && tc.expect.userAgent != result.userAgent {
t.Errorf("userAgent, expected %s, received %s", tc.expect.userAgent, result.userAgent)
}
})
}
}