mirror of
https://github.com/refraction-networking/utls.git
synced 2025-04-04 04:27:36 +03:00
crypto/tls: implement TLS 1.3 KeyLogWriter support
Also, add support for the SSLKEYLOGFILE environment variable to the tests, to simplify debugging of unexpected failures. Updates #9671 Change-Id: I20a34a5824f083da93097b793d51e796d6eb302b Reviewed-on: https://go-review.googlesource.com/c/147417 Run-TryBot: Filippo Valsorda <filippo@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Adam Langley <agl@golang.org>
This commit is contained in:
parent
b85722092b
commit
f513a10f59
7 changed files with 106 additions and 6 deletions
|
@ -968,6 +968,49 @@ func TestKeyLog(t *testing.T) {
|
|||
checkKeylogLine("server", serverBuf.String())
|
||||
}
|
||||
|
||||
func TestKeyLogTLS13(t *testing.T) {
|
||||
var serverBuf, clientBuf bytes.Buffer
|
||||
|
||||
clientConfig := testConfig.Clone()
|
||||
clientConfig.KeyLogWriter = &clientBuf
|
||||
clientConfig.MaxVersion = VersionTLS13
|
||||
|
||||
serverConfig := testConfig.Clone()
|
||||
serverConfig.KeyLogWriter = &serverBuf
|
||||
serverConfig.MaxVersion = VersionTLS13
|
||||
|
||||
c, s := localPipe(t)
|
||||
done := make(chan bool)
|
||||
|
||||
go func() {
|
||||
defer close(done)
|
||||
|
||||
if err := Server(s, serverConfig).Handshake(); err != nil {
|
||||
t.Errorf("server: %s", err)
|
||||
return
|
||||
}
|
||||
s.Close()
|
||||
}()
|
||||
|
||||
if err := Client(c, clientConfig).Handshake(); err != nil {
|
||||
t.Fatalf("client: %s", err)
|
||||
}
|
||||
|
||||
c.Close()
|
||||
<-done
|
||||
|
||||
checkKeylogLines := func(side, loggedLines string) {
|
||||
loggedLines = strings.TrimSpace(loggedLines)
|
||||
lines := strings.Split(loggedLines, "\n")
|
||||
if len(lines) != 4 {
|
||||
t.Errorf("Expected the %s to log 4 lines, got %d", side, len(lines))
|
||||
}
|
||||
}
|
||||
|
||||
checkKeylogLines("client", clientBuf.String())
|
||||
checkKeylogLines("server", serverBuf.String())
|
||||
}
|
||||
|
||||
func TestHandshakeClientALPNMatch(t *testing.T) {
|
||||
config := testConfig.Clone()
|
||||
config.NextProtos = []string{"proto2", "proto1"}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue