access_tokens_test.go 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  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. "context"
  7. "testing"
  8. "time"
  9. "github.com/stretchr/testify/assert"
  10. "github.com/stretchr/testify/require"
  11. "gorm.io/gorm"
  12. "gogs.io/gogs/internal/dbtest"
  13. "gogs.io/gogs/internal/errutil"
  14. )
  15. func TestAccessToken_BeforeCreate(t *testing.T) {
  16. now := time.Now()
  17. db := &gorm.DB{
  18. Config: &gorm.Config{
  19. NowFunc: func() time.Time {
  20. return now
  21. },
  22. },
  23. }
  24. t.Run("CreatedUnix has been set", func(t *testing.T) {
  25. token := &AccessToken{CreatedUnix: 1}
  26. _ = token.BeforeCreate(db)
  27. assert.Equal(t, int64(1), token.CreatedUnix)
  28. assert.Equal(t, int64(0), token.UpdatedUnix)
  29. })
  30. t.Run("CreatedUnix has not been set", func(t *testing.T) {
  31. token := &AccessToken{}
  32. _ = token.BeforeCreate(db)
  33. assert.Equal(t, db.NowFunc().Unix(), token.CreatedUnix)
  34. assert.Equal(t, int64(0), token.UpdatedUnix)
  35. })
  36. }
  37. func TestAccessTokens(t *testing.T) {
  38. if testing.Short() {
  39. t.Skip()
  40. }
  41. t.Parallel()
  42. tables := []interface{}{new(AccessToken)}
  43. db := &accessTokens{
  44. DB: dbtest.NewDB(t, "accessTokens", tables...),
  45. }
  46. for _, tc := range []struct {
  47. name string
  48. test func(*testing.T, *accessTokens)
  49. }{
  50. {"Create", accessTokensCreate},
  51. {"DeleteByID", accessTokensDeleteByID},
  52. {"GetBySHA1", accessTokensGetBySHA},
  53. {"List", accessTokensList},
  54. {"Touch", accessTokensTouch},
  55. } {
  56. t.Run(tc.name, func(t *testing.T) {
  57. t.Cleanup(func() {
  58. err := clearTables(t, db.DB, tables...)
  59. require.NoError(t, err)
  60. })
  61. tc.test(t, db)
  62. })
  63. if t.Failed() {
  64. break
  65. }
  66. }
  67. }
  68. func accessTokensCreate(t *testing.T, db *accessTokens) {
  69. ctx := context.Background()
  70. // Create first access token with name "Test"
  71. token, err := db.Create(ctx, 1, "Test")
  72. require.NoError(t, err)
  73. assert.Equal(t, int64(1), token.UserID)
  74. assert.Equal(t, "Test", token.Name)
  75. assert.Equal(t, 40, len(token.Sha1), "sha1 length")
  76. // Get it back and check the Created field
  77. token, err = db.GetBySHA1(ctx, token.Sha1)
  78. require.NoError(t, err)
  79. assert.Equal(t, db.NowFunc().Format(time.RFC3339), token.Created.UTC().Format(time.RFC3339))
  80. // Try create second access token with same name should fail
  81. _, err = db.Create(ctx, token.UserID, token.Name)
  82. wantErr := ErrAccessTokenAlreadyExist{
  83. args: errutil.Args{
  84. "userID": token.UserID,
  85. "name": token.Name,
  86. },
  87. }
  88. assert.Equal(t, wantErr, err)
  89. }
  90. func accessTokensDeleteByID(t *testing.T, db *accessTokens) {
  91. ctx := context.Background()
  92. // Create an access token with name "Test"
  93. token, err := db.Create(ctx, 1, "Test")
  94. require.NoError(t, err)
  95. // Delete a token with mismatched user ID is noop
  96. err = db.DeleteByID(ctx, 2, token.ID)
  97. require.NoError(t, err)
  98. // We should be able to get it back
  99. _, err = db.GetBySHA1(ctx, token.Sha1)
  100. require.NoError(t, err)
  101. // Now delete this token with correct user ID
  102. err = db.DeleteByID(ctx, token.UserID, token.ID)
  103. require.NoError(t, err)
  104. // We should get token not found error
  105. _, err = db.GetBySHA1(ctx, token.Sha1)
  106. wantErr := ErrAccessTokenNotExist{
  107. args: errutil.Args{
  108. "sha": token.Sha1,
  109. },
  110. }
  111. assert.Equal(t, wantErr, err)
  112. }
  113. func accessTokensGetBySHA(t *testing.T, db *accessTokens) {
  114. ctx := context.Background()
  115. // Create an access token with name "Test"
  116. token, err := db.Create(ctx, 1, "Test")
  117. require.NoError(t, err)
  118. // We should be able to get it back
  119. _, err = db.GetBySHA1(ctx, token.Sha1)
  120. require.NoError(t, err)
  121. // Try to get a non-existent token
  122. _, err = db.GetBySHA1(ctx, "bad_sha")
  123. wantErr := ErrAccessTokenNotExist{
  124. args: errutil.Args{
  125. "sha": "bad_sha",
  126. },
  127. }
  128. assert.Equal(t, wantErr, err)
  129. }
  130. func accessTokensList(t *testing.T, db *accessTokens) {
  131. ctx := context.Background()
  132. // Create two access tokens for user 1
  133. _, err := db.Create(ctx, 1, "user1_1")
  134. require.NoError(t, err)
  135. _, err = db.Create(ctx, 1, "user1_2")
  136. require.NoError(t, err)
  137. // Create one access token for user 2
  138. _, err = db.Create(ctx, 2, "user2_1")
  139. require.NoError(t, err)
  140. // List all access tokens for user 1
  141. tokens, err := db.List(ctx, 1)
  142. require.NoError(t, err)
  143. assert.Equal(t, 2, len(tokens), "number of tokens")
  144. assert.Equal(t, int64(1), tokens[0].UserID)
  145. assert.Equal(t, "user1_1", tokens[0].Name)
  146. assert.Equal(t, int64(1), tokens[1].UserID)
  147. assert.Equal(t, "user1_2", tokens[1].Name)
  148. }
  149. func accessTokensTouch(t *testing.T, db *accessTokens) {
  150. ctx := context.Background()
  151. // Create an access token with name "Test"
  152. token, err := db.Create(ctx, 1, "Test")
  153. require.NoError(t, err)
  154. // Updated field is zero now
  155. assert.True(t, token.Updated.IsZero())
  156. err = db.Touch(ctx, token.ID)
  157. require.NoError(t, err)
  158. // Get back from DB should have Updated set
  159. token, err = db.GetBySHA1(ctx, token.Sha1)
  160. require.NoError(t, err)
  161. assert.Equal(t, db.NowFunc().Format(time.RFC3339), token.Updated.UTC().Format(time.RFC3339))
  162. }