aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/filter_test.exs2
-rw-r--r--test/support/factory.ex8
-rw-r--r--test/web/activity_pub/activity_pub_test.exs69
3 files changed, 78 insertions, 1 deletions
diff --git a/test/filter_test.exs b/test/filter_test.exs
index 63a30c736..061a95ad0 100644
--- a/test/filter_test.exs
+++ b/test/filter_test.exs
@@ -126,7 +126,7 @@ defmodule Pleroma.FilterTest do
{:ok, filter_one} = Pleroma.Filter.create(query_one)
{:ok, filter_two} = Pleroma.Filter.create(query_two)
- filters = Pleroma.Filter.get_filters(user)
+ filters = Pleroma.Filter.get_by_user(Pleroma.Filter, user)
assert filter_one in filters
assert filter_two in filters
end
diff --git a/test/support/factory.ex b/test/support/factory.ex
index af580021c..635d83650 100644
--- a/test/support/factory.ex
+++ b/test/support/factory.ex
@@ -428,4 +428,12 @@ defmodule Pleroma.Factory do
user: build(:user)
}
end
+
+ def filter_factory do
+ %Pleroma.Filter{
+ user: build(:user),
+ filter_id: sequence(:filter_id, & &1),
+ phrase: "cofe"
+ }
+ end
end
diff --git a/test/web/activity_pub/activity_pub_test.exs b/test/web/activity_pub/activity_pub_test.exs
index 575e0c5db..4968403dc 100644
--- a/test/web/activity_pub/activity_pub_test.exs
+++ b/test/web/activity_pub/activity_pub_test.exs
@@ -785,6 +785,75 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do
assert activity == expected_activity
end
+ describe "irreversible filters" do
+ setup do
+ user = insert(:user)
+ user_two = insert(:user)
+
+ insert(:filter, user: user_two, phrase: "cofe", hide: true)
+ insert(:filter, user: user_two, phrase: "ok boomer", hide: true)
+ insert(:filter, user: user_two, phrase: "test", hide: false)
+
+ params = %{
+ "type" => ["Create", "Announce"],
+ "user" => user_two
+ }
+
+ {:ok, %{user: user, user_two: user_two, params: params}}
+ end
+
+ test "it returns statuses if they don't contain exact filter words", %{
+ user: user,
+ params: params
+ } do
+ {:ok, _} = CommonAPI.post(user, %{"status" => "hey"})
+ {:ok, _} = CommonAPI.post(user, %{"status" => "got cofefe?"})
+ {:ok, _} = CommonAPI.post(user, %{"status" => "I am not a boomer"})
+ {:ok, _} = CommonAPI.post(user, %{"status" => "ok boomers"})
+ {:ok, _} = CommonAPI.post(user, %{"status" => "ccofee is not a word"})
+ {:ok, _} = CommonAPI.post(user, %{"status" => "this is a test"})
+
+ activities = ActivityPub.fetch_activities([], params)
+
+ assert Enum.count(activities) == 6
+ end
+
+ test "it does not filter user's own statuses", %{user_two: user_two, params: params} do
+ {:ok, _} = CommonAPI.post(user_two, %{"status" => "Give me some cofe!"})
+ {:ok, _} = CommonAPI.post(user_two, %{"status" => "ok boomer"})
+
+ activities = ActivityPub.fetch_activities([], params)
+
+ assert Enum.count(activities) == 2
+ end
+
+ test "it excludes statuses with filter words", %{user: user, params: params} do
+ {:ok, _} = CommonAPI.post(user, %{"status" => "Give me some cofe!"})
+ {:ok, _} = CommonAPI.post(user, %{"status" => "ok boomer"})
+ {:ok, _} = CommonAPI.post(user, %{"status" => "is it a cOfE?"})
+ {:ok, _} = CommonAPI.post(user, %{"status" => "cofe is all I need"})
+ {:ok, _} = CommonAPI.post(user, %{"status" => "— ok BOOMER\n"})
+
+ activities = ActivityPub.fetch_activities([], params)
+
+ assert Enum.empty?(activities)
+ end
+
+ test "it returns all statuses if user does not have any filters" do
+ another_user = insert(:user)
+ {:ok, _} = CommonAPI.post(another_user, %{"status" => "got cofe?"})
+ {:ok, _} = CommonAPI.post(another_user, %{"status" => "test!"})
+
+ activities =
+ ActivityPub.fetch_activities([], %{
+ "type" => ["Create", "Announce"],
+ "user" => another_user
+ })
+
+ assert Enum.count(activities) == 2
+ end
+ end
+
describe "public fetch activities" do
test "doesn't retrieve unlisted activities" do
user = insert(:user)