user_test.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. // Copyright 2017 Frédéric Guillot. All rights reserved.
  2. // Use of this source code is governed by the Apache 2.0
  3. // license that can be found in the LICENSE file.
  4. package model
  5. import "testing"
  6. func TestValidateUserCreation(t *testing.T) {
  7. user := &User{}
  8. if err := user.ValidateUserCreation(); err == nil {
  9. t.Error(`An empty user should generate an error`)
  10. }
  11. user = &User{Username: "test", Password: ""}
  12. if err := user.ValidateUserCreation(); err == nil {
  13. t.Error(`User without password should generate an error`)
  14. }
  15. user = &User{Username: "test", Password: "a"}
  16. if err := user.ValidateUserCreation(); err == nil {
  17. t.Error(`Passwords shorter than 6 characters should generate an error`)
  18. }
  19. user = &User{Username: "", Password: "secret"}
  20. if err := user.ValidateUserCreation(); err == nil {
  21. t.Error(`An empty username should generate an error`)
  22. }
  23. user = &User{Username: "test", Password: "secret"}
  24. if err := user.ValidateUserCreation(); err != nil {
  25. t.Error(`A valid user should not generate any error`)
  26. }
  27. }
  28. func TestValidateUserModification(t *testing.T) {
  29. user := &User{}
  30. if err := user.ValidateUserModification(); err != nil {
  31. t.Error(`There is no changes, so we should not have an error`)
  32. }
  33. user = &User{Theme: "default"}
  34. if err := user.ValidateUserModification(); err != nil {
  35. t.Error(`A valid theme should not generate any errors`)
  36. }
  37. user = &User{Theme: "invalid theme"}
  38. if err := user.ValidateUserModification(); err == nil {
  39. t.Error(`An invalid theme should generate an error`)
  40. }
  41. user = &User{Password: "test123"}
  42. if err := user.ValidateUserModification(); err != nil {
  43. t.Error(`A valid password should not generate any errors`)
  44. }
  45. user = &User{Password: "a"}
  46. if err := user.ValidateUserModification(); err == nil {
  47. t.Error(`An invalid password should generate an error`)
  48. }
  49. }
  50. func TestMergeUsername(t *testing.T) {
  51. user1 := &User{ID: 42, Username: "user1", Password: "secret", Theme: "default"}
  52. user2 := &User{ID: 42, Username: "user2"}
  53. user1.Merge(user2)
  54. if user1.Username != "user2" {
  55. t.Fatal(`The username should be merged into user1`)
  56. }
  57. if user1.Theme != "default" {
  58. t.Fatal(`The theme should not be merged into user1`)
  59. }
  60. }
  61. func TestMergeIsAdmin(t *testing.T) {
  62. user1 := &User{ID: 42, Username: "user1", Password: "secret", Theme: "default"}
  63. user2 := &User{ID: 42, IsAdmin: true}
  64. user1.Merge(user2)
  65. if !user1.IsAdmin {
  66. t.Fatal(`The is_admin flag should be merged into user1`)
  67. }
  68. user1 = &User{ID: 42, Username: "user1", Password: "secret", Theme: "default"}
  69. user2 = &User{ID: 42}
  70. user1.Merge(user2)
  71. if user1.IsAdmin {
  72. t.Fatal(`The is_admin flag should not be merged into user1`)
  73. }
  74. }