api_test.go 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258
  1. package main
  2. import (
  3. "bytes"
  4. "context"
  5. "encoding/json"
  6. "io/ioutil"
  7. "net/http"
  8. "os"
  9. "sync"
  10. "testing"
  11. "time"
  12. controller "github.com/gravitl/netmaker/controllers"
  13. "github.com/gravitl/netmaker/models"
  14. "github.com/gravitl/netmaker/mongoconn"
  15. "github.com/stretchr/testify/assert"
  16. )
  17. //should be use models.SuccessResponse and models.SuccessfulUserLoginResponse
  18. //rather than creating new type but having trouble decoding that way
  19. type Auth struct {
  20. Username string
  21. AuthToken string
  22. }
  23. type Success struct {
  24. Code int
  25. Message string
  26. Response Auth
  27. }
  28. type AuthorizeTestCase struct {
  29. testname string
  30. name string
  31. password string
  32. code int
  33. tokenExpected bool
  34. errMessage string
  35. }
  36. var Networks []models.Network
  37. var baseURL string = "http://localhost:8081"
  38. func TestMain(m *testing.M) {
  39. mongoconn.ConnectDatabase()
  40. var waitgroup sync.WaitGroup
  41. waitgroup.Add(1)
  42. go controller.HandleRESTRequests(&waitgroup)
  43. time.Sleep(time.Second * 1)
  44. os.Exit(m.Run())
  45. }
  46. func adminExists(t *testing.T) bool {
  47. response, err := http.Get("http://localhost:8081/api/users/adm/hasadmin")
  48. assert.Nil(t, err, err)
  49. assert.Equal(t, http.StatusOK, response.StatusCode)
  50. defer response.Body.Close()
  51. var body bool
  52. json.NewDecoder(response.Body).Decode(&body)
  53. return body
  54. }
  55. func api(t *testing.T, data interface{}, method, url, authorization string) (*http.Response, error) {
  56. var request *http.Request
  57. var err error
  58. if data != "" {
  59. payload, err := json.Marshal(data)
  60. assert.Nil(t, err, err)
  61. request, err = http.NewRequest(method, url, bytes.NewBuffer(payload))
  62. assert.Nil(t, err, err)
  63. request.Header.Set("Content-Type", "application/json")
  64. } else {
  65. request, err = http.NewRequest(method, url, nil)
  66. assert.Nil(t, err, err)
  67. }
  68. if authorization != "" {
  69. request.Header.Set("authorization", "Bearer "+authorization)
  70. }
  71. client := http.Client{}
  72. return client.Do(request)
  73. }
  74. func addAdmin(t *testing.T) {
  75. var admin models.User
  76. admin.UserName = "admin"
  77. admin.Password = "password"
  78. response, err := api(t, admin, http.MethodPost, baseURL+"/api/users/adm/createadmin", "secretkey")
  79. assert.Nil(t, err, err)
  80. assert.Equal(t, http.StatusOK, response.StatusCode)
  81. }
  82. func authenticate(t *testing.T) (string, error) {
  83. var admin models.User
  84. admin.UserName = "admin"
  85. admin.Password = "password"
  86. response, err := api(t, admin, http.MethodPost, baseURL+"/api/users/adm/authenticate", "secretkey")
  87. assert.Nil(t, err, err)
  88. var body Success
  89. err = json.NewDecoder(response.Body).Decode(&body)
  90. assert.Nil(t, err, err)
  91. assert.NotEmpty(t, body.Response.AuthToken, "token not returned")
  92. assert.Equal(t, "W1R3: Device admin Authorized", body.Message)
  93. return body.Response.AuthToken, nil
  94. }
  95. func deleteAdmin(t *testing.T) {
  96. if !adminExists(t) {
  97. return
  98. }
  99. token, err := authenticate(t)
  100. assert.Nil(t, err, err)
  101. _, err = api(t, "", http.MethodDelete, baseURL+"/api/users/admin", token)
  102. assert.Nil(t, err, err)
  103. }
  104. func createNetwork(t *testing.T) {
  105. network := models.Network{}
  106. network.NetID = "skynet"
  107. network.AddressRange = "10.71.0.0/16"
  108. response, err := api(t, network, http.MethodPost, baseURL+"/api/networks", "secretkey")
  109. assert.Nil(t, err, err)
  110. assert.Equal(t, http.StatusOK, response.StatusCode)
  111. }
  112. func createKey(t *testing.T) {
  113. key := models.AccessKey{}
  114. key.Name = "skynet"
  115. key.Uses = 10
  116. response, err := api(t, key, http.MethodPost, baseURL+"/api/networks/skynet/keys", "secretkey")
  117. assert.Nil(t, err, err)
  118. assert.Equal(t, http.StatusOK, response.StatusCode)
  119. defer response.Body.Close()
  120. message, err := ioutil.ReadAll(response.Body)
  121. assert.Nil(t, err, err)
  122. assert.NotNil(t, message, message)
  123. }
  124. func createAccessKey(t *testing.T) (key models.AccessKey) {
  125. createkey := models.AccessKey{}
  126. createkey.Name = "skynet"
  127. createkey.Uses = 10
  128. response, err := api(t, createkey, http.MethodPost, baseURL+"/api/networks/skynet/keys", "secretkey")
  129. assert.Nil(t, err, err)
  130. assert.Equal(t, http.StatusOK, response.StatusCode)
  131. defer response.Body.Close()
  132. err = json.NewDecoder(response.Body).Decode(&key)
  133. assert.Nil(t, err, err)
  134. return key
  135. }
  136. func getKey(t *testing.T, name string) models.AccessKey {
  137. response, err := api(t, "", http.MethodGet, baseURL+"/api/networks/skynet/keys", "secretkey")
  138. assert.Nil(t, err, err)
  139. assert.Equal(t, http.StatusOK, response.StatusCode)
  140. defer response.Body.Close()
  141. var keys []models.AccessKey
  142. err = json.NewDecoder(response.Body).Decode(&keys)
  143. assert.Nil(t, err, err)
  144. for _, key := range keys {
  145. if key.Name == name {
  146. return key
  147. }
  148. }
  149. return models.AccessKey{}
  150. }
  151. func deleteKey(t *testing.T, key, network string) {
  152. response, err := api(t, "", http.MethodDelete, baseURL+"/api/networks/"+network+"/keys/"+key, "secretkey")
  153. assert.Nil(t, err, err)
  154. //api does not return Deleted Count at this time
  155. //defer response.Body.Close()
  156. //var message mongo.DeleteResult
  157. //err = json.NewDecoder(response.Body).Decode(&message)
  158. //assert.Nil(t, err, err)
  159. assert.Equal(t, http.StatusOK, response.StatusCode)
  160. //assert.Equal(t, int64(1), message.DeletedCount)
  161. }
  162. func deleteNetworks(t *testing.T) {
  163. //delete all node
  164. deleteAllNodes(t)
  165. response, err := api(t, "", http.MethodGet, baseURL+"/api/networks", "secretkey")
  166. assert.Nil(t, err, err)
  167. if response.StatusCode == http.StatusOK {
  168. defer response.Body.Close()
  169. err = json.NewDecoder(response.Body).Decode(&Networks)
  170. assert.Nil(t, err, err)
  171. for _, network := range Networks {
  172. name := network.NetID
  173. _, err := api(t, "", http.MethodDelete, baseURL+"/api/networks/"+name, "secretkey")
  174. assert.Nil(t, err, err)
  175. }
  176. }
  177. }
  178. func deleteNode(t *testing.T) {
  179. response, err := api(t, "", http.MethodDelete, baseURL+"/api/nodes/skynet/01:02:03:04:05:06", "secretkey")
  180. assert.Nil(t, err, err)
  181. assert.Equal(t, http.StatusOK, response.StatusCode)
  182. }
  183. func deleteAllNodes(t *testing.T) {
  184. response, err := api(t, "", http.MethodGet, baseURL+"/api/nodes", "secretkey")
  185. assert.Nil(t, err, err)
  186. assert.Equal(t, http.StatusOK, response.StatusCode)
  187. var nodes []models.ReturnNode
  188. defer response.Body.Close()
  189. json.NewDecoder(response.Body).Decode(&nodes)
  190. for _, node := range nodes {
  191. resp, err := api(t, "", http.MethodDelete, baseURL+"/api/nodes/"+node.Network+"/"+node.MacAddress, "secretkey")
  192. assert.Nil(t, err, err)
  193. assert.Equal(t, http.StatusOK, resp.StatusCode)
  194. }
  195. }
  196. func createNode(t *testing.T) {
  197. var node models.Node
  198. key := createAccessKey(t)
  199. node.Address = "10.71.0.1"
  200. node.AccessKey = key.Value
  201. node.MacAddress = "01:02:03:04:05:06"
  202. node.Name = "myNode"
  203. node.PublicKey = "DM5qhLAE20PG9BbfBCger+Ac9D2NDOwCtY1rbYDLf34="
  204. node.Password = "tobedetermined"
  205. node.LocalAddress = "192.168.0.1"
  206. node.Endpoint = "10.100.100.4"
  207. response, err := api(t, node, http.MethodPost, "http://localhost:8081:/api/nodes/skynet", "secretkey")
  208. assert.Nil(t, err, err)
  209. assert.Equal(t, http.StatusOK, response.StatusCode)
  210. }
  211. func getNode(t *testing.T) models.Node {
  212. response, err := api(t, "", http.MethodGet, baseURL+"/api/nodes/skynet/01:02:03:04:05:06", "secretkey")
  213. assert.Nil(t, err, err)
  214. assert.Equal(t, http.StatusOK, response.StatusCode)
  215. var node models.Node
  216. defer response.Body.Close()
  217. err = json.NewDecoder(response.Body).Decode(&node)
  218. assert.Nil(t, err, err)
  219. return node
  220. }
  221. func getNetwork(t *testing.T, network string) models.Network {
  222. var net models.Network
  223. response, err := api(t, "", http.MethodGet, baseURL+"/api/networks/"+network, "secretkey")
  224. assert.Nil(t, err, err)
  225. assert.Equal(t, http.StatusOK, response.StatusCode)
  226. defer response.Body.Close()
  227. err = json.NewDecoder(response.Body).Decode(&net)
  228. assert.Nil(t, err, err)
  229. return net
  230. }
  231. func setup(t *testing.T) {
  232. deleteNetworks(t)
  233. createNetwork(t)
  234. createNode(t)
  235. }