access_tokens_test.go 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201
  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. "fmt"
  7. "os"
  8. "path/filepath"
  9. "testing"
  10. "time"
  11. "github.com/stretchr/testify/assert"
  12. "gogs.io/gogs/internal/conf"
  13. "gogs.io/gogs/internal/errutil"
  14. )
  15. func Test_accessTokens(t *testing.T) {
  16. if testing.Short() {
  17. t.Skip()
  18. }
  19. t.Parallel()
  20. dbpath := filepath.Join(os.TempDir(), fmt.Sprintf("gogs-%d.db", time.Now().Unix()))
  21. gdb, err := openDB(conf.DatabaseOpts{
  22. Type: "sqlite3",
  23. Path: dbpath,
  24. })
  25. if err != nil {
  26. t.Fatal(err)
  27. }
  28. t.Cleanup(func() {
  29. _ = gdb.Close()
  30. if t.Failed() {
  31. t.Logf("Database %q left intact for inspection", dbpath)
  32. return
  33. }
  34. _ = os.Remove(dbpath)
  35. })
  36. err = gdb.AutoMigrate(new(AccessToken)).Error
  37. if err != nil {
  38. t.Fatal(err)
  39. }
  40. now := time.Now().Truncate(time.Second)
  41. clock := func() time.Time { return now }
  42. db := &accessTokens{DB: gdb, clock: clock}
  43. for _, tc := range []struct {
  44. name string
  45. test func(*testing.T, *accessTokens)
  46. }{
  47. {"Create", test_accessTokens_Create},
  48. {"DeleteByID", test_accessTokens_DeleteByID},
  49. {"GetBySHA", test_accessTokens_GetBySHA},
  50. {"List", test_accessTokens_List},
  51. {"Save", test_accessTokens_Save},
  52. } {
  53. t.Run(tc.name, func(t *testing.T) {
  54. t.Cleanup(func() {
  55. err := deleteTables(gdb, new(AccessToken))
  56. if err != nil {
  57. t.Fatal(err)
  58. }
  59. })
  60. tc.test(t, db)
  61. })
  62. }
  63. }
  64. func test_accessTokens_Create(t *testing.T, db *accessTokens) {
  65. // Create first access token with name "Test"
  66. token, err := db.Create(1, "Test")
  67. if err != nil {
  68. t.Fatal(err)
  69. }
  70. assert.Equal(t, int64(1), token.UserID)
  71. assert.Equal(t, "Test", token.Name)
  72. assert.Equal(t, 40, len(token.Sha1), "sha1 length")
  73. assert.Equal(t, db.clock(), token.Created)
  74. // Try create second access token with same name should fail
  75. _, err = db.Create(token.UserID, token.Name)
  76. expErr := ErrAccessTokenAlreadyExist{args: errutil.Args{"userID": token.UserID, "name": token.Name}}
  77. assert.Equal(t, expErr, err)
  78. }
  79. func test_accessTokens_DeleteByID(t *testing.T, db *accessTokens) {
  80. // Create an access token with name "Test"
  81. token, err := db.Create(1, "Test")
  82. if err != nil {
  83. t.Fatal(err)
  84. }
  85. // We should be able to get it back
  86. _, err = db.GetBySHA(token.Sha1)
  87. if err != nil {
  88. t.Fatal(err)
  89. }
  90. // Delete a token with mismatched user ID is noop
  91. err = db.DeleteByID(2, token.ID)
  92. if err != nil {
  93. t.Fatal(err)
  94. }
  95. _, err = db.GetBySHA(token.Sha1)
  96. if err != nil {
  97. t.Fatal(err)
  98. }
  99. // Now delete this token with correct user ID
  100. err = db.DeleteByID(token.UserID, token.ID)
  101. if err != nil {
  102. t.Fatal(err)
  103. }
  104. // We should get token not found error
  105. _, err = db.GetBySHA(token.Sha1)
  106. expErr := ErrAccessTokenNotExist{args: errutil.Args{"sha": token.Sha1}}
  107. assert.Equal(t, expErr, err)
  108. }
  109. func test_accessTokens_GetBySHA(t *testing.T, db *accessTokens) {
  110. // Create an access token with name "Test"
  111. token, err := db.Create(1, "Test")
  112. if err != nil {
  113. t.Fatal(err)
  114. }
  115. // We should be able to get it back
  116. _, err = db.GetBySHA(token.Sha1)
  117. if err != nil {
  118. t.Fatal(err)
  119. }
  120. // Try to get a non-existent token
  121. _, err = db.GetBySHA("bad_sha")
  122. expErr := ErrAccessTokenNotExist{args: errutil.Args{"sha": "bad_sha"}}
  123. assert.Equal(t, expErr, err)
  124. }
  125. func test_accessTokens_List(t *testing.T, db *accessTokens) {
  126. // Create two access tokens for user 1
  127. _, err := db.Create(1, "user1_1")
  128. if err != nil {
  129. t.Fatal(err)
  130. }
  131. _, err = db.Create(1, "user1_2")
  132. if err != nil {
  133. t.Fatal(err)
  134. }
  135. // Create one access token for user 2
  136. _, err = db.Create(2, "user2_1")
  137. if err != nil {
  138. t.Fatal(err)
  139. }
  140. // List all access tokens for user 1
  141. tokens, err := db.List(1)
  142. if err != nil {
  143. t.Fatal(err)
  144. }
  145. assert.Equal(t, 2, len(tokens), "number of tokens")
  146. assert.Equal(t, int64(1), tokens[0].UserID)
  147. assert.Equal(t, "user1_1", tokens[0].Name)
  148. assert.Equal(t, int64(1), tokens[1].UserID)
  149. assert.Equal(t, "user1_2", tokens[1].Name)
  150. }
  151. func test_accessTokens_Save(t *testing.T, db *accessTokens) {
  152. // Create an access token with name "Test"
  153. token, err := db.Create(1, "Test")
  154. if err != nil {
  155. t.Fatal(err)
  156. }
  157. // Updated field is zero now
  158. assert.True(t, token.Updated.IsZero())
  159. err = db.Save(token)
  160. if err != nil {
  161. t.Fatal(err)
  162. }
  163. // Get back from DB should have Updated set
  164. token, err = db.GetBySHA(token.Sha1)
  165. if err != nil {
  166. t.Fatal(err)
  167. }
  168. assert.Equal(t, db.clock(), token.Updated)
  169. }