79 lines
2.0 KiB
Go
79 lines
2.0 KiB
Go
|
package host
|
||
|
|
||
|
import (
|
||
|
"net/http"
|
||
|
"strconv"
|
||
|
"testing"
|
||
|
|
||
|
"dev.sum7.eu/sum7/warehost/system"
|
||
|
"dev.sum7.eu/sum7/warehost/test"
|
||
|
)
|
||
|
|
||
|
func TestAPIProfil(t *testing.T) {
|
||
|
|
||
|
assertion, db, router := test.Init(t)
|
||
|
defer db.Close()
|
||
|
|
||
|
//load system Models to database
|
||
|
system.SyncModels(db)
|
||
|
db.Unscoped().Delete(Profil{})
|
||
|
SyncModels(db)
|
||
|
|
||
|
// Bind API
|
||
|
system.BindAPI(db, router, "")
|
||
|
BindAPI(db, router, "/host")
|
||
|
session := test.NewSession(router)
|
||
|
|
||
|
loginTest(session, assertion)
|
||
|
|
||
|
result, w := session.JSONRequest("DELETE", "/host/delete", nil)
|
||
|
assertion.Equal(w.StatusCode, http.StatusOK)
|
||
|
|
||
|
// Need a Profile for Next tests
|
||
|
result, w = session.JSONRequest("POST", "/host/signup", nil)
|
||
|
assertion.Equal(w.StatusCode, http.StatusOK)
|
||
|
assertion.Equal(result.Data, true)
|
||
|
|
||
|
/*
|
||
|
* TEST profilList
|
||
|
*/
|
||
|
session.Clean()
|
||
|
result, w = session.JSONRequest("GET", "/host/profils", nil)
|
||
|
assertion.Equal(w.StatusCode, http.StatusUnauthorized)
|
||
|
assertion.Equal(result.Data, false)
|
||
|
|
||
|
loginTest(session, assertion)
|
||
|
|
||
|
result, w = session.JSONRequest("GET", "/host/profils", nil)
|
||
|
assertion.Equal(w.StatusCode, http.StatusOK)
|
||
|
assertion.NotEqual(result.Data, false)
|
||
|
|
||
|
/*
|
||
|
* TEST toggleReseller
|
||
|
*/
|
||
|
result, w = session.JSONRequest("GET", "/host/profils", nil)
|
||
|
assertion.Equal(w.StatusCode, http.StatusOK)
|
||
|
assertion.NotEqual(result.Data, false)
|
||
|
var id int
|
||
|
for _, obj := range result.Data.([]interface{}) {
|
||
|
item := obj.(map[string]interface{})
|
||
|
id = int(item["ID"].(float64))
|
||
|
}
|
||
|
|
||
|
session.Clean()
|
||
|
|
||
|
result, w = session.JSONRequest("PATCH", "/host/profil/"+strconv.Itoa(id), nil)
|
||
|
assertion.Equal(w.StatusCode, http.StatusUnauthorized)
|
||
|
assertion.Equal(result.Data, false)
|
||
|
|
||
|
loginTest(session, assertion)
|
||
|
|
||
|
result, w = session.JSONRequest("PATCH", "/host/profil/"+strconv.Itoa(id), nil)
|
||
|
assertion.Equal(w.StatusCode, http.StatusOK)
|
||
|
assertion.Equal(result.Data, true)
|
||
|
|
||
|
result, w = session.JSONRequest("PATCH", "/host/profil/"+strconv.Itoa(id), nil)
|
||
|
assertion.Equal(w.StatusCode, http.StatusOK)
|
||
|
assertion.Equal(result.Data, true)
|
||
|
}
|