Home / File/ helmet_test.go — fiber Source File

helmet_test.go — fiber Source File

Architecture documentation for helmet_test.go, a go file in the fiber codebase. 1 imports, 0 dependents.

File go FiberCore Adapters 1 imports 9 functions

Entity Profile

Dependency Diagram

graph LR
  dc893b58_cc7a_94e6_441a_587c6543a0cd["helmet_test.go"]
  dbea2ac8_9b7c_9118_714a_b9e222cbb2e2["http"]
  dc893b58_cc7a_94e6_441a_587c6543a0cd --> dbea2ac8_9b7c_9118_714a_b9e222cbb2e2
  style dc893b58_cc7a_94e6_441a_587c6543a0cd fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

package helmet

import (
	"net/http"
	"net/http/httptest"
	"testing"

	"github.com/gofiber/fiber/v3"
	"github.com/stretchr/testify/require"
	"github.com/valyala/fasthttp"
)

func Test_Default(t *testing.T) {
	app := fiber.New()

	app.Use(New())

	app.Get("/", func(c fiber.Ctx) error {
		return c.SendString("Hello, World!")
	})

	resp, err := app.Test(httptest.NewRequest(fiber.MethodGet, "/", http.NoBody))
	require.NoError(t, err)
	require.Equal(t, "0", resp.Header.Get(fiber.HeaderXXSSProtection))
	require.Equal(t, "nosniff", resp.Header.Get(fiber.HeaderXContentTypeOptions))
	require.Equal(t, "SAMEORIGIN", resp.Header.Get(fiber.HeaderXFrameOptions))
	require.Empty(t, resp.Header.Get(fiber.HeaderContentSecurityPolicy))
	require.Equal(t, "no-referrer", resp.Header.Get(fiber.HeaderReferrerPolicy))
	require.Empty(t, resp.Header.Get(fiber.HeaderPermissionsPolicy))
	require.Equal(t, "require-corp", resp.Header.Get("Cross-Origin-Embedder-Policy"))
	require.Equal(t, "same-origin", resp.Header.Get("Cross-Origin-Opener-Policy"))
	require.Equal(t, "same-origin", resp.Header.Get("Cross-Origin-Resource-Policy"))
	require.Equal(t, "?1", resp.Header.Get("Origin-Agent-Cluster"))
	require.Equal(t, "off", resp.Header.Get("X-DNS-Prefetch-Control"))
	require.Equal(t, "noopen", resp.Header.Get("X-Download-Options"))
	require.Equal(t, "none", resp.Header.Get("X-Permitted-Cross-Domain-Policies"))
}

func Test_CustomValues_AllHeaders(t *testing.T) {
	app := fiber.New()

	app.Use(New(Config{
		// Custom values for all headers
		XSSProtection:             "0",
		ContentTypeNosniff:        "custom-nosniff",
		XFrameOptions:             "DENY",
		HSTSExcludeSubdomains:     true,
		ContentSecurityPolicy:     "default-src 'none'",
		CSPReportOnly:             true,
		HSTSPreloadEnabled:        true,
		ReferrerPolicy:            "origin",
		PermissionPolicy:          "geolocation=(self)",
		CrossOriginEmbedderPolicy: "custom-value",
		CrossOriginOpenerPolicy:   "custom-value",
		CrossOriginResourcePolicy: "custom-value",
		OriginAgentCluster:        "custom-value",
		XDNSPrefetchControl:       "custom-control",
		XDownloadOptions:          "custom-options",
		XPermittedCrossDomain:     "custom-policies",
	}))
// ... (202 more lines)

Domain

Subdomains

Dependencies

  • http

Frequently Asked Questions

What does helmet_test.go do?
helmet_test.go is a source file in the fiber codebase, written in go. It belongs to the FiberCore domain, Adapters subdomain.
What functions are defined in helmet_test.go?
helmet_test.go defines 9 function(s): Test_ContentSecurityPolicy, Test_ContentSecurityPolicyReportOnly, Test_CustomValues_AllHeaders, Test_Default, Test_HSTSExcludeSubdomainsAndPreload, Test_HSTSHeaders, Test_Next, Test_PermissionsPolicy, Test_RealWorldValues_AllHeaders.
What does helmet_test.go depend on?
helmet_test.go imports 1 module(s): http.
Where is helmet_test.go in the architecture?
helmet_test.go is located at middleware/helmet/helmet_test.go (domain: FiberCore, subdomain: Adapters, directory: middleware/helmet).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free