mirror of
https://github.com/miniflux/v2.git
synced 2025-08-06 17:41:00 +00:00
Improve API
This commit is contained in:
parent
3f473e4a09
commit
d5b8f2fb88
15 changed files with 238 additions and 110 deletions
|
@ -35,42 +35,59 @@ func TestValidateUserCreation(t *testing.T) {
|
|||
|
||||
func TestValidateUserModification(t *testing.T) {
|
||||
user := &User{}
|
||||
if err := user.ValidateUserModification(); err == nil {
|
||||
t.Error(`An empty user should generate an error`)
|
||||
}
|
||||
|
||||
user = &User{ID: 42, Username: "test", Password: "", Theme: "default"}
|
||||
if err := user.ValidateUserModification(); err != nil {
|
||||
t.Error(`User without password should not generate an error`)
|
||||
t.Error(`There is no changes, so we should not have an error`)
|
||||
}
|
||||
|
||||
user = &User{ID: 42, Username: "test", Password: "a", Theme: "default"}
|
||||
if err := user.ValidateUserModification(); err == nil {
|
||||
t.Error(`Passwords shorter than 6 characters should generate an error`)
|
||||
user = &User{Theme: "default"}
|
||||
if err := user.ValidateUserModification(); err != nil {
|
||||
t.Error(`A valid theme should not generate any errors`)
|
||||
}
|
||||
|
||||
user = &User{ID: 42, Username: "", Password: "secret", Theme: "default"}
|
||||
if err := user.ValidateUserModification(); err == nil {
|
||||
t.Error(`An empty username should generate an error`)
|
||||
}
|
||||
|
||||
user = &User{ID: -1, Username: "test", Password: "secret", Theme: "default"}
|
||||
if err := user.ValidateUserModification(); err == nil {
|
||||
t.Error(`An invalid userID should generate an error`)
|
||||
}
|
||||
|
||||
user = &User{ID: 0, Username: "test", Password: "secret", Theme: "default"}
|
||||
if err := user.ValidateUserModification(); err == nil {
|
||||
t.Error(`An invalid userID should generate an error`)
|
||||
}
|
||||
|
||||
user = &User{ID: 42, Username: "test", Password: "secret", Theme: "invalid"}
|
||||
user = &User{Theme: "invalid theme"}
|
||||
if err := user.ValidateUserModification(); err == nil {
|
||||
t.Error(`An invalid theme should generate an error`)
|
||||
}
|
||||
|
||||
user = &User{ID: 42, Username: "test", Password: "secret", Theme: "default"}
|
||||
user = &User{Password: "test123"}
|
||||
if err := user.ValidateUserModification(); err != nil {
|
||||
t.Error(`A valid user should not generate any error`)
|
||||
t.Error(`A valid password should not generate any errors`)
|
||||
}
|
||||
|
||||
user = &User{Password: "a"}
|
||||
if err := user.ValidateUserModification(); err == nil {
|
||||
t.Error(`An invalid password should generate an error`)
|
||||
}
|
||||
}
|
||||
|
||||
func TestMergeUsername(t *testing.T) {
|
||||
user1 := &User{ID: 42, Username: "user1", Password: "secret", Theme: "default"}
|
||||
user2 := &User{ID: 42, Username: "user2"}
|
||||
user1.Merge(user2)
|
||||
|
||||
if user1.Username != "user2" {
|
||||
t.Fatal(`The username should be merged into user1`)
|
||||
}
|
||||
|
||||
if user1.Theme != "default" {
|
||||
t.Fatal(`The theme should not be merged into user1`)
|
||||
}
|
||||
}
|
||||
|
||||
func TestMergeIsAdmin(t *testing.T) {
|
||||
user1 := &User{ID: 42, Username: "user1", Password: "secret", Theme: "default"}
|
||||
user2 := &User{ID: 42, IsAdmin: true}
|
||||
user1.Merge(user2)
|
||||
|
||||
if !user1.IsAdmin {
|
||||
t.Fatal(`The is_admin flag should be merged into user1`)
|
||||
}
|
||||
|
||||
user1 = &User{ID: 42, Username: "user1", Password: "secret", Theme: "default"}
|
||||
user2 = &User{ID: 42}
|
||||
user1.Merge(user2)
|
||||
|
||||
if user1.IsAdmin {
|
||||
t.Fatal(`The is_admin flag should not be merged into user1`)
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue