Add go backend

This commit is contained in:
2022-12-18 13:42:21 +13:00
parent 5719891df8
commit 99f88d6adf
15 changed files with 1179 additions and 0 deletions

View File

@@ -0,0 +1,72 @@
package models_test
import (
"magmise/models"
"testing"
)
type Test struct {
Name string
}
func TestDB(t *testing.T) {
// Create table
models.DB().AutoMigrate(&models.User{})
user := models.User{Username: "test"}
//Create
if err := models.Create(&user); err != nil {
t.Fatal(err)
}
t.Log("\033[33mShould error with unique contraint\033[0m")
if err := models.Create(&user); err == nil {
t.Fatal(err)
}
// Read
if err := models.Read(&user); err != nil {
t.Fatal(err)
}
// Create more rows
user = models.User{Username: "test2"}
models.Create(&user)
user = models.User{Username: "test3"}
models.Create(&user)
user = models.User{Username: "test4"}
models.Create(&user)
// Get second and third row
var users []models.User
if err := models.ReadAll(&users, 1, 2); err != nil {
t.Fatal(err)
}
if users[0].Username != "test2" {
t.Fatal("Offset failed\n", users)
}
if len(users) != 2 {
t.Fatal("Limit failed\n", users)
}
// Update
user.Password = "b"
if err := models.Update(&user, "username", user.Username); err != nil {
t.Fatal(err)
}
// Check Update
if err := models.Read(&user); err != nil {
t.Fatal(err)
}
if user.Password != "b" {
t.Fatal("failed update")
}
// Delete
if err := models.Delete(&user); err != nil {
t.Fatal(err)
}
models.DB().Migrator().DropTable(&models.User{})
}

View File

@@ -0,0 +1,76 @@
package models_test
import (
"magmise/models"
"magmise/test"
"testing"
)
func TestUserCreate(t *testing.T) {
cleanup := test.Setup(t, "user create")
defer cleanup()
user := models.User{Username: "Bob", Password: "a"}
if user.Create() != nil {
t.Fail()
}
}
func TestUserRead(t *testing.T) {
cleanup := test.Setup(t, "user read")
defer cleanup()
user := models.User{Username: "fred"}
if user.Read() != nil {
t.Fatal("Faied to read application user")
}
if user.Password != "a" {
t.Log(user)
}
}
func TestUserReadAll(t *testing.T) {
cleanup := test.Setup(t, "user readall")
defer cleanup()
user := models.User{}
users, err := user.ReadAll(0, 10)
if err != nil {
t.Fatal(err)
}
if users[0].Username != "fred" {
t.Log(users)
t.Fail()
}
}
func TestUserUpdate(t *testing.T) {
cleanup := test.Setup(t, "user update")
defer cleanup()
user := models.User{Username: "fred"}
user.Read()
user.Password = "b"
if user.Update() != nil {
t.Fail()
}
user.Read()
if user.Password != "b" {
t.Fail()
}
}
func TestUserDelete(t *testing.T) {
cleanup := test.Setup(t, "user delete")
defer cleanup()
user := models.User{Username: "fred"}
if err := user.Delete(); err != nil {
t.Fatal(err)
}
t.Log()
t.Log("\033[33m\033[1mShould error with \033[95mrecord not found\033[0m")
if user.Read() == nil {
t.Fatal(user)
}
}