kex_test.go 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  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. "sync"
  10. "testing"
  11. )
  12. // Runs multiple key exchanges concurrent to detect potential data races with
  13. // kex obtained from the global kexAlgoMap.
  14. // This test needs to be executed using the race detector in order to detect
  15. // race conditions.
  16. func TestKexes(t *testing.T) {
  17. type kexResultErr struct {
  18. result *kexResult
  19. err error
  20. }
  21. for name, kex := range kexAlgoMap {
  22. t.Run(name, func(t *testing.T) {
  23. wg := sync.WaitGroup{}
  24. for i := 0; i < 3; i++ {
  25. wg.Add(1)
  26. go func() {
  27. defer wg.Done()
  28. a, b := memPipe()
  29. s := make(chan kexResultErr, 1)
  30. c := make(chan kexResultErr, 1)
  31. var magics handshakeMagics
  32. go func() {
  33. r, e := kex.Client(a, rand.Reader, &magics)
  34. a.Close()
  35. c <- kexResultErr{r, e}
  36. }()
  37. go func() {
  38. r, e := kex.Server(b, rand.Reader, &magics, testSigners["ecdsa"])
  39. b.Close()
  40. s <- kexResultErr{r, e}
  41. }()
  42. clientRes := <-c
  43. serverRes := <-s
  44. if clientRes.err != nil {
  45. t.Errorf("client: %v", clientRes.err)
  46. }
  47. if serverRes.err != nil {
  48. t.Errorf("server: %v", serverRes.err)
  49. }
  50. if !reflect.DeepEqual(clientRes.result, serverRes.result) {
  51. t.Errorf("kex %q: mismatch %#v, %#v", name, clientRes.result, serverRes.result)
  52. }
  53. }()
  54. }
  55. wg.Wait()
  56. })
  57. }
  58. }