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.

delete_user_test.go 2.1KB

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