Skip to content

Commit

Permalink
crypto/tls: fix WriteTo method signature
Browse files Browse the repository at this point in the history
Give *recordingConn the correct WriteTo signature
to be an io.WriterTo. This makes vet happy.
It also means that it'll report errors,
which were previously being ignored.

Updates golang#11041

Change-Id: I13f171407d63f4b62427679bff362eb74faddca5
Reviewed-on: https://go-review.googlesource.com/27121
Run-TryBot: Josh Bleecher Snyder <[email protected]>
Reviewed-by: Brad Fitzpatrick <[email protected]>
  • Loading branch information
josharian committed Aug 16, 2016
1 parent 6a4ec07 commit 8e34bdc
Showing 1 changed file with 17 additions and 5 deletions.
22 changes: 17 additions & 5 deletions handshake_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -88,21 +88,33 @@ func (r *recordingConn) Write(b []byte) (n int, err error) {
}

// WriteTo writes Go source code to w that contains the recorded traffic.
func (r *recordingConn) WriteTo(w io.Writer) {
func (r *recordingConn) WriteTo(w io.Writer) (int64, error) {
// TLS always starts with a client to server flow.
clientToServer := true

var written int64
for i, flow := range r.flows {
source, dest := "client", "server"
if !clientToServer {
source, dest = dest, source
}
fmt.Fprintf(w, ">>> Flow %d (%s to %s)\n", i+1, source, dest)
n, err := fmt.Fprintf(w, ">>> Flow %d (%s to %s)\n", i+1, source, dest)
written += int64(n)
if err != nil {
return written, err
}
dumper := hex.Dumper(w)
dumper.Write(flow)
dumper.Close()
n, err = dumper.Write(flow)
written += int64(n)
if err != nil {
return written, err
}
err = dumper.Close()
if err != nil {
return written, err
}
clientToServer = !clientToServer
}
return written, nil
}

func parseTestData(r io.Reader) (flows [][]byte, err error) {
Expand Down

0 comments on commit 8e34bdc

Please sign in to comment.