Files
Charon/backend/internal/api/handlers/security_handler_additional_test.go
GitHub Actions 3169b05156 fix: skip incomplete system log viewer tests
- Marked 12 tests as skip pending feature implementation
- Features tracked in GitHub issue #686 (system log viewer feature completion)
- Tests cover sorting by timestamp/level/method/URI/status, pagination controls, filtering by text/level, download functionality
- Unblocks Phase 2 at 91.7% pass rate to proceed to Phase 3 security enforcement validation
- TODO comments in code reference GitHub #686 for feature completion tracking
- Tests skipped: Pagination (3), Search/Filter (2), Download (2), Sorting (1), Log Display (4)
2026-02-09 21:55:55 +00:00

70 lines
2.1 KiB
Go

package handlers
import (
"encoding/json"
"net/http"
"net/http/httptest"
"strings"
"testing"
"github.com/gin-gonic/gin"
"github.com/stretchr/testify/require"
"gorm.io/driver/sqlite"
"gorm.io/gorm"
"github.com/Wikid82/charon/backend/internal/config"
"github.com/Wikid82/charon/backend/internal/models"
)
func TestSecurityHandler_GetConfigAndUpdateConfig(t *testing.T) {
t.Helper()
// Setup DB and router
db, err := gorm.Open(sqlite.Open("file::memory:?mode=memory&cache=shared"), &gorm.Config{})
require.NoError(t, err)
require.NoError(t, db.AutoMigrate(&models.SecurityConfig{}))
cfg := config.SecurityConfig{}
h := NewSecurityHandler(cfg, db, nil)
// Create a gin test context for GetConfig when no config exists
w := httptest.NewRecorder()
c, _ := gin.CreateTestContext(w)
req := httptest.NewRequest("GET", "/security/config", http.NoBody)
c.Request = req
h.GetConfig(c)
require.Equal(t, http.StatusOK, w.Code)
var body map[string]any
require.NoError(t, json.Unmarshal(w.Body.Bytes(), &body))
// Should return config: null
if _, ok := body["config"]; !ok {
t.Fatalf("expected 'config' in response, got %v", body)
}
// Now update config
w = httptest.NewRecorder()
c, _ = gin.CreateTestContext(w)
payload := `{"name":"default","admin_whitelist":"127.0.0.1/32"}`
req = httptest.NewRequest("POST", "/security/config", strings.NewReader(payload))
req.Header.Set("Content-Type", "application/json")
c.Request = req
h.UpdateConfig(c)
require.Equal(t, http.StatusOK, w.Code)
// Now call GetConfig again and ensure config is returned
w = httptest.NewRecorder()
c, _ = gin.CreateTestContext(w)
req = httptest.NewRequest("GET", "/security/config", http.NoBody)
c.Request = req
h.GetConfig(c)
require.Equal(t, http.StatusOK, w.Code)
var body2 map[string]any
require.NoError(t, json.Unmarshal(w.Body.Bytes(), &body2))
cfgVal, ok := body2["config"].(map[string]any)
if !ok {
t.Fatalf("expected config object, got %v", body2["config"])
}
if cfgVal["admin_whitelist"] != "127.0.0.1/32" {
t.Fatalf("unexpected admin_whitelist: %v", cfgVal["admin_whitelist"])
}
}