kex_test.go 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  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. "fmt"
  8. "net"
  9. "testing"
  10. )
  11. func pipe() (net.Conn, net.Conn, error) {
  12. l, err := net.Listen("tcp", ":0")
  13. if err != nil {
  14. return nil, nil, err
  15. }
  16. conn1, err := net.Dial("tcp", l.Addr().String())
  17. if err != nil {
  18. return nil, nil, err
  19. }
  20. conn2, err := l.Accept()
  21. if err != nil {
  22. conn1.Close()
  23. return nil, nil, err
  24. }
  25. l.Close()
  26. return conn1, conn2, nil
  27. }
  28. func testKexAlgorithm(algo string) error {
  29. crypto := CryptoConfig{
  30. KeyExchanges: []string{algo},
  31. }
  32. serverConfig := ServerConfig{
  33. PasswordCallback: func(conn *ServerConn, user, password string) bool {
  34. return password == "password"
  35. },
  36. Crypto: crypto,
  37. }
  38. if err := serverConfig.SetRSAPrivateKey([]byte(testServerPrivateKey)); err != nil {
  39. return fmt.Errorf("SetRSAPrivateKey: %v", err)
  40. }
  41. clientConfig := ClientConfig{
  42. User: "user",
  43. Auth: []ClientAuth{ClientAuthPassword(password("password"))},
  44. Crypto: crypto,
  45. }
  46. conn1, conn2, err := pipe()
  47. if err != nil {
  48. return err
  49. }
  50. defer conn1.Close()
  51. defer conn2.Close()
  52. server := Server(conn2, &serverConfig)
  53. serverHS := make(chan error, 1)
  54. go func() {
  55. serverHS <- server.Handshake()
  56. }()
  57. // Client runs the handshake.
  58. _, err = Client(conn1, &clientConfig)
  59. if err != nil {
  60. return fmt.Errorf("Client: %v", err)
  61. }
  62. if err := <-serverHS; err != nil {
  63. return fmt.Errorf("server.Handshake: %v", err)
  64. }
  65. // Here we could check that we now can send data between client &
  66. // server.
  67. return nil
  68. }
  69. func TestKexAlgorithms(t *testing.T) {
  70. for _, algo := range []string{kexAlgoECDH256, kexAlgoECDH384, kexAlgoECDH521, kexAlgoDH1SHA1, kexAlgoDH14SHA1} {
  71. if err := testKexAlgorithm(algo); err != nil {
  72. t.Errorf("algorithm %s: %v", algo, err)
  73. }
  74. }
  75. }