mirror of
https://github.com/gravitl/netmaker.git
synced 2024-09-20 15:26:04 +08:00
cleanup
This commit is contained in:
parent
21e66a1e88
commit
f28937c1f6
|
@ -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
|
||||
}
|
||||
|
|
|
@ -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)
|
||||
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 {
|
||||
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)
|
||||
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
|
||||
}
|
||||
|
|
|
@ -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)
|
||||
var message models.SuccessResponse
|
||||
err = json.NewDecoder(response.Body).Decode(&message)
|
||||
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", "")
|
||||
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)
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue