package host import ( "net/http" "strconv" "testing" "dev.sum7.eu/sum7/warehost/system" "dev.sum7.eu/sum7/warehost/test" ) func TestAPIDatabase(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(http.StatusOK, w.StatusCode) // Need a Profile for Next tests result, w = session.JSONRequest("POST", "/host/signup", nil) assertion.Equal(http.StatusOK, w.StatusCode) assertion.Equal(true, result.Data) /* * TEST databaseList */ session.Clean() result, w = session.JSONRequest("GET", "/host/database", nil) assertion.Equal(http.StatusUnauthorized, w.StatusCode) assertion.Equal(false, result.Data) loginTest(session, assertion) result, w = session.JSONRequest("GET", "/host/database", nil) assertion.Equal(http.StatusOK, w.StatusCode) assertion.NotEqual(false, result.Data) result, w = session.JSONRequest("GET", "/host/database?filter=all", nil) assertion.Equal(http.StatusOK, w.StatusCode) assertion.NotEqual(false, result.Data) /* * TEST databaseAdd */ result, w = session.JSONRequest("POST", "/host/database", Database{ Password: "example.de", Comment: "test", }) assertion.Equal(http.StatusOK, w.StatusCode) assertion.NotEqual(false, result.Data) /* * TEST databaseEdit */ result, w = session.JSONRequest("GET", "/host/database", nil) assertion.Equal(http.StatusOK, w.StatusCode) assertion.NotEqual(false, result.Data) var database int for _, obj := range result.Data.([]interface{}) { item := obj.(map[string]interface{}) if item["password"] == "example.de" { database = int(item["ID"].(float64)) break } } session.Clean() result, w = session.JSONRequest("PATCH", "/host/database/"+strconv.Itoa(database), Database{ Comment: "test-bug", }) assertion.Equal(http.StatusUnauthorized, w.StatusCode) assertion.Equal(false, result.Data) loginTest(session, assertion) result, w = session.JSONRequest("PATCH", "/host/database/"+strconv.Itoa(database), Database{ Comment: "test2", }) assertion.Equal(http.StatusOK, w.StatusCode) assertion.Equal(true, result.Data) result, w = session.JSONRequest("PATCH", "/host/database/"+strconv.Itoa(-1), Database{ Comment: "test-bug", }) assertion.Equal(http.StatusNotFound, w.StatusCode) assertion.Equal(false, result.Data) result, w = session.JSONRequest("PATCH", "/host/database/"+strconv.Itoa(database), []byte{2, 3}) assertion.Equal(http.StatusBadRequest, w.StatusCode) assertion.Equal(false, result.Data) /* * TEST databaseDelete */ session.Clean() result, w = session.JSONRequest("DELETE", "/host/database/"+strconv.Itoa(database), nil) assertion.Equal(http.StatusUnauthorized, w.StatusCode) assertion.Equal(false, result.Data) loginTest(session, assertion) result, w = session.JSONRequest("DELETE", "/host/database/"+strconv.Itoa(database), nil) assertion.Equal(http.StatusOK, w.StatusCode) assertion.Equal(true, result.Data) result, w = session.JSONRequest("DELETE", "/host/database/"+strconv.Itoa(database), nil) assertion.Equal(http.StatusNotFound, w.StatusCode) assertion.Equal(false, result.Data) }