diff options
| author | eugenijm <eugenijm@protonmail.com> | 2020-05-18 18:46:04 +0300 | 
|---|---|---|
| committer | eugenijm <eugenijm@protonmail.com> | 2020-06-14 18:27:11 +0300 | 
| commit | b15cfc3d365dcfa5f99159fe06e29de6f8aceb4f (patch) | |
| tree | 156ff3c3c0fb6eb12064e536ae5a754048b48af4 /test | |
| parent | 271ea5068f4e3b901cb3f682e132378246daf452 (diff) | |
| download | pleroma-b15cfc3d365dcfa5f99159fe06e29de6f8aceb4f.tar.gz pleroma-b15cfc3d365dcfa5f99159fe06e29de6f8aceb4f.zip | |
Mastodon API: ensure the notification endpoint doesn't return less than the requested amount of records unless it's the last page
Diffstat (limited to 'test')
| -rw-r--r-- | test/notification_test.exs | 8 | ||||
| -rw-r--r-- | test/web/mastodon_api/controllers/notification_controller_test.exs | 27 | ||||
| -rw-r--r-- | test/web/mastodon_api/views/notification_view_test.exs | 4 | 
3 files changed, 36 insertions, 3 deletions
| diff --git a/test/notification_test.exs b/test/notification_test.exs index b9bbdceca..526f43fab 100644 --- a/test/notification_test.exs +++ b/test/notification_test.exs @@ -306,6 +306,14 @@ defmodule Pleroma.NotificationTest do        assert {:ok, []} == Notification.create_notifications(status)      end + +    test "it disables notifications from people who are invisible" do +      author = insert(:user, invisible: true) +      user = insert(:user) + +      {:ok, status} = CommonAPI.post(author, %{status: "hey @#{user.nickname}"}) +      refute Notification.create_notification(status, user) +    end    end    describe "follow / follow_request notifications" do diff --git a/test/web/mastodon_api/controllers/notification_controller_test.exs b/test/web/mastodon_api/controllers/notification_controller_test.exs index 698c99711..70ef0e8b5 100644 --- a/test/web/mastodon_api/controllers/notification_controller_test.exs +++ b/test/web/mastodon_api/controllers/notification_controller_test.exs @@ -313,6 +313,33 @@ defmodule Pleroma.Web.MastodonAPI.NotificationControllerTest do        assert public_activity.id in activity_ids        refute unlisted_activity.id in activity_ids      end + +    test "doesn't return less than the requested amount of records when the user's reply is liked" do +      user = insert(:user) +      %{user: other_user, conn: conn} = oauth_access(["read:notifications"]) + +      {:ok, mention} = +        CommonAPI.post(user, %{status: "@#{other_user.nickname}", visibility: "public"}) + +      {:ok, activity} = CommonAPI.post(user, %{status: ".", visibility: "public"}) + +      {:ok, reply} = +        CommonAPI.post(other_user, %{ +          status: ".", +          visibility: "public", +          in_reply_to_status_id: activity.id +        }) + +      {:ok, _favorite} = CommonAPI.favorite(user, reply.id) + +      activity_ids = +        conn +        |> get("/api/v1/notifications?exclude_visibilities[]=direct&limit=2") +        |> json_response_and_validate_schema(200) +        |> Enum.map(& &1["status"]["id"]) + +      assert [reply.id, mention.id] == activity_ids +    end    end    test "filters notifications using exclude_types" do diff --git a/test/web/mastodon_api/views/notification_view_test.exs b/test/web/mastodon_api/views/notification_view_test.exs index b2fa5b302..9c399b2df 100644 --- a/test/web/mastodon_api/views/notification_view_test.exs +++ b/test/web/mastodon_api/views/notification_view_test.exs @@ -139,9 +139,7 @@ defmodule Pleroma.Web.MastodonAPI.NotificationViewTest do      test_notifications_rendering([notification], followed, [expected])      User.perform(:delete, follower) -    notification = Notification |> Repo.one() |> Repo.preload(:activity) - -    test_notifications_rendering([notification], followed, []) +    refute Repo.one(Notification)    end    @tag capture_log: true | 
