Files
headscale/hscontrol/templates/ping_test.go
Kristoffer Dalby 010a5564c5 all: rephrase prose to fit codebase voice
Reword comments, one doc paragraph, and one test failure message
so the prose reads naturally. No behaviour change.
2026-04-29 16:22:19 +01:00

27 lines
639 B
Go

package templates
import (
"strings"
"testing"
)
// TestPingPageEscapesQuery asserts hostile query values cannot break out of
// the input's value attribute. elem-go does not escape attribute values, so
// the template must escape before rendering.
func TestPingPageEscapesQuery(t *testing.T) {
payloads := []string{
`" autofocus onfocus=alert(1) x="`,
`"><script>alert(1)</script>`,
`<img src=x onerror=alert(1)>`,
}
for _, p := range payloads {
t.Run(p, func(t *testing.T) {
out := PingPage(p, nil, nil).Render()
if strings.Contains(out, p) {
t.Fatalf("payload rendered without escaping: %q", p)
}
})
}
}