service_test.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. package service
  2. import (
  3. "bytes"
  4. "context"
  5. "errors"
  6. "net"
  7. "testing"
  8. "time"
  9. "dario.cat/mergo"
  10. "github.com/slackhq/nebula/cert"
  11. "github.com/slackhq/nebula/config"
  12. "github.com/slackhq/nebula/e2e"
  13. "golang.org/x/sync/errgroup"
  14. "gopkg.in/yaml.v2"
  15. )
  16. type m map[string]interface{}
  17. func newSimpleService(caCrt *cert.NebulaCertificate, caKey []byte, name string, udpIp net.IP, overrides m) *Service {
  18. vpnIpNet := &net.IPNet{IP: make([]byte, len(udpIp)), Mask: net.IPMask{255, 255, 255, 0}}
  19. copy(vpnIpNet.IP, udpIp)
  20. _, _, myPrivKey, myPEM := e2e.NewTestCert(caCrt, caKey, "a", time.Now(), time.Now().Add(5*time.Minute), vpnIpNet, nil, []string{})
  21. caB, err := caCrt.MarshalToPEM()
  22. if err != nil {
  23. panic(err)
  24. }
  25. mc := m{
  26. "pki": m{
  27. "ca": string(caB),
  28. "cert": string(myPEM),
  29. "key": string(myPrivKey),
  30. },
  31. //"tun": m{"disabled": true},
  32. "firewall": m{
  33. "outbound": []m{{
  34. "proto": "any",
  35. "port": "any",
  36. "host": "any",
  37. }},
  38. "inbound": []m{{
  39. "proto": "any",
  40. "port": "any",
  41. "host": "any",
  42. }},
  43. },
  44. "timers": m{
  45. "pending_deletion_interval": 2,
  46. "connection_alive_interval": 2,
  47. },
  48. "handshakes": m{
  49. "try_interval": "200ms",
  50. },
  51. }
  52. if overrides != nil {
  53. err = mergo.Merge(&overrides, mc, mergo.WithAppendSlice)
  54. if err != nil {
  55. panic(err)
  56. }
  57. mc = overrides
  58. }
  59. cb, err := yaml.Marshal(mc)
  60. if err != nil {
  61. panic(err)
  62. }
  63. var c config.C
  64. if err := c.LoadString(string(cb)); err != nil {
  65. panic(err)
  66. }
  67. s, err := New(&c)
  68. if err != nil {
  69. panic(err)
  70. }
  71. return s
  72. }
  73. func TestService(t *testing.T) {
  74. ca, _, caKey, _ := e2e.NewTestCaCert(time.Now(), time.Now().Add(10*time.Minute), []*net.IPNet{}, []*net.IPNet{}, []string{})
  75. a := newSimpleService(ca, caKey, "a", net.IP{10, 0, 0, 1}, m{
  76. "static_host_map": m{},
  77. "lighthouse": m{
  78. "am_lighthouse": true,
  79. },
  80. "listen": m{
  81. "host": "0.0.0.0",
  82. "port": 4243,
  83. },
  84. })
  85. b := newSimpleService(ca, caKey, "b", net.IP{10, 0, 0, 2}, m{
  86. "static_host_map": m{
  87. "10.0.0.1": []string{"localhost:4243"},
  88. },
  89. "lighthouse": m{
  90. "hosts": []string{"10.0.0.1"},
  91. "interval": 1,
  92. },
  93. })
  94. ln, err := a.Listen("tcp", ":1234")
  95. if err != nil {
  96. t.Fatal(err)
  97. }
  98. var eg errgroup.Group
  99. eg.Go(func() error {
  100. conn, err := ln.Accept()
  101. if err != nil {
  102. return err
  103. }
  104. defer conn.Close()
  105. t.Log("accepted connection")
  106. if _, err := conn.Write([]byte("server msg")); err != nil {
  107. return err
  108. }
  109. t.Log("server: wrote message")
  110. data := make([]byte, 100)
  111. n, err := conn.Read(data)
  112. if err != nil {
  113. return err
  114. }
  115. data = data[:n]
  116. if !bytes.Equal(data, []byte("client msg")) {
  117. return errors.New("got invalid message from client")
  118. }
  119. t.Log("server: read message")
  120. return conn.Close()
  121. })
  122. c, err := b.DialContext(context.Background(), "tcp", "10.0.0.1:1234")
  123. if err != nil {
  124. t.Fatal(err)
  125. }
  126. if _, err := c.Write([]byte("client msg")); err != nil {
  127. t.Fatal(err)
  128. }
  129. data := make([]byte, 100)
  130. n, err := c.Read(data)
  131. if err != nil {
  132. t.Fatal(err)
  133. }
  134. data = data[:n]
  135. if !bytes.Equal(data, []byte("server msg")) {
  136. t.Fatal("got invalid message from client")
  137. }
  138. if err := c.Close(); err != nil {
  139. t.Fatal(err)
  140. }
  141. if err := eg.Wait(); err != nil {
  142. t.Fatal(err)
  143. }
  144. }