nodeHttpController_test.go 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. package controller
  2. import (
  3. "testing"
  4. "github.com/gravitl/netmaker/database"
  5. "github.com/gravitl/netmaker/logic"
  6. "github.com/gravitl/netmaker/models"
  7. "github.com/stretchr/testify/assert"
  8. )
  9. func TestCreateEgressGateway(t *testing.T) {
  10. var gateway models.EgressGatewayRequest
  11. gateway.Interface = "eth0"
  12. gateway.Ranges = []string{"10.100.100.0/24"}
  13. database.InitializeDatabase()
  14. deleteAllNetworks()
  15. createNet()
  16. t.Run("NoNodes", func(t *testing.T) {
  17. node, err := CreateEgressGateway(gateway)
  18. assert.Equal(t, models.Node{}, node)
  19. assert.EqualError(t, err, "unable to get record key")
  20. })
  21. t.Run("Success", func(t *testing.T) {
  22. testnode := createTestNode()
  23. gateway.NetID = "skynet"
  24. gateway.NodeID = testnode.MacAddress
  25. node, err := CreateEgressGateway(gateway)
  26. assert.Nil(t, err)
  27. assert.Equal(t, "yes", node.IsEgressGateway)
  28. assert.Equal(t, gateway.Ranges, node.EgressGatewayRanges)
  29. })
  30. }
  31. func TestDeleteEgressGateway(t *testing.T) {
  32. var gateway models.EgressGatewayRequest
  33. database.InitializeDatabase()
  34. deleteAllNetworks()
  35. createNet()
  36. createTestNode()
  37. testnode := createTestNode()
  38. gateway.Interface = "eth0"
  39. gateway.Ranges = []string{"10.100.100.0/24"}
  40. gateway.NetID = "skynet"
  41. gateway.NodeID = testnode.MacAddress
  42. t.Run("Success", func(t *testing.T) {
  43. node, err := CreateEgressGateway(gateway)
  44. assert.Nil(t, err)
  45. assert.Equal(t, "yes", node.IsEgressGateway)
  46. assert.Equal(t, []string{"10.100.100.0/24"}, node.EgressGatewayRanges)
  47. node, err = DeleteEgressGateway(gateway.NetID, gateway.NodeID)
  48. assert.Nil(t, err)
  49. assert.Equal(t, "no", node.IsEgressGateway)
  50. assert.Equal(t, []string([]string{}), node.EgressGatewayRanges)
  51. assert.Equal(t, "", node.PostUp)
  52. assert.Equal(t, "", node.PostDown)
  53. })
  54. t.Run("NotGateway", func(t *testing.T) {
  55. node, err := DeleteEgressGateway(gateway.NetID, gateway.NodeID)
  56. assert.Nil(t, err)
  57. assert.Equal(t, "no", node.IsEgressGateway)
  58. assert.Equal(t, []string([]string{}), node.EgressGatewayRanges)
  59. assert.Equal(t, "", node.PostUp)
  60. assert.Equal(t, "", node.PostDown)
  61. })
  62. t.Run("BadNode", func(t *testing.T) {
  63. node, err := DeleteEgressGateway(gateway.NetID, "01:02:03")
  64. assert.EqualError(t, err, "no result found")
  65. assert.Equal(t, models.Node{}, node)
  66. })
  67. t.Run("BadNet", func(t *testing.T) {
  68. node, err := DeleteEgressGateway("badnet", gateway.NodeID)
  69. assert.EqualError(t, err, "no result found")
  70. assert.Equal(t, models.Node{}, node)
  71. })
  72. }
  73. func TestGetNetworkNodes(t *testing.T) {
  74. database.InitializeDatabase()
  75. deleteAllNetworks()
  76. createNet()
  77. t.Run("BadNet", func(t *testing.T) {
  78. node, err := logic.GetNetworkNodes("badnet")
  79. assert.Nil(t, err)
  80. assert.Equal(t, []models.Node{}, node)
  81. //assert.Equal(t, "mongo: no documents in result", err.Error())
  82. })
  83. t.Run("NoNodes", func(t *testing.T) {
  84. node, err := logic.GetNetworkNodes("skynet")
  85. assert.Nil(t, err)
  86. assert.Equal(t, []models.Node{}, node)
  87. })
  88. t.Run("Success", func(t *testing.T) {
  89. createTestNode()
  90. node, err := logic.GetNetworkNodes("skynet")
  91. assert.Nil(t, err)
  92. assert.NotEqual(t, []models.Node(nil), node)
  93. })
  94. }
  95. func TestUncordonNode(t *testing.T) {
  96. database.InitializeDatabase()
  97. deleteAllNetworks()
  98. createNet()
  99. node := createTestNode()
  100. t.Run("BadNet", func(t *testing.T) {
  101. resp, err := UncordonNode("badnet", node.MacAddress)
  102. assert.Equal(t, models.Node{}, resp)
  103. assert.EqualError(t, err, "no result found")
  104. })
  105. t.Run("BadMac", func(t *testing.T) {
  106. resp, err := UncordonNode("skynet", "01:02:03")
  107. assert.Equal(t, models.Node{}, resp)
  108. assert.EqualError(t, err, "no result found")
  109. })
  110. t.Run("Success", func(t *testing.T) {
  111. resp, err := UncordonNode("skynet", node.MacAddress)
  112. assert.Nil(t, err)
  113. assert.Equal(t, "no", resp.IsPending)
  114. })
  115. }
  116. func TestValidateEgressGateway(t *testing.T) {
  117. var gateway models.EgressGatewayRequest
  118. t.Run("EmptyRange", func(t *testing.T) {
  119. gateway.Interface = "eth0"
  120. gateway.Ranges = []string{}
  121. err := ValidateEgressGateway(gateway)
  122. assert.EqualError(t, err, "IP Ranges Cannot Be Empty")
  123. })
  124. t.Run("EmptyInterface", func(t *testing.T) {
  125. gateway.Interface = ""
  126. err := ValidateEgressGateway(gateway)
  127. assert.NotNil(t, err)
  128. assert.Equal(t, "Interface cannot be empty", err.Error())
  129. })
  130. t.Run("Success", func(t *testing.T) {
  131. gateway.Interface = "eth0"
  132. gateway.Ranges = []string{"10.100.100.0/24"}
  133. err := ValidateEgressGateway(gateway)
  134. assert.Nil(t, err)
  135. })
  136. }
  137. //
  138. ////func TestUpdateNode(t *testing.T) {
  139. ////}
  140. func deleteAllNodes() {
  141. nodes, _ := logic.GetAllNodes()
  142. for _, node := range nodes {
  143. key := node.MacAddress + "###" + node.Network
  144. DeleteNode(key, true)
  145. }
  146. }