pkg-proxy/internal/handler/path_traversal_test.go

27 lines
641 B
Go
Raw Permalink Normal View History

package handler
import "testing"
func TestContainsPathTraversal(t *testing.T) {
tests := []struct {
path string
want bool
}{
{"pool/main/n/nginx/nginx_1.0.deb", false},
{"releases/39/Packages/test.rpm", false},
{"../etc/passwd", true},
{"pool/../../etc/passwd", true},
{"pool/main/../../../etc/shadow", true},
{"pool/..hidden/file", false}, // ".." as a segment, not "..hidden"
{"", false},
}
for _, tt := range tests {
t.Run(tt.path, func(t *testing.T) {
got := containsPathTraversal(tt.path)
if got != tt.want {
t.Errorf("containsPathTraversal(%q) = %v, want %v", tt.path, got, tt.want)
}
})
}
}