You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

token_test.go 4.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. // Copyright 2016 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package auth_test
  4. import (
  5. "testing"
  6. auth_model "code.gitea.io/gitea/models/auth"
  7. "code.gitea.io/gitea/models/db"
  8. "code.gitea.io/gitea/models/unittest"
  9. "github.com/stretchr/testify/assert"
  10. )
  11. func TestNewAccessToken(t *testing.T) {
  12. assert.NoError(t, unittest.PrepareTestDatabase())
  13. token := &auth_model.AccessToken{
  14. UID: 3,
  15. Name: "Token C",
  16. }
  17. assert.NoError(t, auth_model.NewAccessToken(db.DefaultContext, token))
  18. unittest.AssertExistsAndLoadBean(t, token)
  19. invalidToken := &auth_model.AccessToken{
  20. ID: token.ID, // duplicate
  21. UID: 2,
  22. Name: "Token F",
  23. }
  24. assert.Error(t, auth_model.NewAccessToken(db.DefaultContext, invalidToken))
  25. }
  26. func TestAccessTokenByNameExists(t *testing.T) {
  27. name := "Token Gitea"
  28. assert.NoError(t, unittest.PrepareTestDatabase())
  29. token := &auth_model.AccessToken{
  30. UID: 3,
  31. Name: name,
  32. }
  33. // Check to make sure it doesn't exists already
  34. exist, err := auth_model.AccessTokenByNameExists(db.DefaultContext, token)
  35. assert.NoError(t, err)
  36. assert.False(t, exist)
  37. // Save it to the database
  38. assert.NoError(t, auth_model.NewAccessToken(db.DefaultContext, token))
  39. unittest.AssertExistsAndLoadBean(t, token)
  40. // This token must be found by name in the DB now
  41. exist, err = auth_model.AccessTokenByNameExists(db.DefaultContext, token)
  42. assert.NoError(t, err)
  43. assert.True(t, exist)
  44. user4Token := &auth_model.AccessToken{
  45. UID: 4,
  46. Name: name,
  47. }
  48. // Name matches but different user ID, this shouldn't exists in the
  49. // database
  50. exist, err = auth_model.AccessTokenByNameExists(db.DefaultContext, user4Token)
  51. assert.NoError(t, err)
  52. assert.False(t, exist)
  53. }
  54. func TestGetAccessTokenBySHA(t *testing.T) {
  55. assert.NoError(t, unittest.PrepareTestDatabase())
  56. token, err := auth_model.GetAccessTokenBySHA(db.DefaultContext, "d2c6c1ba3890b309189a8e618c72a162e4efbf36")
  57. assert.NoError(t, err)
  58. assert.Equal(t, int64(1), token.UID)
  59. assert.Equal(t, "Token A", token.Name)
  60. assert.Equal(t, "2b3668e11cb82d3af8c6e4524fc7841297668f5008d1626f0ad3417e9fa39af84c268248b78c481daa7e5dc437784003494f", token.TokenHash)
  61. assert.Equal(t, "e4efbf36", token.TokenLastEight)
  62. _, err = auth_model.GetAccessTokenBySHA(db.DefaultContext, "notahash")
  63. assert.Error(t, err)
  64. assert.True(t, auth_model.IsErrAccessTokenNotExist(err))
  65. _, err = auth_model.GetAccessTokenBySHA(db.DefaultContext, "")
  66. assert.Error(t, err)
  67. assert.True(t, auth_model.IsErrAccessTokenEmpty(err))
  68. }
  69. func TestListAccessTokens(t *testing.T) {
  70. assert.NoError(t, unittest.PrepareTestDatabase())
  71. tokens, err := auth_model.ListAccessTokens(db.DefaultContext, auth_model.ListAccessTokensOptions{UserID: 1})
  72. assert.NoError(t, err)
  73. if assert.Len(t, tokens, 2) {
  74. assert.Equal(t, int64(1), tokens[0].UID)
  75. assert.Equal(t, int64(1), tokens[1].UID)
  76. assert.Contains(t, []string{tokens[0].Name, tokens[1].Name}, "Token A")
  77. assert.Contains(t, []string{tokens[0].Name, tokens[1].Name}, "Token B")
  78. }
  79. tokens, err = auth_model.ListAccessTokens(db.DefaultContext, auth_model.ListAccessTokensOptions{UserID: 2})
  80. assert.NoError(t, err)
  81. if assert.Len(t, tokens, 1) {
  82. assert.Equal(t, int64(2), tokens[0].UID)
  83. assert.Equal(t, "Token A", tokens[0].Name)
  84. }
  85. tokens, err = auth_model.ListAccessTokens(db.DefaultContext, auth_model.ListAccessTokensOptions{UserID: 100})
  86. assert.NoError(t, err)
  87. assert.Empty(t, tokens)
  88. }
  89. func TestUpdateAccessToken(t *testing.T) {
  90. assert.NoError(t, unittest.PrepareTestDatabase())
  91. token, err := auth_model.GetAccessTokenBySHA(db.DefaultContext, "4c6f36e6cf498e2a448662f915d932c09c5a146c")
  92. assert.NoError(t, err)
  93. token.Name = "Token Z"
  94. assert.NoError(t, auth_model.UpdateAccessToken(db.DefaultContext, token))
  95. unittest.AssertExistsAndLoadBean(t, token)
  96. }
  97. func TestDeleteAccessTokenByID(t *testing.T) {
  98. assert.NoError(t, unittest.PrepareTestDatabase())
  99. token, err := auth_model.GetAccessTokenBySHA(db.DefaultContext, "4c6f36e6cf498e2a448662f915d932c09c5a146c")
  100. assert.NoError(t, err)
  101. assert.Equal(t, int64(1), token.UID)
  102. assert.NoError(t, auth_model.DeleteAccessTokenByID(db.DefaultContext, token.ID, 1))
  103. unittest.AssertNotExistsBean(t, token)
  104. err = auth_model.DeleteAccessTokenByID(db.DefaultContext, 100, 100)
  105. assert.Error(t, err)
  106. assert.True(t, auth_model.IsErrAccessTokenNotExist(err))
  107. }