mirror of
https://github.com/refraction-networking/utls.git
synced 2025-04-03 20:17:36 +03:00
Merge branch golang crypto/tls upstream
This commit is contained in:
commit
ceee37ab69
29 changed files with 1664 additions and 1941 deletions
42
tls_test.go
42
tls_test.go
|
@ -18,6 +18,7 @@ import (
|
|||
"os"
|
||||
"reflect"
|
||||
"strings"
|
||||
"sync"
|
||||
"testing"
|
||||
"time"
|
||||
)
|
||||
|
@ -1076,18 +1077,47 @@ func TestEscapeRoute(t *testing.T) {
|
|||
VersionSSL30,
|
||||
}
|
||||
|
||||
ss, cs, err := testHandshake(t, testConfig, testConfig)
|
||||
expectVersion(t, testConfig, testConfig, VersionTLS12)
|
||||
}
|
||||
|
||||
func expectVersion(t *testing.T, clientConfig, serverConfig *Config, v uint16) {
|
||||
ss, cs, err := testHandshake(t, clientConfig, serverConfig)
|
||||
if err != nil {
|
||||
t.Fatalf("Handshake failed when support for TLS 1.3 was dropped: %v", err)
|
||||
t.Fatalf("Handshake failed: %v", err)
|
||||
}
|
||||
if ss.Version != VersionTLS12 {
|
||||
t.Errorf("Server negotiated version %x, expected %x", cs.Version, VersionTLS12)
|
||||
if ss.Version != v {
|
||||
t.Errorf("Server negotiated version %x, expected %x", cs.Version, v)
|
||||
}
|
||||
if cs.Version != VersionTLS12 {
|
||||
t.Errorf("Client negotiated version %x, expected %x", cs.Version, VersionTLS12)
|
||||
if cs.Version != v {
|
||||
t.Errorf("Client negotiated version %x, expected %x", cs.Version, v)
|
||||
}
|
||||
}
|
||||
|
||||
// TestTLS13Switch checks the behavior of GODEBUG=tls13=[0|1]. See Issue 30055.
|
||||
func TestTLS13Switch(t *testing.T) {
|
||||
defer func(savedGODEBUG string) {
|
||||
os.Setenv("GODEBUG", savedGODEBUG)
|
||||
}(os.Getenv("GODEBUG"))
|
||||
|
||||
os.Setenv("GODEBUG", "tls13=0")
|
||||
tls13Support.Once = sync.Once{} // reset the cache
|
||||
|
||||
tls12Config := testConfig.Clone()
|
||||
tls12Config.MaxVersion = VersionTLS12
|
||||
expectVersion(t, testConfig, testConfig, VersionTLS12)
|
||||
expectVersion(t, tls12Config, testConfig, VersionTLS12)
|
||||
expectVersion(t, testConfig, tls12Config, VersionTLS12)
|
||||
expectVersion(t, tls12Config, tls12Config, VersionTLS12)
|
||||
|
||||
os.Setenv("GODEBUG", "tls13=1")
|
||||
tls13Support.Once = sync.Once{} // reset the cache
|
||||
|
||||
expectVersion(t, testConfig, testConfig, VersionTLS13)
|
||||
expectVersion(t, tls12Config, testConfig, VersionTLS12)
|
||||
expectVersion(t, testConfig, tls12Config, VersionTLS12)
|
||||
expectVersion(t, tls12Config, tls12Config, VersionTLS12)
|
||||
}
|
||||
|
||||
// Issue 28744: Ensure that we don't modify memory
|
||||
// that Config doesn't own such as Certificates.
|
||||
func TestBuildNameToCertificate_doesntModifyCertificates(t *testing.T) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue