Matthew R Kasun 4 years ago
parent
commit
f28937c1f6
3 changed files with 93 additions and 48 deletions
  1. 10 0
      controllers/nodeHttpController.go
  2. 58 10
      test/api_test.go
  3. 25 38
      test/node_test.go

+ 10 - 0
controllers/nodeHttpController.go

@@ -52,6 +52,8 @@ func authenticate(response http.ResponseWriter, request *http.Request) {
 	defer request.Body.Close()
 
 	if decoderErr != nil {
+		errorResponse.Code = http.StatusBadRequest
+		errorResponse.Message = decoderErr.Error()
 		returnErrorResponse(response, request, errorResponse)
 		return
 	} else {
@@ -74,6 +76,8 @@ func authenticate(response http.ResponseWriter, request *http.Request) {
 			defer cancel()
 
 			if err != nil {
+				errorResponse.Code = http.StatusBadRequest
+				errorResponse.Message = err.Error()
 				returnErrorResponse(response, request, errorResponse)
 				return
 			}
@@ -83,6 +87,8 @@ func authenticate(response http.ResponseWriter, request *http.Request) {
 			//TODO: Consider a way of hashing the password client side before sending, or using certificates
 			err = bcrypt.CompareHashAndPassword([]byte(result.Password), []byte(authRequest.Password))
 			if err != nil {
+				errorResponse.Code = http.StatusBadRequest
+				errorResponse.Message = err.Error()
 				returnErrorResponse(response, request, errorResponse)
 				return
 			} else {
@@ -90,6 +96,8 @@ func authenticate(response http.ResponseWriter, request *http.Request) {
 				tokenString, _ := functions.CreateJWT(authRequest.MacAddress, result.Network)
 
 				if tokenString == "" {
+					errorResponse.Code = http.StatusBadRequest
+					errorResponse.Message = "Could not create Token"
 					returnErrorResponse(response, request, errorResponse)
 					return
 				}
@@ -106,6 +114,8 @@ func authenticate(response http.ResponseWriter, request *http.Request) {
 				successJSONResponse, jsonError := json.Marshal(successResponse)
 
 				if jsonError != nil {
+					errorResponse.Code = http.StatusBadRequest
+					errorResponse.Message = err.Error()
 					returnErrorResponse(response, request, errorResponse)
 					return
 				}

+ 58 - 10
test/api_test.go

@@ -217,29 +217,77 @@ func networkExists(t *testing.T) bool {
 }
 
 func deleteNetworks(t *testing.T) {
-
-	response, err := api(t, "", http.MethodGet, baseURL+"/api/networks", "secretkey")
+	//delete all network nodes
+	var nodes []models.ReturnNode
+	response, err := api(t, "", http.MethodGet, baseURL+"/api/nodes/skynet", "secretkey")
 	assert.Nil(t, err, err)
-	defer response.Body.Close()
-	assert.Equal(t, http.StatusOK, response.StatusCode)
-	err = json.NewDecoder(response.Body).Decode(&Networks)
+	if response.StatusCode == http.StatusOK {
+		err = json.NewDecoder(response.Body).Decode(&nodes)
+		response.Body.Close()
+		assert.Nil(t, err, err)
+		for _, node := range nodes {
+			resp, err := api(t, "", http.MethodDelete, baseURL+"/api/nodes/skynet/"+node.MacAddress, "secretkey")
+			assert.Nil(t, err, err)
+			assert.Equal(t, http.StatusOK, resp.StatusCode)
+		}
+	}
+	response, err = api(t, "", http.MethodGet, baseURL+"/api/networks", "secretkey")
 	assert.Nil(t, err, err)
-	for _, network := range Networks {
-		name := network.NetID
-		_, err := api(t, "", http.MethodDelete, baseURL+"/api/networks/"+name, "secretkey")
+	if response.StatusCode == http.StatusOK {
+		defer response.Body.Close()
+		err = json.NewDecoder(response.Body).Decode(&Networks)
 		assert.Nil(t, err, err)
+		for _, network := range Networks {
+			name := network.NetID
+			_, err := api(t, "", http.MethodDelete, baseURL+"/api/networks/"+name, "secretkey")
+			assert.Nil(t, err, err)
+		}
 	}
 }
 
 func getNetworkNodes(t *testing.T) []models.ReturnNode {
 	var nodes []models.ReturnNode
-	var node models.ReturnNode
-	nodes = append(nodes, node)
+	//var node models.ReturnNode
+	//response, err := api(t, "", http.MethodGet, baseURL+"/api/nodes/skynet", "secretkey")
+	//assert.Nil(t, err, err)
+	//assert.Equal(t, http.StatusOK, response.StatusCode)
+	//defer response.Body.Close()
+	//err = json.NewDecoder(response.Body).Decode(&nodes)
+	//assert.Nil(t, err, err)
+	//for _, nodes := range nodes {
+	//	nodes = append(nodes, node)
+	//}
 	return nodes
 }
 
 func deleteNode(t *testing.T, node models.ReturnNode) {
+	response, err := api(t, "", http.MethodDelete, baseURL+"/api/nodes/skynet/"+node.MacAddress, "secretkey")
+	assert.Nil(t, err, err)
+	assert.Equal(t, http.StatusOK, response.StatusCode)
 }
 
 func createNode(t *testing.T) {
+	var node models.Node
+	key := createAccessKey(t)
+	node.AccessKey = key.Value
+	node.MacAddress = "01:02:03:04:05:06"
+	node.Name = "myNode"
+	node.PublicKey = "DM5qhLAE20PG9BbfBCger+Ac9D2NDOwCtY1rbYDLf34="
+	node.Password = "tobedetermined"
+	node.LocalAddress = "192.168.0.1"
+	node.Endpoint = "10.100.100.4"
+	response, err := api(t, node, http.MethodPost, "http://localhost:8081:/api/nodes/skynet", "secretkey")
+	assert.Nil(t, err, err)
+	assert.Equal(t, http.StatusOK, response.StatusCode)
+}
+
+func getNode(t *testing.T) models.Node {
+	response, err := api(t, "", http.MethodGet, baseURL+"/api/nodes/skynet/01:02:03:04:05:06", "secretkey")
+	assert.Nil(t, err, err)
+	assert.Equal(t, http.StatusOK, response.StatusCode)
+	var node models.Node
+	defer response.Body.Close()
+	err = json.NewDecoder(response.Body).Decode(&node)
+	assert.Nil(t, err, err)
+	return node
 }

+ 25 - 38
test/node_test.go

@@ -2,7 +2,6 @@ package main
 
 import (
 	"encoding/json"
-	"io/ioutil"
 	"net/http"
 	"testing"
 
@@ -10,8 +9,18 @@ import (
 	"github.com/stretchr/testify/assert"
 )
 
+func setup(t *testing.T) {
+	deleteNetworks(t)
+	createNetwork(t)
+	createNode(t)
+}
+
+func TestJunk(t *testing.T) {
+	deleteNetworks(t)
+}
+
 func TestGetAllNodes(t *testing.T) {
-	//ensure nodes exist
+	setup(t)
 	response, err := api(t, "", http.MethodGet, baseURL+"/api/nodes", "secretkey")
 	assert.Nil(t, err, err)
 	assert.Equal(t, http.StatusOK, response.StatusCode)
@@ -25,6 +34,7 @@ func TestGetAllNodes(t *testing.T) {
 }
 
 func TestGetNetworkNodes(t *testing.T) {
+	setup(t)
 	response, err := api(t, "", http.MethodGet, baseURL+"/api/nodes/skynet", "secretkey")
 	assert.Nil(t, err, err)
 	assert.Equal(t, http.StatusOK, response.StatusCode)
@@ -38,6 +48,7 @@ func TestGetNetworkNodes(t *testing.T) {
 }
 
 func TestGetNode(t *testing.T) {
+	setup(t)
 	response, err := api(t, "", http.MethodGet, baseURL+"/api/nodes/skynet/01:02:03:04:05:06", "secretkey")
 	assert.Nil(t, err, err)
 	assert.Equal(t, http.StatusOK, response.StatusCode)
@@ -49,6 +60,7 @@ func TestGetNode(t *testing.T) {
 }
 
 func TestUpdateNode(t *testing.T) {
+	setup(t)
 	var data struct {
 		Name string
 	}
@@ -64,6 +76,7 @@ func TestUpdateNode(t *testing.T) {
 }
 
 func TestDeleteNode(t *testing.T) {
+	setup(t)
 	t.Run("ExistingNode", func(t *testing.T) {
 		response, err := api(t, "", http.MethodDelete, baseURL+"/api/nodes/skynet/01:02:03:04:05:06", "secretkey")
 		assert.Nil(t, err, err)
@@ -92,6 +105,7 @@ func TestDeleteNode(t *testing.T) {
 func TestCheckIn(t *testing.T) {
 	//get node
 	//oldNode := getNode(t)
+	setup(t)
 	response, err := api(t, "", http.MethodPost, baseURL+"/api/nodes/skynet/01:02:03:04:05:06/checkin", "secretkey")
 	assert.Nil(t, err, err)
 	assert.Equal(t, http.StatusOK, response.StatusCode)
@@ -103,6 +117,7 @@ func TestCheckIn(t *testing.T) {
 }
 
 func TestCreateGateway(t *testing.T) {
+	setup(t)
 	//assert.False(t, node.IsGateway)
 	var gateway models.GatewayRequest
 	gateway.RangeString = "0.0.0.0/0"
@@ -118,6 +133,7 @@ func TestCreateGateway(t *testing.T) {
 }
 
 func TestDeleteGateway(t *testing.T) {
+	setup(t)
 	response, err := api(t, "", http.MethodDelete, baseURL+"/api/nodes/skynet/01:02:03:04:05:06/deletegateway", "secretkey")
 	assert.Nil(t, err, err)
 	assert.Equal(t, http.StatusOK, response.StatusCode)
@@ -129,6 +145,7 @@ func TestDeleteGateway(t *testing.T) {
 }
 
 func TestUncordonNode(t *testing.T) {
+	setup(t)
 	response, err := api(t, "", http.MethodPost, baseURL+"/api/nodes/skynet/01:02:03:04:05:06/approve", "secretkey")
 	assert.Nil(t, err, err)
 	assert.Equal(t, http.StatusOK, response.StatusCode)
@@ -141,11 +158,6 @@ func TestUncordonNode(t *testing.T) {
 }
 
 func TestCreateNode(t *testing.T) {
-	//setup environment
-	nodes := getNetworkNodes(t)
-	for _, node := range nodes {
-		deleteNode(t, node)
-	}
 	deleteNetworks(t)
 	createNetwork(t)
 	key := createAccessKey(t)
@@ -163,13 +175,10 @@ func TestCreateNode(t *testing.T) {
 	assert.Nil(t, err, err)
 	assert.Equal(t, http.StatusOK, response.StatusCode)
 	defer response.Body.Close()
-	//message, err := ioutil.ReadAll(response.Body)
-	//assert.Nil(t, err, err)
 	var message models.Node
 	err = json.NewDecoder(response.Body).Decode(&message)
 	assert.Nil(t, err, err)
 	assert.Equal(t, node.Name, message.Name)
-	//nodePassword = message.Password
 	t.Log(message.Password)
 }
 
@@ -181,39 +190,17 @@ func TestGetLastModified(t *testing.T) {
 }
 
 func TestNodeAuthenticate(t *testing.T) {
-	//setup
-	//deleteA
-	deleteNetworks(t)
-	createNetwork(t)
-	//password := createNode(t)
+	setup(t)
 	var authRequest models.AuthParams
 	authRequest.MacAddress = "01:02:03:04:05:06"
-	//authRequest.MacAddress = "mastermac"
-	//authRequest.Password = nodePassword
-	authRequest.Password = "secretkey"
+	authRequest.Password = "tobedetermined"
 	response, err := api(t, authRequest, http.MethodPost, "http://localhost:8081:/api/nodes/adm/skynet/authenticate", "")
 	assert.Nil(t, err, err)
 	assert.Equal(t, http.StatusOK, response.StatusCode)
 	defer response.Body.Close()
-	message, err := ioutil.ReadAll(response.Body)
-	assert.Nil(t, err, err)
-	//var message string
-	//json.NewDecoder(response.Body).Decode(&message)
-	t.Log(string(message))
-
-}
-
-func TestNodeAuthorize(t *testing.T) {
-	//testing
-	var authRequest models.AuthParams
-	//authRequest.MacAddress = "01:02:03:04:05:06"
-	authRequest.MacAddress = "mastermac"
-	authRequest.Password = "to be determined"
-	response, err := api(t, authRequest, http.MethodPost, "http://localhost:8081:/api/nodes/adm/skynet/authenticate", "")
+	var message models.SuccessResponse
+	err = json.NewDecoder(response.Body).Decode(&message)
 	assert.Nil(t, err, err)
-	assert.Equal(t, http.StatusOK, response.StatusCode)
-	defer response.Body.Close()
-	var message string
-	json.NewDecoder(response.Body).Decode(&message)
-	t.Log(message)
+	assert.Equal(t, http.StatusOK, message.Code)
+	assert.Equal(t, "W1R3: Device 01:02:03:04:05:06 Authorized", message.Message)
 }