package middleware import ( "net/http" "net/http/httptest" "testing" "github.com/gin-gonic/gin" "github.com/stretchr/testify/assert" ) // TestSecurityHeaders vérifie que les headers de sécurité sont ajoutés // MOD-P2-005: Test pour valider que les headers sécurité sont présents func TestSecurityHeaders(t *testing.T) { gin.SetMode(gin.TestMode) router := gin.New() router.Use(SecurityHeaders()) router.GET("/test", func(c *gin.Context) { c.JSON(http.StatusOK, gin.H{"message": "test"}) }) req, _ := http.NewRequest("GET", "/test", nil) w := httptest.NewRecorder() router.ServeHTTP(w, req) // MOD-P2-005: Vérifier que tous les headers de sécurité sont présents assert.Equal(t, "max-age=31536000; includeSubDomains; preload", w.Header().Get("Strict-Transport-Security")) assert.Equal(t, "nosniff", w.Header().Get("X-Content-Type-Options")) assert.Equal(t, "DENY", w.Header().Get("X-Frame-Options")) assert.Equal(t, "1; mode=block", w.Header().Get("X-XSS-Protection")) assert.Equal(t, "strict-origin-when-cross-origin", w.Header().Get("Referrer-Policy")) assert.Equal(t, "geolocation=(), microphone=(), camera=()", w.Header().Get("Permissions-Policy")) assert.Contains(t, w.Header().Get("Content-Security-Policy"), "default-src 'none'") }