diff options
author | lain <lain@soykaf.club> | 2020-05-20 11:43:49 +0000 |
---|---|---|
committer | lain <lain@soykaf.club> | 2020-05-20 11:43:49 +0000 |
commit | 423ea497bb2a7225f4f0d0e1ebff93466b3ec124 (patch) | |
tree | 635a88c98b28451b01bb5ed8bf5a247792b71d60 /test | |
parent | 67844a8b11e7b921375f184afd1410a42c342d0f (diff) | |
parent | 287f781808c88f43f5689508b5aa21f6639b9d16 (diff) | |
download | pleroma-423ea497bb2a7225f4f0d0e1ebff93466b3ec124.tar.gz |
Merge branch 'feature/1734-user-deletion' into 'develop'
User deletion
Closes #1734
See merge request pleroma/pleroma!2493
Diffstat (limited to 'test')
-rw-r--r-- | test/user_test.exs | 27 | ||||
-rw-r--r-- | test/web/activity_pub/side_effects_test.exs | 25 |
2 files changed, 52 insertions, 0 deletions
diff --git a/test/user_test.exs b/test/user_test.exs index 239d16799..863e0106c 100644 --- a/test/user_test.exs +++ b/test/user_test.exs @@ -1172,6 +1172,33 @@ defmodule Pleroma.UserTest do end end + describe "delete/1 when confirmation is pending" do + setup do + user = insert(:user, confirmation_pending: true) + {:ok, user: user} + end + + test "deletes user from database when activation required", %{user: user} do + clear_config([:instance, :account_activation_required], true) + + {:ok, job} = User.delete(user) + {:ok, _} = ObanHelpers.perform(job) + + refute User.get_cached_by_id(user.id) + refute User.get_by_id(user.id) + end + + test "deactivates user when activation is not required", %{user: user} do + clear_config([:instance, :account_activation_required], false) + + {:ok, job} = User.delete(user) + {:ok, _} = ObanHelpers.perform(job) + + assert %{deactivated: true} = User.get_cached_by_id(user.id) + assert %{deactivated: true} = User.get_by_id(user.id) + end + end + test "get_public_key_for_ap_id fetches a user that's not in the db" do assert {:ok, _key} = User.get_public_key_for_ap_id("http://mastodon.example.org/users/admin") end diff --git a/test/web/activity_pub/side_effects_test.exs b/test/web/activity_pub/side_effects_test.exs index 797f00d08..a46254a05 100644 --- a/test/web/activity_pub/side_effects_test.exs +++ b/test/web/activity_pub/side_effects_test.exs @@ -140,6 +140,31 @@ defmodule Pleroma.Web.ActivityPub.SideEffectsTest do end end + describe "delete users with confirmation pending" do + setup do + user = insert(:user, confirmation_pending: true) + {:ok, delete_user_data, _meta} = Builder.delete(user, user.ap_id) + {:ok, delete_user, _meta} = ActivityPub.persist(delete_user_data, local: true) + {:ok, delete: delete_user, user: user} + end + + test "when activation is not required", %{delete: delete, user: user} do + clear_config([:instance, :account_activation_required], false) + {:ok, _, _} = SideEffects.handle(delete) + ObanHelpers.perform_all() + + assert User.get_cached_by_id(user.id).deactivated + end + + test "when activation is required", %{delete: delete, user: user} do + clear_config([:instance, :account_activation_required], true) + {:ok, _, _} = SideEffects.handle(delete) + ObanHelpers.perform_all() + + refute User.get_cached_by_id(user.id) + end + end + describe "Undo objects" do setup do poster = insert(:user) |