api_test.go 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. package main
  2. import (
  3. "bytes"
  4. "encoding/json"
  5. "io/ioutil"
  6. "net/http"
  7. "os"
  8. "sync"
  9. "testing"
  10. "time"
  11. controller "github.com/gravitl/netmaker/controllers"
  12. "github.com/gravitl/netmaker/database"
  13. "github.com/gravitl/netmaker/models"
  14. "github.com/stretchr/testify/assert"
  15. )
  16. //should be use models.SuccessResponse and models.SuccessfulUserLoginResponse
  17. //rather than creating new type but having trouble decoding that way
  18. type Auth struct {
  19. Username string
  20. AuthToken string
  21. }
  22. type Success struct {
  23. Code int
  24. Message string
  25. Response Auth
  26. }
  27. type AuthorizeTestCase struct {
  28. testname string
  29. name string
  30. password string
  31. code int
  32. tokenExpected bool
  33. errMessage string
  34. }
  35. var Networks []models.Network
  36. var baseURL string = "http://localhost:8081"
  37. func TestMain(m *testing.M) {
  38. database.InitializeDatabase()
  39. var waitgroup sync.WaitGroup
  40. waitgroup.Add(1)
  41. go controller.HandleRESTRequests(&waitgroup)
  42. time.Sleep(time.Second * 1)
  43. os.Exit(m.Run())
  44. }
  45. func adminExists(t *testing.T) bool {
  46. response, err := http.Get("http://localhost:8081/api/users/adm/hasadmin")
  47. t.Log(err)
  48. assert.Nil(t, 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.UserAuthParams
  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. t.Log(err)
  111. assert.Equal(t, http.StatusOK, response.StatusCode)
  112. }
  113. func createKey(t *testing.T) {
  114. key := models.AccessKey{}
  115. key.Name = "skynet"
  116. key.Uses = 10
  117. response, err := api(t, key, http.MethodPost, baseURL+"/api/networks/skynet/keys", "secretkey")
  118. assert.Nil(t, err, err)
  119. assert.Equal(t, http.StatusOK, response.StatusCode)
  120. defer response.Body.Close()
  121. message, err := ioutil.ReadAll(response.Body)
  122. assert.Nil(t, err, err)
  123. assert.NotNil(t, message, message)
  124. }
  125. func createAccessKey(t *testing.T) (key models.AccessKey) {
  126. //delete existing key if
  127. _, _ = api(t, "", http.MethodDelete, baseURL+"/api/networks/skynet/keys/skynet", "secretkey")
  128. createkey := models.AccessKey{}
  129. createkey.Name = "skynet"
  130. createkey.Uses = 10
  131. response, err := api(t, createkey, http.MethodPost, baseURL+"/api/networks/skynet/keys", "secretkey")
  132. assert.Nil(t, err, err)
  133. assert.Equal(t, http.StatusOK, response.StatusCode)
  134. defer response.Body.Close()
  135. err = json.NewDecoder(response.Body).Decode(&key)
  136. assert.Nil(t, err, err)
  137. return key
  138. }
  139. func getKey(t *testing.T, name string) models.AccessKey {
  140. response, err := api(t, "", http.MethodGet, baseURL+"/api/networks/skynet/keys", "secretkey")
  141. assert.Nil(t, err, err)
  142. assert.Equal(t, http.StatusOK, response.StatusCode)
  143. defer response.Body.Close()
  144. var keys []models.AccessKey
  145. err = json.NewDecoder(response.Body).Decode(&keys)
  146. assert.Nil(t, err, err)
  147. for _, key := range keys {
  148. if key.Name == name {
  149. return key
  150. }
  151. }
  152. return models.AccessKey{}
  153. }
  154. func deleteKey(t *testing.T, key, network string) {
  155. response, err := api(t, "", http.MethodDelete, baseURL+"/api/networks/"+network+"/keys/"+key, "secretkey")
  156. assert.Nil(t, err, err)
  157. //api does not return Deleted Count at this time
  158. //defer response.Body.Close()
  159. //var message mongo.DeleteResult
  160. //err = json.NewDecoder(response.Body).Decode(&message)
  161. //assert.Nil(t, err, err)
  162. assert.Equal(t, http.StatusOK, response.StatusCode)
  163. //assert.Equal(t, int64(1), message.DeletedCount)
  164. }
  165. func deleteNetworks(t *testing.T) {
  166. //delete all node
  167. deleteAllNodes(t)
  168. response, err := api(t, "", http.MethodGet, baseURL+"/api/networks", "secretkey")
  169. assert.Nil(t, err, err)
  170. if response.StatusCode == http.StatusOK {
  171. defer response.Body.Close()
  172. err = json.NewDecoder(response.Body).Decode(&Networks)
  173. assert.Nil(t, err, err)
  174. for _, network := range Networks {
  175. name := network.NetID
  176. _, err := api(t, "", http.MethodDelete, baseURL+"/api/networks/"+name, "secretkey")
  177. assert.Nil(t, err, err)
  178. }
  179. }
  180. }
  181. func deleteNode(t *testing.T) {
  182. response, err := api(t, "", http.MethodDelete, baseURL+"/api/nodes/skynet/01:02:03:04:05:06", "secretkey")
  183. assert.Nil(t, err, err)
  184. assert.Equal(t, http.StatusOK, response.StatusCode)
  185. }
  186. func deleteAllNodes(t *testing.T) {
  187. response, err := api(t, "", http.MethodGet, baseURL+"/api/nodes", "secretkey")
  188. assert.Nil(t, err, err)
  189. assert.Equal(t, http.StatusOK, response.StatusCode)
  190. var nodes []models.Node
  191. defer response.Body.Close()
  192. json.NewDecoder(response.Body).Decode(&nodes)
  193. for _, node := range nodes {
  194. resp, err := api(t, "", http.MethodDelete, baseURL+"/api/nodes/"+node.Network+"/"+node.MacAddress, "secretkey")
  195. assert.Nil(t, err, err)
  196. assert.Equal(t, http.StatusOK, resp.StatusCode)
  197. }
  198. }
  199. func createNode(t *testing.T) {
  200. var node models.Node
  201. key := createAccessKey(t)
  202. node.Address = "10.71.0.1"
  203. node.AccessKey = key.Value
  204. node.MacAddress = "01:02:03:04:05:06"
  205. node.Name = "myNode"
  206. node.PublicKey = "DM5qhLAE20PG9BbfBCger+Ac9D2NDOwCtY1rbYDLf34="
  207. node.Password = "tobedetermined"
  208. node.Endpoint = "10.100.100.4"
  209. response, err := api(t, node, http.MethodPost, "http://localhost:8081:/api/nodes/skynet", "secretkey")
  210. assert.Nil(t, err, err)
  211. assert.Equal(t, http.StatusOK, response.StatusCode)
  212. }
  213. func getNode(t *testing.T) models.Node {
  214. response, err := api(t, "", http.MethodGet, baseURL+"/api/nodes/skynet/01:02:03:04:05:06", "secretkey")
  215. assert.Nil(t, err, err)
  216. assert.Equal(t, http.StatusOK, response.StatusCode)
  217. var node models.Node
  218. defer response.Body.Close()
  219. err = json.NewDecoder(response.Body).Decode(&node)
  220. assert.Nil(t, err, err)
  221. return node
  222. }
  223. func getNetwork(t *testing.T, network string) models.Network {
  224. var net models.Network
  225. response, err := api(t, "", http.MethodGet, baseURL+"/api/networks/"+network, "secretkey")
  226. assert.Nil(t, err, err)
  227. assert.Equal(t, http.StatusOK, response.StatusCode)
  228. defer response.Body.Close()
  229. err = json.NewDecoder(response.Body).Decode(&net)
  230. assert.Nil(t, err, err)
  231. return net
  232. }
  233. func setup(t *testing.T) {
  234. deleteNetworks(t)
  235. createNetwork(t)
  236. createNode(t)
  237. }