mirror of
https://github.com/caddyserver/caddy.git
synced 2026-04-18 22:20:44 -04:00
Reuse shared protocol defaults instead of repeating the default HTTP protocol list, unify server name registration to carry ALPN in one experimental API and reuse the TLS default ALPN ordering for HTTPS RR publication
66 lines
1.7 KiB
Go
66 lines
1.7 KiB
Go
package caddytls
|
|
|
|
import (
|
|
"encoding/base64"
|
|
"reflect"
|
|
"sync"
|
|
"testing"
|
|
|
|
"github.com/libdns/libdns"
|
|
)
|
|
|
|
func TestRegisterServerNamesWithALPN(t *testing.T) {
|
|
tlsApp := &TLS{
|
|
serverNames: make(map[string]serverNameRegistration),
|
|
serverNamesMu: new(sync.Mutex),
|
|
}
|
|
|
|
tlsApp.RegisterServerNames([]string{
|
|
"Example.com:443",
|
|
"example.com",
|
|
"127.0.0.1:443",
|
|
}, []string{"h2", "http/1.1"})
|
|
tlsApp.RegisterServerNames([]string{"EXAMPLE.COM"}, []string{"h3"})
|
|
|
|
got := tlsApp.alpnValuesForServerNames([]string{"example.com:443", "127.0.0.1:443"})
|
|
want := map[string][]string{
|
|
"example.com": {"h3", "h2", "http/1.1"},
|
|
}
|
|
|
|
if !reflect.DeepEqual(got, want) {
|
|
t.Fatalf("unexpected ALPN values: got %#v want %#v", got, want)
|
|
}
|
|
}
|
|
|
|
func TestECHDNSPublisherPublishedSvcParams(t *testing.T) {
|
|
dnsPub := &ECHDNSPublisher{
|
|
alpnByDomain: map[string][]string{
|
|
"example.com": {"h3", "h2", "http/1.1"},
|
|
},
|
|
}
|
|
|
|
existing := libdns.SvcParams{
|
|
"alpn": {"h2"},
|
|
"ipv4hint": {"203.0.113.10"},
|
|
}
|
|
|
|
got := dnsPub.publishedSvcParams("Example.com", existing, []byte{0x01, 0x02, 0x03})
|
|
|
|
if !reflect.DeepEqual(existing["alpn"], []string{"h2"}) {
|
|
t.Fatalf("existing params mutated: got %v", existing["alpn"])
|
|
}
|
|
|
|
if !reflect.DeepEqual(got["alpn"], []string{"h3", "h2", "http/1.1"}) {
|
|
t.Fatalf("unexpected ALPN params: got %v", got["alpn"])
|
|
}
|
|
|
|
if !reflect.DeepEqual(got["ipv4hint"], []string{"203.0.113.10"}) {
|
|
t.Fatalf("unexpected preserved params: got %v", got["ipv4hint"])
|
|
}
|
|
|
|
wantECH := base64.StdEncoding.EncodeToString([]byte{0x01, 0x02, 0x03})
|
|
if !reflect.DeepEqual(got["ech"], []string{wantECH}) {
|
|
t.Fatalf("unexpected ECH params: got %v want %v", got["ech"], wantECH)
|
|
}
|
|
}
|