kex_test.go 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. // Copyright 2013 The Go Authors. All rights reserved.
  2. // Use of this source code is governed by a BSD-style
  3. // license that can be found in the LICENSE file.
  4. package ssh
  5. // Key exchange tests.
  6. import (
  7. "crypto/rand"
  8. "io"
  9. "reflect"
  10. "testing"
  11. )
  12. // An in-memory packetConn.
  13. type memTransport struct {
  14. r, w chan []byte
  15. }
  16. func (t *memTransport) readPacket() ([]byte, error) {
  17. p, ok := <-t.r
  18. if !ok {
  19. return nil, io.EOF
  20. }
  21. return p, nil
  22. }
  23. func (t *memTransport) Close() error {
  24. close(t.w)
  25. return nil
  26. }
  27. func (t *memTransport) writePacket(p []byte) error {
  28. t.w <- p
  29. return nil
  30. }
  31. func memPipe() (a, b packetConn) {
  32. p := make(chan []byte, 1)
  33. q := make(chan []byte, 1)
  34. return &memTransport{p, q}, &memTransport{q, p}
  35. }
  36. func TestKexes(t *testing.T) {
  37. type kexResultErr struct {
  38. result *kexResult
  39. err error
  40. }
  41. for name, kex := range kexAlgoMap {
  42. a, b := memPipe()
  43. s := make(chan kexResultErr, 1)
  44. c := make(chan kexResultErr, 1)
  45. var magics handshakeMagics
  46. go func() {
  47. r, e := kex.Client(a, rand.Reader, &magics)
  48. c <- kexResultErr{r, e}
  49. }()
  50. go func() {
  51. r, e := kex.Server(b, rand.Reader, &magics, ecdsaKey)
  52. s <- kexResultErr{r, e}
  53. }()
  54. clientRes := <-c
  55. serverRes := <-s
  56. if clientRes.err != nil {
  57. t.Errorf("client: %v", clientRes.err)
  58. }
  59. if serverRes.err != nil {
  60. t.Errorf("server: %v", serverRes.err)
  61. }
  62. if !reflect.DeepEqual(clientRes.result, serverRes.result) {
  63. t.Errorf("kex %q: mismatch %#v, %#v", name, clientRes.result, serverRes.result)
  64. }
  65. }
  66. }