Files
Charon/backend/internal/api/handlers/crowdsec_lapi_test.go
GitHub Actions 25082778c9 feat(cerberus): integrate Cerberus security features (WAF, ACLs, rate limiting, CrowdSec)
- Implement GeoIPService for IP-to-country lookups with comprehensive error handling.
- Add tests for GeoIPService covering various scenarios including invalid IPs and database loading.
- Extend AccessListService to handle GeoIP service integration, including graceful degradation when GeoIP service is unavailable.
- Introduce new tests for AccessListService to validate geo ACL behavior and country code parsing.
- Update SecurityService to include new fields for WAF configuration and enhance decision logging functionality.
- Add extensive tests for SecurityService covering rule set management and decision logging.
- Create a detailed Security Coverage QA Plan to ensure 100% code coverage for security-related functionality.
2025-12-12 17:56:30 +00:00

143 lines
3.5 KiB
Go

package handlers
import (
"encoding/json"
"net/http"
"net/http/httptest"
"os"
"testing"
"github.com/gin-gonic/gin"
"github.com/stretchr/testify/assert"
)
func TestGetLAPIDecisions_FallbackToCscli(t *testing.T) {
gin.SetMode(gin.TestMode)
router := gin.New()
// Create handler with mock executor
handler := &CrowdsecHandler{
CmdExec: &mockCommandExecutor{output: []byte(`[]`), err: nil},
DataDir: t.TempDir(),
}
router.GET("/admin/crowdsec/decisions/lapi", handler.GetLAPIDecisions)
// This test will fallback to cscli since localhost:8080 LAPI is not running
req := httptest.NewRequest(http.MethodGet, "/admin/crowdsec/decisions/lapi", http.NoBody)
w := httptest.NewRecorder()
router.ServeHTTP(w, req)
// Should return success (from cscli fallback)
assert.Equal(t, http.StatusOK, w.Code)
var response map[string]interface{}
err := json.Unmarshal(w.Body.Bytes(), &response)
assert.NoError(t, err)
// Should have decisions array (empty from mock)
_, hasDecisions := response["decisions"]
assert.True(t, hasDecisions)
}
func TestGetLAPIDecisions_EmptyResponse(t *testing.T) {
gin.SetMode(gin.TestMode)
router := gin.New()
// Create handler with mock executor that returns empty array
handler := &CrowdsecHandler{
CmdExec: &mockCommandExecutor{output: []byte(`[]`), err: nil},
DataDir: t.TempDir(),
}
router.GET("/admin/crowdsec/decisions/lapi", handler.GetLAPIDecisions)
req := httptest.NewRequest(http.MethodGet, "/admin/crowdsec/decisions/lapi", http.NoBody)
w := httptest.NewRecorder()
router.ServeHTTP(w, req)
// Will fallback to cscli which returns empty
assert.Equal(t, http.StatusOK, w.Code)
var response map[string]interface{}
err := json.Unmarshal(w.Body.Bytes(), &response)
assert.NoError(t, err)
// Should have decisions array (may be empty)
_, hasDecisions := response["decisions"]
assert.True(t, hasDecisions)
}
func TestCheckLAPIHealth_Handler(t *testing.T) {
gin.SetMode(gin.TestMode)
router := gin.New()
handler := &CrowdsecHandler{
CmdExec: &mockCommandExecutor{output: []byte(`[]`), err: nil},
DataDir: t.TempDir(),
}
router.GET("/admin/crowdsec/lapi/health", handler.CheckLAPIHealth)
req := httptest.NewRequest(http.MethodGet, "/admin/crowdsec/lapi/health", http.NoBody)
w := httptest.NewRecorder()
router.ServeHTTP(w, req)
assert.Equal(t, http.StatusOK, w.Code)
var response map[string]interface{}
err := json.Unmarshal(w.Body.Bytes(), &response)
assert.NoError(t, err)
// Should have healthy field
_, hasHealthy := response["healthy"]
assert.True(t, hasHealthy)
// Should have lapi_url field
_, hasURL := response["lapi_url"]
assert.True(t, hasURL)
}
func TestGetLAPIKey_FromEnv(t *testing.T) {
// Save and restore original env
original := os.Getenv("CROWDSEC_API_KEY")
defer func() {
if original != "" {
_ = os.Setenv("CROWDSEC_API_KEY", original)
} else {
_ = os.Unsetenv("CROWDSEC_API_KEY")
}
}()
// Set test value
_ = os.Setenv("CROWDSEC_API_KEY", "test-key-123")
key := getLAPIKey()
assert.Equal(t, "test-key-123", key)
}
func TestGetLAPIKey_Empty(t *testing.T) {
// Save and restore original env vars
envVars := []string{
"CROWDSEC_API_KEY",
"CROWDSEC_BOUNCER_API_KEY",
"CERBERUS_SECURITY_CROWDSEC_API_KEY",
"CHARON_SECURITY_CROWDSEC_API_KEY",
"CPM_SECURITY_CROWDSEC_API_KEY",
}
originals := make(map[string]string)
for _, key := range envVars {
originals[key] = os.Getenv(key)
_ = os.Unsetenv(key)
}
defer func() {
for key, val := range originals {
if val != "" {
_ = os.Setenv(key, val)
}
}
}()
key := getLAPIKey()
assert.Empty(t, key)
}