123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620 |
- package main
- import (
- "encoding/json"
- "io/ioutil"
- "net/http"
- "testing"
- "github.com/gravitl/netmaker/models"
- "github.com/stretchr/testify/assert"
- "go.mongodb.org/mongo-driver/mongo"
- )
- var Groups []models.Group
- func TestCreateGroup(t *testing.T) {
- group := models.Group{}
- group.NameID = "skynet"
- group.AddressRange = "10.71.0.0/16"
- t.Run("CreateGroup", func(t *testing.T) {
- response, err := api(t, group, http.MethodPost, "http://localhost:8081/api/groups", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- })
- t.Run("InvalidToken", func(t *testing.T) {
- response, err := api(t, group, http.MethodPost, "http://localhost:8081/api/groups", "badkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnauthorized, response.StatusCode)
- defer response.Body.Close()
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnauthorized, message.Code)
- assert.Equal(t, "W1R3: You are unauthorized to access this endpoint.", message.Message)
- })
- t.Run("BadName", func(t *testing.T) {
- //issue #42
- t.Skip()
- })
- t.Run("BadAddress", func(t *testing.T) {
- //issue #42
- t.Skip()
- })
- t.Run("DuplicateGroup", func(t *testing.T) {
- //issue #42
- t.Skip()
- })
- }
- func TestGetGroups(t *testing.T) {
- t.Run("ValidToken", func(t *testing.T) {
- response, err := api(t, "", http.MethodGet, "http://localhost:8081/api/groups", "secretkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- assert.Equal(t, http.StatusOK, response.StatusCode)
- err = json.NewDecoder(response.Body).Decode(&Groups)
- assert.Nil(t, err, err)
- })
- t.Run("InvalidToken", func(t *testing.T) {
- response, err := api(t, "", http.MethodGet, "http://localhost:8081/api/groups", "badkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnauthorized, response.StatusCode)
- assert.Equal(t, http.StatusUnauthorized, message.Code)
- assert.Equal(t, "W1R3: You are unauthorized to access this endpoint.", message.Message)
- })
- }
- func TestGetGroup(t *testing.T) {
- t.Run("ValidToken", func(t *testing.T) {
- var group models.Group
- response, err := api(t, "", http.MethodGet, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- assert.Equal(t, http.StatusOK, response.StatusCode)
- err = json.NewDecoder(response.Body).Decode(&group)
- assert.Nil(t, err, err)
- assert.Equal(t, "skynet", group.DisplayName)
- })
- t.Run("InvalidToken", func(t *testing.T) {
- response, err := api(t, "", http.MethodGet, "http://localhost:8081/api/groups/skynet", "badkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnauthorized, response.StatusCode)
- assert.Equal(t, http.StatusUnauthorized, message.Code)
- assert.Equal(t, "W1R3: You are unauthorized to access this endpoint.", message.Message)
- })
- t.Run("InvalidGroup", func(t *testing.T) {
- response, err := api(t, "", http.MethodGet, "http://localhost:8081/api/groups/badgroup", "secretkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, "W1R3: This group does not exist.", message.Message)
- assert.Equal(t, http.StatusNotFound, response.StatusCode)
- })
- }
- func TestGetGroupNodeNumber(t *testing.T) {
- t.Run("ValidKey", func(t *testing.T) {
- response, err := api(t, "", http.MethodGet, "http://localhost:8081/api/groups/skynet/numnodes", "secretkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- var message int
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- //assert.Equal(t, "W1R3: This group does not exist.", message.Message)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- })
- t.Run("InvalidKey", func(t *testing.T) {
- response, err := api(t, "", http.MethodGet, "http://localhost:8081/api/groups/skynet/numnodes", "badkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnauthorized, response.StatusCode)
- assert.Equal(t, http.StatusUnauthorized, message.Code)
- assert.Equal(t, "W1R3: You are unauthorized to access this endpoint.", message.Message)
- })
- t.Run("BadGroup", func(t *testing.T) {
- response, err := api(t, "", http.MethodGet, "http://localhost:8081/api/groups/badgroup/numnodes", "secretkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, "W1R3: This group does not exist.", message.Message)
- assert.Equal(t, http.StatusNotFound, response.StatusCode)
- })
- }
- func TestDeleteGroup(t *testing.T) {
- t.Run("InvalidKey", func(t *testing.T) {
- response, err := api(t, "", http.MethodDelete, "http://localhost:8081/api/groups/skynet", "badkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnauthorized, response.StatusCode)
- assert.Equal(t, http.StatusUnauthorized, message.Code)
- assert.Equal(t, "W1R3: You are unauthorized to access this endpoint.", message.Message)
- })
- t.Run("ValidKey", func(t *testing.T) {
- response, err := api(t, "", http.MethodDelete, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- var message mongo.DeleteResult
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- assert.Equal(t, int64(1), message.DeletedCount)
- })
- t.Run("BadGroup", func(t *testing.T) {
- response, err := api(t, "", http.MethodDelete, "http://localhost:8081/api/groups/badgroup", "secretkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, "W1R3: This group does not exist.", message.Message)
- assert.Equal(t, http.StatusNotFound, response.StatusCode)
- })
- t.Run("NodesExist", func(t *testing.T) {
- t.Skip()
- })
- //Create Group for follow-on tests
- createGroup(t)
- }
- func TestCreateAccessKey(t *testing.T) {
- key := models.AccessKey{}
- key.Name = "skynet"
- key.Uses = 10
- t.Run("MultiUse", func(t *testing.T) {
- response, err := api(t, key, http.MethodPost, "http://localhost:8081/api/groups/skynet/keys", "secretkey")
- 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)
- assert.NotNil(t, message, message)
- returnedkey := getKey(t, key.Name)
- assert.Equal(t, key.Name, returnedkey.Name)
- assert.Equal(t, key.Uses, returnedkey.Uses)
- })
- deleteKey(t, "skynet", "skynet")
- t.Run("ZeroUse", func(t *testing.T) {
- //t.Skip()
- key.Uses = 0
- response, err := api(t, key, http.MethodPost, "http://localhost:8081/api/groups/skynet/keys", "secretkey")
- 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)
- assert.NotNil(t, message, message)
- returnedkey := getKey(t, key.Name)
- assert.Equal(t, key.Name, returnedkey.Name)
- assert.Equal(t, 1, returnedkey.Uses)
- })
- t.Run("DuplicateAccessKey", func(t *testing.T) {
- //t.Skip()
- //this will fail
- response, err := api(t, key, http.MethodPost, "http://localhost:8081/api/groups/skynet/keys", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnprocessableEntity, response.StatusCode)
- deleteKey(t, key.Name, "skynet")
- })
- t.Run("InvalidToken", func(t *testing.T) {
- response, err := api(t, key, http.MethodPost, "http://localhost:8081/api/groups/skynet/keys", "badkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnauthorized, response.StatusCode)
- defer response.Body.Close()
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnauthorized, message.Code)
- assert.Equal(t, "W1R3: You are unauthorized to access this endpoint.", message.Message)
- })
- t.Run("BadGroup", func(t *testing.T) {
- response, err := api(t, key, http.MethodPost, "http://localhost:8081/api/groups/badgroup/keys", "secretkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, "W1R3: This group does not exist.", message.Message)
- assert.Equal(t, http.StatusNotFound, response.StatusCode)
- })
- }
- func TestDeleteKey(t *testing.T) {
- t.Run("KeyValid", func(t *testing.T) {
- //fails -- deletecount not returned
- response, err := api(t, "", http.MethodDelete, "http://localhost:8081/api/groups/skynet/keys/skynet", "secretkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- var message mongo.DeleteResult
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- assert.Equal(t, int64(1), message.DeletedCount)
- })
- t.Run("InValidKey", func(t *testing.T) {
- //fails -- status message not returned
- response, err := api(t, "", http.MethodDelete, "http://localhost:8081/api/groups/skynet/keys/badkey", "secretkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, "W1R3: This key does not exist.", message.Message)
- assert.Equal(t, http.StatusNotFound, response.StatusCode)
- })
- t.Run("KeyInValidGroup", func(t *testing.T) {
- response, err := api(t, "", http.MethodDelete, "http://localhost:8081/api/groups/badgroup/keys/skynet", "secretkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, "W1R3: This group does not exist.", message.Message)
- assert.Equal(t, http.StatusNotFound, response.StatusCode)
- })
- t.Run("InvalidCredentials", func(t *testing.T) {
- response, err := api(t, "", http.MethodDelete, "http://localhost:8081/api/groups/skynet/keys/skynet", "badkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnauthorized, response.StatusCode)
- defer response.Body.Close()
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnauthorized, message.Code)
- assert.Equal(t, "W1R3: You are unauthorized to access this endpoint.", message.Message)
- })
- }
- func TestGetKeys(t *testing.T) {
- createKey(t)
- t.Run("Valid", func(t *testing.T) {
- response, err := api(t, "", http.MethodGet, "http://localhost:8081/api/groups/skynet/keys", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- defer response.Body.Close()
- var keys []models.AccessKey
- err = json.NewDecoder(response.Body).Decode(&keys)
- assert.Nil(t, err, err)
- })
- //deletekeys
- t.Run("InvalidGroup", func(t *testing.T) {
- response, err := api(t, "", http.MethodGet, "http://localhost:8081/api/groups/badgroup/keys", "secretkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, "W1R3: This group does not exist.", message.Message)
- assert.Equal(t, http.StatusNotFound, response.StatusCode)
- })
- t.Run("InvalidCredentials", func(t *testing.T) {
- response, err := api(t, "", http.MethodGet, "http://localhost:8081/api/groups/skynet/keys", "badkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnauthorized, response.StatusCode)
- defer response.Body.Close()
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnauthorized, message.Code)
- assert.Equal(t, "W1R3: You are unauthorized to access this endpoint.", message.Message)
- })
- }
- func TestUpdateGroup(t *testing.T) {
- var returnedGroup models.Group
- t.Run("UpdateNameID", func(t *testing.T) {
- type Group struct {
- NameID string
- }
- var group Group
- group.NameID = "wirecat"
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- defer response.Body.Close()
- err = json.NewDecoder(response.Body).Decode(&returnedGroup)
- assert.Nil(t, err, err)
- assert.Equal(t, group.NameID, returnedGroup.NameID)
- })
- t.Run("NameIDInvalidCredentials", func(t *testing.T) {
- type Group struct {
- NameID string
- }
- var group Group
- group.NameID = "wirecat"
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "badkey")
- assert.Nil(t, err, err)
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnauthorized, message.Code)
- assert.Equal(t, "W1R3: You are unauthorized to access this endpoint.", message.Message)
- assert.Equal(t, http.StatusUnauthorized, response.StatusCode)
- })
- t.Run("InvalidGroup", func(t *testing.T) {
- type Group struct {
- NameID string
- }
- var group Group
- group.NameID = "wirecat"
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/badgroup", "secretkey")
- assert.Nil(t, err, err)
- defer response.Body.Close()
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusNotFound, message.Code)
- assert.Equal(t, "W1R3: This group does not exist.", message.Message)
- assert.Equal(t, http.StatusNotFound, response.StatusCode)
- })
- t.Run("UpdateNameIDTooLong", func(t *testing.T) {
- type Group struct {
- NameID string
- }
- var group Group
- group.NameID = "wirecat-skynet"
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnprocessableEntity, response.StatusCode)
- })
- t.Run("UpdateAddress", func(t *testing.T) {
- type Group struct {
- AddressRange string
- }
- var group Group
- group.AddressRange = "10.0.0.1/24"
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- defer response.Body.Close()
- err = json.NewDecoder(response.Body).Decode(&returnedGroup)
- assert.Nil(t, err, err)
- assert.Equal(t, group.AddressRange, returnedGroup.AddressRange)
- })
- t.Run("UpdateAddressInvalid", func(t *testing.T) {
- type Group struct {
- AddressRange string
- }
- var group Group
- group.AddressRange = "10.0.0.1/36"
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnprocessableEntity, response.StatusCode)
- })
- t.Run("UpdateDisplayName", func(t *testing.T) {
- type Group struct {
- DisplayName string
- }
- var group Group
- group.DisplayName = "wirecat"
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- defer response.Body.Close()
- err = json.NewDecoder(response.Body).Decode(&returnedGroup)
- assert.Nil(t, err, err)
- assert.Equal(t, group.DisplayName, returnedGroup.DisplayName)
- })
- t.Run("UpdateDisplayNameInvalidName", func(t *testing.T) {
- type Group struct {
- DisplayName string
- }
- var group Group
- //create name that is longer than 100 chars
- name := ""
- for i := 0; i < 101; i++ {
- name = name + "a"
- }
- group.DisplayName = name
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnprocessableEntity, message.Code)
- assert.Equal(t, "W1R3: Field validation for 'DisplayName' failed.", message.Message)
- assert.Equal(t, http.StatusUnprocessableEntity, response.StatusCode)
- })
- t.Run("UpdateInterface", func(t *testing.T) {
- type Group struct {
- DefaultInterface string
- }
- var group Group
- group.DefaultInterface = "netmaker"
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- defer response.Body.Close()
- err = json.NewDecoder(response.Body).Decode(&returnedGroup)
- assert.Nil(t, err, err)
- assert.Equal(t, group.DefaultInterface, returnedGroup.DefaultInterface)
- })
- t.Run("UpdateListenPort", func(t *testing.T) {
- type Group struct {
- DefaultListenPort int32
- }
- var group Group
- group.DefaultListenPort = 6000
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- defer response.Body.Close()
- err = json.NewDecoder(response.Body).Decode(&returnedGroup)
- assert.Nil(t, err, err)
- assert.Equal(t, group.DefaultListenPort, returnedGroup.DefaultListenPort)
- })
- t.Run("UpdateListenPortInvalidPort", func(t *testing.T) {
- type Group struct {
- DefaultListenPort int32
- }
- var group Group
- group.DefaultListenPort = 1023
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnprocessableEntity, message.Code)
- assert.Equal(t, "W1R3: Field validation for 'DefaultListenPort' failed.", message.Message)
- assert.Equal(t, http.StatusUnprocessableEntity, response.StatusCode)
- })
- t.Run("UpdatePostUP", func(t *testing.T) {
- type Group struct {
- DefaultPostUp string
- }
- var group Group
- group.DefaultPostUp = "sudo wg add-conf wc-netmaker /etc/wireguard/peers/conf"
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- defer response.Body.Close()
- err = json.NewDecoder(response.Body).Decode(&returnedGroup)
- assert.Nil(t, err, err)
- assert.Equal(t, group.DefaultPostUp, returnedGroup.DefaultPostUp)
- })
- t.Run("UpdatePreUP", func(t *testing.T) {
- type Group struct {
- DefaultPreUp string
- }
- var group Group
- group.DefaultPreUp = "test string"
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- defer response.Body.Close()
- err = json.NewDecoder(response.Body).Decode(&returnedGroup)
- assert.Nil(t, err, err)
- assert.Equal(t, group.DefaultPreUp, returnedGroup.DefaultPreUp)
- })
- t.Run("UpdateKeepAlive", func(t *testing.T) {
- type Group struct {
- DefaultKeepalive int32
- }
- var group Group
- group.DefaultKeepalive = 60
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- defer response.Body.Close()
- err = json.NewDecoder(response.Body).Decode(&returnedGroup)
- assert.Nil(t, err, err)
- assert.Equal(t, group.DefaultKeepalive, returnedGroup.DefaultKeepalive)
- })
- t.Run("UpdateKeepAliveTooBig", func(t *testing.T) {
- type Group struct {
- DefaultKeepAlive int32
- }
- var group Group
- group.DefaultKeepAlive = 1001
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnprocessableEntity, message.Code)
- assert.Equal(t, "W1R3: Field validation for 'DefaultKeepAlive' failed.", message.Message)
- assert.Equal(t, http.StatusUnprocessableEntity, response.StatusCode)
- })
- t.Run("UpdateSaveConfig", func(t *testing.T) {
- //causes panic
- t.Skip()
- type Group struct {
- DefaultSaveConfig *bool
- }
- var group Group
- value := false
- group.DefaultSaveConfig = &value
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- defer response.Body.Close()
- err = json.NewDecoder(response.Body).Decode(&returnedGroup)
- assert.Nil(t, err, err)
- assert.Equal(t, *group.DefaultSaveConfig, *returnedGroup.DefaultSaveConfig)
- })
- t.Run("UpdateManualSignUP", func(t *testing.T) {
- t.Skip()
- type Group struct {
- AllowManualSignUp *bool
- }
- var group Group
- value := true
- group.AllowManualSignUp = &value
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- defer response.Body.Close()
- err = json.NewDecoder(response.Body).Decode(&returnedGroup)
- assert.Nil(t, err, err)
- assert.Equal(t, *group.AllowManualSignUp, *returnedGroup.AllowManualSignUp)
- })
- t.Run("DefaultCheckInterval", func(t *testing.T) {
- type Group struct {
- DefaultCheckInInterval int32
- }
- var group Group
- group.DefaultCheckInInterval = 6000
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- defer response.Body.Close()
- err = json.NewDecoder(response.Body).Decode(&returnedGroup)
- assert.Nil(t, err, err)
- assert.Equal(t, group.DefaultCheckInInterval, returnedGroup.DefaultCheckInInterval)
- })
- t.Run("DefaultCheckIntervalTooBig", func(t *testing.T) {
- type Group struct {
- DefaultCheckInInterval int32
- }
- var group Group
- group.DefaultCheckInInterval = 100001
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- var message models.ErrorResponse
- err = json.NewDecoder(response.Body).Decode(&message)
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusUnprocessableEntity, message.Code)
- assert.Equal(t, "W1R3: Field validation for 'DefaultCheckInInterval' failed.", message.Message)
- assert.Equal(t, http.StatusUnprocessableEntity, response.StatusCode)
- })
- t.Run("MultipleFields", func(t *testing.T) {
- type Group struct {
- DisplayName string
- DefaultListenPort int32
- }
- var group Group
- group.DefaultListenPort = 7777
- group.DisplayName = "multi"
- response, err := api(t, group, http.MethodPut, "http://localhost:8081/api/groups/skynet", "secretkey")
- assert.Nil(t, err, err)
- assert.Equal(t, http.StatusOK, response.StatusCode)
- defer response.Body.Close()
- err = json.NewDecoder(response.Body).Decode(&returnedGroup)
- assert.Nil(t, err, err)
- assert.Equal(t, group.DisplayName, returnedGroup.DisplayName)
- assert.Equal(t, group.DefaultListenPort, returnedGroup.DefaultListenPort)
- })
- }
|