Files
Charon/backend/internal/logger/logger_test.go
T
akanealw eec8c28fb3
Go Benchmark / Performance Regression Check (push) Has been cancelled
Cerberus Integration / Cerberus Security Stack Integration (push) Has been cancelled
Upload Coverage to Codecov / Backend Codecov Upload (push) Has been cancelled
Upload Coverage to Codecov / Frontend Codecov Upload (push) Has been cancelled
CodeQL - Analyze / CodeQL analysis (go) (push) Has been cancelled
CodeQL - Analyze / CodeQL analysis (javascript-typescript) (push) Has been cancelled
CrowdSec Integration / CrowdSec Bouncer Integration (push) Has been cancelled
Docker Build, Publish & Test / build-and-push (push) Has been cancelled
Quality Checks / Auth Route Protection Contract (push) Has been cancelled
Quality Checks / Codecov Trigger/Comment Parity Guard (push) Has been cancelled
Quality Checks / Backend (Go) (push) Has been cancelled
Quality Checks / Frontend (React) (push) Has been cancelled
Rate Limit integration / Rate Limiting Integration (push) Has been cancelled
Security Scan (PR) / Trivy Binary Scan (push) Has been cancelled
Supply Chain Verification (PR) / Verify Supply Chain (push) Has been cancelled
WAF integration / Coraza WAF Integration (push) Has been cancelled
Docker Build, Publish & Test / Security Scan PR Image (push) Has been cancelled
Repo Health Check / Repo health (push) Has been cancelled
History Rewrite Dry-Run / Dry-run preview for history rewrite (push) Has been cancelled
Prune Renovate Branches / prune (push) Has been cancelled
Renovate / renovate (push) Has been cancelled
Nightly Build & Package / sync-development-to-nightly (push) Has been cancelled
Nightly Build & Package / Trigger Nightly Validation Workflows (push) Has been cancelled
Nightly Build & Package / build-and-push-nightly (push) Has been cancelled
Nightly Build & Package / test-nightly-image (push) Has been cancelled
Nightly Build & Package / verify-nightly-supply-chain (push) Has been cancelled
Update GeoLite2 Checksum / update-checksum (push) Has been cancelled
Container Registry Prune / prune-ghcr (push) Has been cancelled
Container Registry Prune / prune-dockerhub (push) Has been cancelled
Container Registry Prune / summarize (push) Has been cancelled
Supply Chain Verification / Verify SBOM (push) Has been cancelled
Supply Chain Verification / Verify Release Artifacts (push) Has been cancelled
Supply Chain Verification / Verify Docker Image Supply Chain (push) Has been cancelled
Monitor Caddy Major Release / check-caddy-major (push) Has been cancelled
Weekly Nightly to Main Promotion / Verify Nightly Branch Health (push) Has been cancelled
Weekly Nightly to Main Promotion / Create Promotion PR (push) Has been cancelled
Weekly Nightly to Main Promotion / Trigger Missing Required Checks (push) Has been cancelled
Weekly Nightly to Main Promotion / Notify on Failure (push) Has been cancelled
Weekly Nightly to Main Promotion / Workflow Summary (push) Has been cancelled
Weekly Security Rebuild / Security Rebuild & Scan (push) Has been cancelled
changed perms
2026-04-22 18:19:14 +00:00

116 lines
2.4 KiB
Go
Executable File

package logger
import (
"bytes"
"testing"
"github.com/sirupsen/logrus"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
func TestNewBroadcastHook(t *testing.T) {
hook := NewBroadcastHook()
assert.NotNil(t, hook)
assert.NotNil(t, hook.listeners)
assert.Equal(t, 0, len(hook.listeners))
}
func TestBroadcastHook_Levels(t *testing.T) {
hook := NewBroadcastHook()
levels := hook.Levels()
assert.Equal(t, logrus.AllLevels, levels)
}
func TestBroadcastHook_Subscribe(t *testing.T) {
hook := NewBroadcastHook()
ch := hook.Subscribe("test-id")
assert.NotNil(t, ch)
assert.Equal(t, 1, hook.ActiveListeners())
}
func TestBroadcastHook_Unsubscribe(t *testing.T) {
hook := NewBroadcastHook()
ch := hook.Subscribe("test-id")
assert.NotNil(t, ch)
assert.Equal(t, 1, hook.ActiveListeners())
hook.Unsubscribe("test-id")
assert.Equal(t, 0, hook.ActiveListeners())
// Test unsubscribe non-existent ID (should not panic)
hook.Unsubscribe("non-existent")
}
func TestInit(t *testing.T) {
var buf bytes.Buffer
// Test with debug mode
Init(true, &buf)
assert.NotNil(t, _log)
assert.Equal(t, logrus.DebugLevel, _log.Level)
// Test without debug mode
buf.Reset()
Init(false, &buf)
assert.Equal(t, logrus.InfoLevel, _log.Level)
// Test with nil output (should use stdout)
Init(false, nil)
assert.NotNil(t, _log.Out)
}
func TestLog(t *testing.T) {
Init(false, nil)
entry := Log()
assert.NotNil(t, entry)
assert.Equal(t, _log, entry.Logger)
}
func TestWithFields(t *testing.T) {
Init(false, nil)
fields := logrus.Fields{
"key1": "value1",
"key2": "value2",
}
entry := WithFields(fields)
assert.NotNil(t, entry)
assert.Equal(t, "value1", entry.Data["key1"])
assert.Equal(t, "value2", entry.Data["key2"])
}
func TestBroadcastHook_Fire(t *testing.T) {
hook := NewBroadcastHook()
ch := hook.Subscribe("test-id")
entry := &logrus.Entry{
Logger: logrus.New(),
Message: "test message",
Level: logrus.InfoLevel,
}
err := hook.Fire(entry)
require.NoError(t, err)
// Verify we can receive the entry
select {
case receivedEntry := <-ch:
assert.NotNil(t, receivedEntry)
assert.Equal(t, "test message", receivedEntry.Message)
default:
t.Fatal("Expected to receive log entry")
}
}
func TestGetBroadcastHook(t *testing.T) {
// Reset global hook
_broadcastHook = nil
hook := GetBroadcastHook()
assert.NotNil(t, hook)
// Call again to test cached hook
hook2 := GetBroadcastHook()
assert.Equal(t, hook, hook2)
}