fleet/server/platform/logging/kitlog_adapter_test.go
Victor Lyuboslavsky aaac4b1dfe
Changes needed before gokit/log to slog transition. (#39527)
<!-- Add the related story/sub-task/bug number, like Resolves #123, or
remove if NA -->
**Related issue:** Resolves #38889

PLEASE READ BELOW before looking at file changes

Before converting individual files/packages to slog, we generally need
to make these 2 changes to make the conversion easier:
- Replace uses of `kitlog.With` since they are not fully compatible with
our kitlog adapter
- Directly use the kitlog adapter logger type instead of the kitlog
interface, which will let us have direct access to the underlying slog
logger: `*logging.Logger`

Note: that I did not replace absolutely all uses of `kitlog.Logger`, but
I did remove all uses of `kitlog.With` except for these due to
complexity:
- server/logging/filesystem.go and the other log writers (webhook,
firehose, kinesis, lambda, pubsub, nats)
- server/datastore/mysql/nanomdm_storage.go (adapter pattern)
- server/vulnerabilities/nvd/* (cascades to CLI tools)
- server/service/osquery_utils/queries.go (callback type signatures
cascade broadly)
- cmd/maintained-apps/ (standalone, so can be transitioned later all at
once)

Most of the changes in this PR follow these patterns:
- `kitlog.Logger` type → `*logging.Logger`
- `kitlog.With(logger, ...)` → `logger.With(...)`
- `kitlog.NewNopLogger() → logging.NewNopLogger()`, including similar
variations such as `logging.NewLogfmtLogger(w)` and
`logging.NewJSONLogger(w)`
- removed many now-unused kitlog imports

Unique changes that the PR review should focus on:
- server/platform/logging/kitlog_adapter.go: Core adapter changes
- server/platform/logging/logging.go: New convenience functions
- server/service/integration_logger_test.go: Test changes for slog

# Checklist for submitter

If some of the following don't apply, delete the relevant line.

- [x] Changes file added for user-visible changes in `changes/`,
`orbit/changes/` or `ee/fleetd-chrome/changes`.
  - Was added in previous PR

## Testing

- [x] Added/updated automated tests
- [x] QA'd all new/changed functionality manually


<!-- This is an auto-generated comment: release notes by coderabbit.ai
-->
## Summary by CodeRabbit

* **Refactor**
* Migrated the codebase to a unified internal structured logging system
for more consistent, reliable logs and observability.
* No user-facing functionality changed; runtime behavior and APIs remain
compatible.
* **Tests**
* Updated tests to use the new logging helpers to ensure consistent test
logging and validation.
<!-- end of auto-generated comment: release notes by coderabbit.ai -->
2026-02-11 10:08:33 -06:00

107 lines
2.5 KiB
Go

package logging
import (
"log/slog"
"testing"
kitlog "github.com/go-kit/log"
"github.com/go-kit/log/level"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
"github.com/fleetdm/fleet/v4/server/platform/logging/testutils"
)
// newTestAdapter creates a kitlog adapter with a TestHandler for capturing records.
func newTestAdapter(t *testing.T) (*testutils.TestHandler, kitlog.Logger) {
t.Helper()
handler := testutils.NewTestHandler()
slogLogger := slog.New(handler)
return handler, NewLogger(slogLogger)
}
func TestKitlogAdapter(t *testing.T) {
t.Parallel()
t.Run("basic logging", func(t *testing.T) {
t.Parallel()
handler, adapter := newTestAdapter(t)
err := adapter.Log("msg", "hello world", "key", "value")
require.NoError(t, err)
record := handler.LastRecord()
require.NotNil(t, record)
assert.Equal(t, "hello world", record.Message)
attrs := testutils.RecordAttrs(record)
assert.Equal(t, "value", attrs["key"])
})
t.Run("with context via With", func(t *testing.T) {
t.Parallel()
handler, adapter := newTestAdapter(t)
kitlogAdapter, ok := adapter.(*Logger)
require.True(t, ok, "adapter should be *Logger")
contextLogger := kitlogAdapter.With("component", "test-component")
err := contextLogger.Log("msg", "message with context")
require.NoError(t, err)
record := handler.LastRecord()
require.NotNil(t, record)
assert.Equal(t, "message with context", record.Message)
attrs := testutils.RecordAttrs(record)
assert.Equal(t, "test-component", attrs["component"])
})
}
func TestKitlogAdapterLevels(t *testing.T) {
t.Parallel()
tests := []struct {
name string
levelFunc func(kitlog.Logger) kitlog.Logger
expectedLevel slog.Level
}{
{
name: "info",
levelFunc: level.Info,
expectedLevel: slog.LevelInfo,
},
{
name: "debug",
levelFunc: level.Debug,
expectedLevel: slog.LevelDebug,
},
{
name: "warn",
levelFunc: level.Warn,
expectedLevel: slog.LevelWarn,
},
{
name: "error",
levelFunc: level.Error,
expectedLevel: slog.LevelError,
},
}
for _, tc := range tests {
t.Run(tc.name, func(t *testing.T) {
t.Parallel()
handler, adapter := newTestAdapter(t)
leveledLogger := tc.levelFunc(adapter)
err := leveledLogger.Log("msg", tc.name+" message")
require.NoError(t, err)
record := handler.LastRecord()
require.NotNil(t, record)
assert.Equal(t, tc.name+" message", record.Message)
assert.Equal(t, tc.expectedLevel, record.Level)
})
}
}