| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- // Copyright 2013 The Go Authors. All rights reserved.
- // Use of this source code is governed by a BSD-style
- // license that can be found in the LICENSE file.
- package ssh
- // Key exchange tests.
- import (
- "crypto/rand"
- "io"
- "reflect"
- "testing"
- )
- // An in-memory packetConn.
- type memTransport struct {
- r, w chan []byte
- }
- func (t *memTransport) readPacket() ([]byte, error) {
- p, ok := <-t.r
- if !ok {
- return nil, io.EOF
- }
- return p, nil
- }
- func (t *memTransport) Close() error {
- close(t.w)
- return nil
- }
- func (t *memTransport) writePacket(p []byte) error {
- t.w <- p
- return nil
- }
- func memPipe() (a, b packetConn) {
- p := make(chan []byte, 1)
- q := make(chan []byte, 1)
- return &memTransport{p, q}, &memTransport{q, p}
- }
- func TestKexes(t *testing.T) {
- type kexResultErr struct {
- result *kexResult
- err error
- }
- for name, kex := range kexAlgoMap {
- a, b := memPipe()
- s := make(chan kexResultErr, 1)
- c := make(chan kexResultErr, 1)
- var magics handshakeMagics
- go func() {
- r, e := kex.Client(a, rand.Reader, &magics)
- c <- kexResultErr{r, e}
- }()
- go func() {
- r, e := kex.Server(b, rand.Reader, &magics, ecdsaKey)
- s <- kexResultErr{r, e}
- }()
- clientRes := <-c
- serverRes := <-s
- if clientRes.err != nil {
- t.Errorf("client: %v", clientRes.err)
- }
- if serverRes.err != nil {
- t.Errorf("server: %v", serverRes.err)
- }
- if !reflect.DeepEqual(clientRes.result, serverRes.result) {
- t.Errorf("kex %q: mismatch %#v, %#v", name, clientRes.result, serverRes.result)
- }
- }
- }
|