access_tokens_test.go 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. // Copyright 2020 The Gogs Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. package db
  5. import (
  6. "testing"
  7. "time"
  8. "github.com/jinzhu/gorm"
  9. "github.com/stretchr/testify/assert"
  10. "gogs.io/gogs/internal/errutil"
  11. )
  12. func Test_accessTokens(t *testing.T) {
  13. if testing.Short() {
  14. t.Skip()
  15. }
  16. t.Parallel()
  17. db := &accessTokens{
  18. DB: initTestDB(t, "accessTokens", new(AccessToken)),
  19. }
  20. for _, tc := range []struct {
  21. name string
  22. test func(*testing.T, *accessTokens)
  23. }{
  24. {"Create", test_accessTokens_Create},
  25. {"DeleteByID", test_accessTokens_DeleteByID},
  26. {"GetBySHA", test_accessTokens_GetBySHA},
  27. {"List", test_accessTokens_List},
  28. {"Save", test_accessTokens_Save},
  29. } {
  30. t.Run(tc.name, func(t *testing.T) {
  31. t.Cleanup(func() {
  32. err := deleteTables(db.DB, new(AccessToken))
  33. if err != nil {
  34. t.Fatal(err)
  35. }
  36. })
  37. tc.test(t, db)
  38. })
  39. }
  40. }
  41. func test_accessTokens_Create(t *testing.T, db *accessTokens) {
  42. // Create first access token with name "Test"
  43. token, err := db.Create(1, "Test")
  44. if err != nil {
  45. t.Fatal(err)
  46. }
  47. assert.Equal(t, int64(1), token.UserID)
  48. assert.Equal(t, "Test", token.Name)
  49. assert.Equal(t, 40, len(token.Sha1), "sha1 length")
  50. // Get it back and check the Created field
  51. token, err = db.GetBySHA(token.Sha1)
  52. if err != nil {
  53. t.Fatal(err)
  54. }
  55. assert.Equal(t, gorm.NowFunc().Format(time.RFC3339), token.Created.Format(time.RFC3339))
  56. // Try create second access token with same name should fail
  57. _, err = db.Create(token.UserID, token.Name)
  58. expErr := ErrAccessTokenAlreadyExist{args: errutil.Args{"userID": token.UserID, "name": token.Name}}
  59. assert.Equal(t, expErr, err)
  60. }
  61. func test_accessTokens_DeleteByID(t *testing.T, db *accessTokens) {
  62. // Create an access token with name "Test"
  63. token, err := db.Create(1, "Test")
  64. if err != nil {
  65. t.Fatal(err)
  66. }
  67. // We should be able to get it back
  68. _, err = db.GetBySHA(token.Sha1)
  69. if err != nil {
  70. t.Fatal(err)
  71. }
  72. // Delete a token with mismatched user ID is noop
  73. err = db.DeleteByID(2, token.ID)
  74. if err != nil {
  75. t.Fatal(err)
  76. }
  77. _, err = db.GetBySHA(token.Sha1)
  78. if err != nil {
  79. t.Fatal(err)
  80. }
  81. // Now delete this token with correct user ID
  82. err = db.DeleteByID(token.UserID, token.ID)
  83. if err != nil {
  84. t.Fatal(err)
  85. }
  86. // We should get token not found error
  87. _, err = db.GetBySHA(token.Sha1)
  88. expErr := ErrAccessTokenNotExist{args: errutil.Args{"sha": token.Sha1}}
  89. assert.Equal(t, expErr, err)
  90. }
  91. func test_accessTokens_GetBySHA(t *testing.T, db *accessTokens) {
  92. // Create an access token with name "Test"
  93. token, err := db.Create(1, "Test")
  94. if err != nil {
  95. t.Fatal(err)
  96. }
  97. // We should be able to get it back
  98. _, err = db.GetBySHA(token.Sha1)
  99. if err != nil {
  100. t.Fatal(err)
  101. }
  102. // Try to get a non-existent token
  103. _, err = db.GetBySHA("bad_sha")
  104. expErr := ErrAccessTokenNotExist{args: errutil.Args{"sha": "bad_sha"}}
  105. assert.Equal(t, expErr, err)
  106. }
  107. func test_accessTokens_List(t *testing.T, db *accessTokens) {
  108. // Create two access tokens for user 1
  109. _, err := db.Create(1, "user1_1")
  110. if err != nil {
  111. t.Fatal(err)
  112. }
  113. _, err = db.Create(1, "user1_2")
  114. if err != nil {
  115. t.Fatal(err)
  116. }
  117. // Create one access token for user 2
  118. _, err = db.Create(2, "user2_1")
  119. if err != nil {
  120. t.Fatal(err)
  121. }
  122. // List all access tokens for user 1
  123. tokens, err := db.List(1)
  124. if err != nil {
  125. t.Fatal(err)
  126. }
  127. assert.Equal(t, 2, len(tokens), "number of tokens")
  128. assert.Equal(t, int64(1), tokens[0].UserID)
  129. assert.Equal(t, "user1_1", tokens[0].Name)
  130. assert.Equal(t, int64(1), tokens[1].UserID)
  131. assert.Equal(t, "user1_2", tokens[1].Name)
  132. }
  133. func test_accessTokens_Save(t *testing.T, db *accessTokens) {
  134. // Create an access token with name "Test"
  135. token, err := db.Create(1, "Test")
  136. if err != nil {
  137. t.Fatal(err)
  138. }
  139. // Updated field is zero now
  140. assert.True(t, token.Updated.IsZero())
  141. err = db.Save(token)
  142. if err != nil {
  143. t.Fatal(err)
  144. }
  145. // Get back from DB should have Updated set
  146. token, err = db.GetBySHA(token.Sha1)
  147. if err != nil {
  148. t.Fatal(err)
  149. }
  150. assert.Equal(t, gorm.NowFunc().Format(time.RFC3339), token.Updated.Format(time.RFC3339))
  151. }