gitea源码

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. // Copyright 2017 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package integration
  4. import (
  5. "net/http"
  6. "testing"
  7. issues_model "code.gitea.io/gitea/models/issues"
  8. "code.gitea.io/gitea/models/organization"
  9. access_model "code.gitea.io/gitea/models/perm/access"
  10. repo_model "code.gitea.io/gitea/models/repo"
  11. "code.gitea.io/gitea/models/unittest"
  12. user_model "code.gitea.io/gitea/models/user"
  13. "code.gitea.io/gitea/tests"
  14. )
  15. func assertUserDeleted(t *testing.T, userID int64) {
  16. unittest.AssertNotExistsBean(t, &user_model.User{ID: userID})
  17. unittest.AssertNotExistsBean(t, &user_model.Follow{UserID: userID})
  18. unittest.AssertNotExistsBean(t, &user_model.Follow{FollowID: userID})
  19. unittest.AssertNotExistsBean(t, &repo_model.Repository{OwnerID: userID})
  20. unittest.AssertNotExistsBean(t, &access_model.Access{UserID: userID})
  21. unittest.AssertNotExistsBean(t, &organization.OrgUser{UID: userID})
  22. unittest.AssertNotExistsBean(t, &issues_model.IssueUser{UID: userID})
  23. unittest.AssertNotExistsBean(t, &organization.TeamUser{UID: userID})
  24. unittest.AssertNotExistsBean(t, &repo_model.Star{UID: userID})
  25. }
  26. func TestUserDeleteAccount(t *testing.T) {
  27. defer tests.PrepareTestEnv(t)()
  28. session := loginUser(t, "user8")
  29. csrf := GetUserCSRFToken(t, session)
  30. urlStr := "/user/settings/account/delete?password=" + userPassword
  31. req := NewRequestWithValues(t, "POST", urlStr, map[string]string{
  32. "_csrf": csrf,
  33. })
  34. session.MakeRequest(t, req, http.StatusSeeOther)
  35. assertUserDeleted(t, 8)
  36. unittest.CheckConsistencyFor(t, &user_model.User{})
  37. }
  38. func TestUserDeleteAccountStillOwnRepos(t *testing.T) {
  39. defer tests.PrepareTestEnv(t)()
  40. session := loginUser(t, "user2")
  41. csrf := GetUserCSRFToken(t, session)
  42. urlStr := "/user/settings/account/delete?password=" + userPassword
  43. req := NewRequestWithValues(t, "POST", urlStr, map[string]string{
  44. "_csrf": csrf,
  45. })
  46. session.MakeRequest(t, req, http.StatusSeeOther)
  47. // user should not have been deleted, because the user still owns repos
  48. unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
  49. }