common_test.go.bak 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. package controller
  2. import (
  3. "testing"
  4. "time"
  5. "github.com/gravitl/netmaker/database"
  6. "github.com/gravitl/netmaker/models"
  7. "github.com/stretchr/testify/assert"
  8. )
  9. func TestGetPeerList(t *testing.T) {
  10. database.InitializeDatabase()
  11. database.InitializeDatabase()
  12. //deleteNet(t)
  13. //createNet()
  14. _ = createTestNode(t)
  15. //createnode := models.Node{PublicKey: "RM5qhLAE20PG9BbfBCger+Ac9D2NDOwCtY1rbYDLf34=", Endpoint: "10.0.0.2", MacAddress: "02:02:03:04:05:06", Password: "password", Network: "skynet"}
  16. //_, _ = CreateNode(createnode, "skynet")
  17. t.Run("PeerExist", func(t *testing.T) {
  18. peers, err := GetPeersList("skynet")
  19. assert.Nil(t, err)
  20. assert.NotEqual(t, []models.PeersResponse(nil), peers)
  21. t.Log(peers)
  22. })
  23. t.Run("NoNodes", func(t *testing.T) {
  24. // _ = DeleteNode("01:02:03:04:05:06", "skynet")
  25. peers, err := GetPeersList("skynet")
  26. assert.Nil(t, err)
  27. assert.Equal(t, []models.PeersResponse(nil), peers)
  28. t.Log(peers)
  29. })
  30. }
  31. type NodeValidationTC struct {
  32. testname string
  33. node models.Node
  34. errorMessage string
  35. }
  36. type NodeValidationUpdateTC struct {
  37. testname string
  38. node models.Node
  39. errorMessage string
  40. }
  41. func TestDeleteNode(t *testing.T) {
  42. database.InitializeDatabase()
  43. //deleteNet(t)
  44. //createNet()
  45. //node := createTestNode(t)
  46. t.Run("NodeExists", func(t *testing.T) {
  47. //err := DeleteNode(node.MacAddress, node.Network)
  48. //assert.Nil(t, err)
  49. })
  50. t.Run("NonExistantNode", func(t *testing.T) {
  51. //err := DeleteNode(node.MacAddress, node.Network)
  52. //assert.Nil(t, err)
  53. })
  54. }
  55. func TestGetNode(t *testing.T) {
  56. database.InitializeDatabase()
  57. //deleteNet(t)
  58. //createNet()
  59. node := createTestNode(t)
  60. t.Run("NodeExists", func(t *testing.T) {
  61. response, err := GetNode(node.MacAddress, node.Network)
  62. assert.Nil(t, err)
  63. assert.Equal(t, "10.0.0.1", response.Endpoint)
  64. assert.Equal(t, "DM5qhLAE20PG9BbfBCger+Ac9D2NDOwCtY1rbYDLf34=", response.PublicKey)
  65. assert.Equal(t, "01:02:03:04:05:06", response.MacAddress)
  66. assert.Equal(t, int32(51821), response.ListenPort)
  67. assert.NotNil(t, response.Name)
  68. assert.Equal(t, "skynet", response.Network)
  69. assert.Equal(t, "nm-skynet", response.Interface)
  70. })
  71. t.Run("BadMac", func(t *testing.T) {
  72. response, err := GetNode("01:02:03:04:05:07", node.Network)
  73. assert.NotNil(t, err)
  74. assert.Equal(t, models.Node{}, response)
  75. assert.Equal(t, "mongo: no documents in result", err.Error())
  76. })
  77. t.Run("BadNetwork", func(t *testing.T) {
  78. response, err := GetNode(node.MacAddress, "badnet")
  79. assert.NotNil(t, err)
  80. assert.Equal(t, models.Node{}, response)
  81. assert.Equal(t, "mongo: no documents in result", err.Error())
  82. })
  83. t.Run("NoNode", func(t *testing.T) {
  84. //_ = DeleteNode("01:02:03:04:05:06", "skynet")
  85. response, err := GetNode(node.MacAddress, node.Network)
  86. assert.NotNil(t, err)
  87. assert.Equal(t, models.Node{}, response)
  88. //assert.Equal(t, "mongo: no documents in result", err.Error())
  89. })
  90. }
  91. func TestCreateNode(t *testing.T) {
  92. database.InitializeDatabase()
  93. //deleteNet(t)
  94. //createNet()
  95. createnode := models.Node{PublicKey: "DM5qhLAE20PG9BbfBCger+Ac9D2NDOwCtY1rbYDLf34=", Endpoint: "10.0.0.1", MacAddress: "01:02:03:04:05:06", Password: "password", Network: "skynet"}
  96. //err := ValidateNodeCreate("skynet", createnode)
  97. //assert.Nil(t, err)
  98. node, err := CreateNode(createnode, "skynet")
  99. assert.Nil(t, err)
  100. assert.Equal(t, "10.0.0.1", node.Endpoint)
  101. assert.Equal(t, "DM5qhLAE20PG9BbfBCger+Ac9D2NDOwCtY1rbYDLf34=", node.PublicKey)
  102. assert.Equal(t, "01:02:03:04:05:06", node.MacAddress)
  103. assert.Equal(t, int32(51821), node.ListenPort)
  104. assert.NotNil(t, node.Name)
  105. assert.Equal(t, "skynet", node.Network)
  106. assert.Equal(t, "nm-skynet", node.Interface)
  107. }
  108. func TestSetNetworkNodesLastModified(t *testing.T) {
  109. database.InitializeDatabase()
  110. //deleteNet(t)
  111. //createNet()
  112. t.Run("InvalidNetwork", func(t *testing.T) {
  113. err := SetNetworkNodesLastModified("badnet")
  114. assert.NotNil(t, err)
  115. assert.Equal(t, "mongo: no documents in result", err.Error())
  116. })
  117. t.Run("NetworkExists", func(t *testing.T) {
  118. err := SetNetworkNodesLastModified("skynet")
  119. assert.Nil(t, err)
  120. })
  121. }
  122. func TestTimestampNode(t *testing.T) {
  123. database.InitializeDatabase()
  124. //deleteNet(t)
  125. //createNet()
  126. node := createTestNode(t)
  127. time.Sleep(time.Second * 1)
  128. before, err := GetNode(node.MacAddress, node.Network)
  129. assert.Nil(t, err)
  130. t.Run("UpdateCheckIn", func(t *testing.T) {
  131. err = TimestampNode(node, true, false, false)
  132. assert.Nil(t, err)
  133. after, err := GetNode(node.MacAddress, node.Network)
  134. assert.Nil(t, err)
  135. assert.Greater(t, after.LastCheckIn, before.LastCheckIn)
  136. })
  137. t.Run("UpdatePeers", func(t *testing.T) {
  138. err = TimestampNode(node, false, true, false)
  139. assert.Nil(t, err)
  140. after, err := GetNode(node.MacAddress, node.Network)
  141. assert.Nil(t, err)
  142. assert.Greater(t, after.LastPeerUpdate, before.LastPeerUpdate)
  143. })
  144. t.Run("UpdateLastModified", func(t *testing.T) {
  145. err = TimestampNode(node, false, false, true)
  146. assert.Nil(t, err)
  147. after, err := GetNode(node.MacAddress, node.Network)
  148. assert.Nil(t, err)
  149. assert.Greater(t, after.LastModified, before.LastModified)
  150. })
  151. t.Run("InvalidNode", func(t *testing.T) {
  152. node.MacAddress = "01:02:03:04:05:08"
  153. err = TimestampNode(node, true, true, true)
  154. assert.NotNil(t, err)
  155. //assert.Equal(t, "mongo: no documents in result", err.Error())
  156. })
  157. }
  158. func createTestNode(t *testing.T) models.Node {
  159. createnode := models.Node{PublicKey: "DM5qhLAE20PG9BbfBCger+Ac9D2NDOwCtY1rbYDLf34=", Endpoint: "10.0.0.1", MacAddress: "01:02:03:04:05:06", Password: "password", Network: "skynet"}
  160. node, err := CreateNode(createnode, "skynet")
  161. assert.Nil(t, err)
  162. t.Log(err)
  163. return node
  164. }