Add go backend
This commit is contained in:
72
api/test/models/db_test.go
Normal file
72
api/test/models/db_test.go
Normal 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{})
|
||||
}
|
||||
76
api/test/models/user_test.go
Normal file
76
api/test/models/user_test.go
Normal 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)
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user