forked from jinzhu/gorm
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
9 changed files
with
2,109 additions
and
2,114 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
package gorm_test | ||
|
||
import ( | ||
"reflect" | ||
"testing" | ||
"time" | ||
) | ||
|
||
func TestCreate(t *testing.T) { | ||
user := User{Name: "1", Age: 18, Birthday: time.Now(), UserNum: Num(111), PasswordHash: []byte{'f', 'a', 'k', '4'}} | ||
|
||
if !db.NewRecord(user) || !db.NewRecord(&user) { | ||
t.Error("User should be new record before create") | ||
} | ||
|
||
if count := db.Save(&user).RowsAffected; count != 1 { | ||
t.Error("There should be one record be affected when create record") | ||
} | ||
|
||
if db.NewRecord(user) || db.NewRecord(&user) { | ||
t.Error("User should not new record after save") | ||
} | ||
|
||
var newUser User | ||
db.First(&newUser, user.Id) | ||
|
||
if !reflect.DeepEqual(newUser.PasswordHash, []byte{'f', 'a', 'k', '4'}) { | ||
t.Errorf("User's PasswordHash should be saved ([]byte)") | ||
} | ||
|
||
if newUser.Age != 18 { | ||
t.Errorf("User's Age should be saved (int)") | ||
} | ||
|
||
if newUser.UserNum != Num(111) { | ||
t.Errorf("User's UserNum should be saved (custom type)") | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
package gorm_test | ||
|
||
import ( | ||
"testing" | ||
"time" | ||
) | ||
|
||
func TestDelete(t *testing.T) { | ||
user1, user2 := User{Name: "delete1"}, User{Name: "delete2"} | ||
db.Save(&user1) | ||
db.Save(&user2) | ||
|
||
if db.Delete(&user1).Error != nil { | ||
t.Errorf("No error should happen when delete a record") | ||
} | ||
|
||
if !db.Where("name = ?", user1.Name).First(&User{}).RecordNotFound() { | ||
t.Errorf("User can't be found after delete") | ||
} | ||
|
||
if db.Where("name = ?", user2.Name).First(&User{}).RecordNotFound() { | ||
t.Errorf("Other users that not deleted should be found-able") | ||
} | ||
} | ||
|
||
func TestInlineDelete(t *testing.T) { | ||
user1, user2 := User{Name: "inline_delete1"}, User{Name: "inline_delete2"} | ||
db.Save(&user1) | ||
db.Save(&user2) | ||
|
||
if db.Delete(&User{}, user1.Id).Error != nil { | ||
t.Errorf("No error should happen when delete a record") | ||
} else if !db.Where("name = ?", user1.Name).First(&User{}).RecordNotFound() { | ||
t.Errorf("User can't be found after delete") | ||
} | ||
|
||
if db.Delete(&User{}, "name = ?", user2.Name).Error != nil { | ||
t.Errorf("No error should happen when delete a record") | ||
} else if !db.Where("name = ?", user2.Name).First(&User{}).RecordNotFound() { | ||
t.Errorf("User can't be found after delete") | ||
} | ||
} | ||
|
||
func TestSoftDelete(t *testing.T) { | ||
type User struct { | ||
Id int64 | ||
Name string | ||
DeletedAt time.Time | ||
} | ||
db.AutoMigrate(&User{}) | ||
|
||
user := User{Name: "soft_delete"} | ||
db.Save(&user) | ||
db.Delete(&user) | ||
|
||
if db.First(&User{}, "name = ?", user.Name).Error == nil { | ||
t.Errorf("Can't find a soft deleted record") | ||
} | ||
|
||
if db.Unscoped().First(&User{}, "name = ?", user.Name).Error != nil { | ||
t.Errorf("Should be able to find soft deleted record with Unscoped") | ||
} | ||
|
||
db.Unscoped().Delete(&user) | ||
if !db.Unscoped().First(&User{}, "name = ?", user.Name).RecordNotFound() { | ||
t.Errorf("Can't find permanently deleted record") | ||
} | ||
} |
Oops, something went wrong.