service_test.go 3.5 KB

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