package host import ( "net/http" "strconv" "testing" "dev.sum7.eu/sum7/warehost/system" "dev.sum7.eu/sum7/warehost/test" ) func TestAPIDomain(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 domainList */ session.Clean() result, w = session.JSONRequest("GET", "/host/domain", nil) assertion.Equal(w.StatusCode, http.StatusUnauthorized) assertion.Equal(result.Data, false) loginTest(session, assertion) result, w = session.JSONRequest("GET", "/host/domain", nil) assertion.Equal(w.StatusCode, http.StatusOK) assertion.NotEqual(result.Data, false) result, w = session.JSONRequest("GET", "/host/domain?filter=all", nil) assertion.Equal(w.StatusCode, http.StatusOK) assertion.NotEqual(result.Data, false) /* * TEST domainAdd */ session.Clean() result, w = session.JSONRequest("POST", "/host/domain", Domain{ FQDN: "example.de", }) assertion.Equal(w.StatusCode, http.StatusUnauthorized) assertion.Equal(result.Data, false) loginTest(session, assertion) result, w = session.JSONRequest("POST", "/host/domain", []byte{2, 3}) assertion.Equal(w.StatusCode, http.StatusBadRequest) assertion.Equal(result.Data, false) result, w = session.JSONRequest("POST", "/host/domain", Domain{ FQDN: "example.de", }) assertion.Equal(w.StatusCode, http.StatusOK) assertion.NotEqual(result.Data, false) result, w = session.JSONRequest("POST", "/host/domain", Domain{ FQDN: "example.de", }) assertion.Equal(w.StatusCode, http.StatusOK) assertion.Equal(result.Data, false) /* * TEST domainEdit */ result, w = session.JSONRequest("GET", "/host/domain", nil) assertion.Equal(w.StatusCode, http.StatusOK) assertion.NotEqual(result.Data, false) var domain int for _, obj := range result.Data.([]interface{}) { item := obj.(map[string]interface{}) if item["fqdn"] == "example.de" { domain = int(item["ID"].(float64)) break } } session.Clean() result, w = session.JSONRequest("PATCH", "/host/domain/"+strconv.Itoa(domain), Domain{ Mail: true, }) assertion.Equal(w.StatusCode, http.StatusUnauthorized) assertion.Equal(result.Data, false) loginTest(session, assertion) result, w = session.JSONRequest("PATCH", "/host/domain/"+strconv.Itoa(domain), Domain{ Mail: true, }) assertion.Equal(w.StatusCode, http.StatusOK) assertion.Equal(result.Data, true) result, w = session.JSONRequest("PATCH", "/host/domain/"+strconv.Itoa(domain), []byte{2, 3}) assertion.Equal(w.StatusCode, http.StatusBadRequest) assertion.Equal(result.Data, false) /* * TEST domainDelete */ session.Clean() result, w = session.JSONRequest("DELETE", "/host/domain/"+strconv.Itoa(domain), nil) assertion.Equal(w.StatusCode, http.StatusUnauthorized) assertion.Equal(result.Data, false) loginTest(session, assertion) result, w = session.JSONRequest("DELETE", "/host/domain/"+strconv.Itoa(domain), nil) assertion.Equal(w.StatusCode, http.StatusOK) assertion.Equal(result.Data, true) result, w = session.JSONRequest("DELETE", "/host/domain/"+strconv.Itoa(domain), nil) assertion.Equal(w.StatusCode, http.StatusOK) assertion.Equal(result.Data, false) }