diff options
Diffstat (limited to 'test/web/mastodon_api')
| -rw-r--r-- | test/web/mastodon_api/account_view_test.exs | 4 | ||||
| -rw-r--r-- | test/web/mastodon_api/notification_view_test.exs | 104 | ||||
| -rw-r--r-- | test/web/mastodon_api/status_view_test.exs | 3 | 
3 files changed, 108 insertions, 3 deletions
diff --git a/test/web/mastodon_api/account_view_test.exs b/test/web/mastodon_api/account_view_test.exs index c2ffc21da..6dc60afe9 100644 --- a/test/web/mastodon_api/account_view_test.exs +++ b/test/web/mastodon_api/account_view_test.exs @@ -144,7 +144,7 @@ defmodule Pleroma.Web.MastodonAPI.AccountViewTest do        muting_notifications: false,        requested: false,        domain_blocking: false, -      showing_reblogs: false, +      showing_reblogs: true,        endorsed: false      } @@ -202,7 +202,7 @@ defmodule Pleroma.Web.MastodonAPI.AccountViewTest do            muting_notifications: false,            requested: false,            domain_blocking: false, -          showing_reblogs: false, +          showing_reblogs: true,            endorsed: false          }        } diff --git a/test/web/mastodon_api/notification_view_test.exs b/test/web/mastodon_api/notification_view_test.exs new file mode 100644 index 000000000..b826a7e61 --- /dev/null +++ b/test/web/mastodon_api/notification_view_test.exs @@ -0,0 +1,104 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.MastodonAPI.NotificationViewTest do +  use Pleroma.DataCase + +  alias Pleroma.Activity +  alias Pleroma.Notification +  alias Pleroma.Repo +  alias Pleroma.User +  alias Pleroma.Web.CommonAPI +  alias Pleroma.Web.CommonAPI.Utils +  alias Pleroma.Web.MastodonAPI.AccountView +  alias Pleroma.Web.MastodonAPI.NotificationView +  alias Pleroma.Web.MastodonAPI.StatusView +  import Pleroma.Factory + +  test "Mention notification" do +    user = insert(:user) +    mentioned_user = insert(:user) +    {:ok, activity} = CommonAPI.post(user, %{"status" => "hey @#{mentioned_user.nickname}"}) +    {:ok, [notification]} = Notification.create_notifications(activity) +    user = Repo.get(User, user.id) + +    expected = %{ +      id: to_string(notification.id), +      pleroma: %{is_seen: false}, +      type: "mention", +      account: AccountView.render("account.json", %{user: user, for: mentioned_user}), +      status: StatusView.render("status.json", %{activity: activity, for: mentioned_user}), +      created_at: Utils.to_masto_date(notification.inserted_at) +    } + +    result = +      NotificationView.render("index.json", %{notifications: [notification], for: mentioned_user}) + +    assert [expected] == result +  end + +  test "Favourite notification" do +    user = insert(:user) +    another_user = insert(:user) +    {:ok, create_activity} = CommonAPI.post(user, %{"status" => "hey"}) +    {:ok, favorite_activity, _object} = CommonAPI.favorite(create_activity.id, another_user) +    {:ok, [notification]} = Notification.create_notifications(favorite_activity) +    create_activity = Repo.get(Activity, create_activity.id) + +    expected = %{ +      id: to_string(notification.id), +      pleroma: %{is_seen: false}, +      type: "favourite", +      account: AccountView.render("account.json", %{user: another_user, for: user}), +      status: StatusView.render("status.json", %{activity: create_activity, for: user}), +      created_at: Utils.to_masto_date(notification.inserted_at) +    } + +    result = NotificationView.render("index.json", %{notifications: [notification], for: user}) + +    assert [expected] == result +  end + +  test "Reblog notification" do +    user = insert(:user) +    another_user = insert(:user) +    {:ok, create_activity} = CommonAPI.post(user, %{"status" => "hey"}) +    {:ok, reblog_activity, _object} = CommonAPI.repeat(create_activity.id, another_user) +    {:ok, [notification]} = Notification.create_notifications(reblog_activity) +    reblog_activity = Repo.get(Activity, create_activity.id) + +    expected = %{ +      id: to_string(notification.id), +      pleroma: %{is_seen: false}, +      type: "reblog", +      account: AccountView.render("account.json", %{user: another_user, for: user}), +      status: StatusView.render("status.json", %{activity: reblog_activity, for: user}), +      created_at: Utils.to_masto_date(notification.inserted_at) +    } + +    result = NotificationView.render("index.json", %{notifications: [notification], for: user}) + +    assert [expected] == result +  end + +  test "Follow notification" do +    follower = insert(:user) +    followed = insert(:user) +    {:ok, follower, followed, _activity} = CommonAPI.follow(follower, followed) +    notification = Notification |> Repo.one() |> Repo.preload(:activity) + +    expected = %{ +      id: to_string(notification.id), +      pleroma: %{is_seen: false}, +      type: "follow", +      account: AccountView.render("account.json", %{user: follower, for: followed}), +      created_at: Utils.to_masto_date(notification.inserted_at) +    } + +    result = +      NotificationView.render("index.json", %{notifications: [notification], for: followed}) + +    assert [expected] == result +  end +end diff --git a/test/web/mastodon_api/status_view_test.exs b/test/web/mastodon_api/status_view_test.exs index 3eec2cb5b..ade0ca9f9 100644 --- a/test/web/mastodon_api/status_view_test.exs +++ b/test/web/mastodon_api/status_view_test.exs @@ -196,7 +196,8 @@ defmodule Pleroma.Web.MastodonAPI.StatusViewTest do        remote_url: "someurl",        preview_url: "someurl",        text_url: "someurl", -      description: nil +      description: nil, +      pleroma: %{mime_type: "image/png"}      }      assert expected == StatusView.render("attachment.json", %{attachment: object})  | 
