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 3.9KB

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