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
116 lines
2.4 KiB
Go
Executable File
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)
|
|
}
|