kex_test.go 1.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  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. "reflect"
  9. "testing"
  10. )
  11. func TestKexes(t *testing.T) {
  12. type kexResultErr struct {
  13. result *kexResult
  14. err error
  15. }
  16. for name, kex := range kexAlgoMap {
  17. a, b := memPipe()
  18. s := make(chan kexResultErr, 1)
  19. c := make(chan kexResultErr, 1)
  20. var magics handshakeMagics
  21. go func() {
  22. r, e := kex.Client(a, rand.Reader, &magics)
  23. c <- kexResultErr{r, e}
  24. }()
  25. go func() {
  26. r, e := kex.Server(b, rand.Reader, &magics, testSigners["ecdsa"])
  27. s <- kexResultErr{r, e}
  28. }()
  29. clientRes := <-c
  30. serverRes := <-s
  31. if clientRes.err != nil {
  32. t.Errorf("client: %v", clientRes.err)
  33. }
  34. if serverRes.err != nil {
  35. t.Errorf("server: %v", serverRes.err)
  36. }
  37. if !reflect.DeepEqual(clientRes.result, serverRes.result) {
  38. t.Errorf("kex %q: mismatch %#v, %#v", name, clientRes.result, serverRes.result)
  39. }
  40. }
  41. }