diff options
Diffstat (limited to 'test/web/twitter_api/views')
| -rw-r--r-- | test/web/twitter_api/views/activity_view_test.exs | 158 | ||||
| -rw-r--r-- | test/web/twitter_api/views/notification_view_test.exs | 20 | ||||
| -rw-r--r-- | test/web/twitter_api/views/user_view_test.exs | 85 | 
3 files changed, 229 insertions, 34 deletions
| diff --git a/test/web/twitter_api/views/activity_view_test.exs b/test/web/twitter_api/views/activity_view_test.exs index f4741cf24..7ef0270cc 100644 --- a/test/web/twitter_api/views/activity_view_test.exs +++ b/test/web/twitter_api/views/activity_view_test.exs @@ -1,19 +1,126 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only +  defmodule Pleroma.Web.TwitterAPI.ActivityViewTest do    use Pleroma.DataCase +  alias Pleroma.Activity +  alias Pleroma.Object +  alias Pleroma.Repo +  alias Pleroma.User +  alias Pleroma.Web.ActivityPub.ActivityPub    alias Pleroma.Web.CommonAPI    alias Pleroma.Web.CommonAPI.Utils    alias Pleroma.Web.TwitterAPI.ActivityView    alias Pleroma.Web.TwitterAPI.UserView -  alias Pleroma.Web.TwitterAPI.TwitterAPI -  alias Pleroma.Repo -  alias Pleroma.{Activity, Object} -  alias Pleroma.User -  alias Pleroma.Web.ActivityPub.ActivityPub    import Pleroma.Factory +  import Tesla.Mock + +  setup do +    mock(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end +    import Mock +  test "returns a temporary ap_id based user for activities missing db users" do +    user = insert(:user) + +    {:ok, activity} = CommonAPI.post(user, %{"status" => "Hey @shp!", "visibility" => "direct"}) + +    Repo.delete(user) +    Cachex.clear(:user_cache) + +    %{"user" => tw_user} = ActivityView.render("activity.json", activity: activity) + +    assert tw_user["screen_name"] == "erroruser@example.com" +    assert tw_user["name"] == user.ap_id +    assert tw_user["statusnet_profile_url"] == user.ap_id +  end + +  test "tries to get a user by nickname if fetching by ap_id doesn't work" do +    user = insert(:user) + +    {:ok, activity} = CommonAPI.post(user, %{"status" => "Hey @shp!", "visibility" => "direct"}) + +    {:ok, user} = +      user +      |> Ecto.Changeset.change(%{ap_id: "#{user.ap_id}/extension/#{user.nickname}"}) +      |> Repo.update() + +    Cachex.clear(:user_cache) + +    result = ActivityView.render("activity.json", activity: activity) +    assert result["user"]["id"] == user.id +  end + +  test "tells if the message is muted for some reason" do +    user = insert(:user) +    other_user = insert(:user) + +    {:ok, user} = User.mute(user, other_user) + +    {:ok, activity} = CommonAPI.post(other_user, %{"status" => "test"}) +    status = ActivityView.render("activity.json", %{activity: activity}) + +    assert status["muted"] == false + +    status = ActivityView.render("activity.json", %{activity: activity, for: user}) + +    assert status["muted"] == true +  end + +  test "a create activity with a html status" do +    text = """ +    #Bike log - Commute Tuesday\nhttps://pla.bike/posts/20181211/\n#cycling #CHScycling #commute\nMVIMG_20181211_054020.jpg +    """ + +    {:ok, activity} = CommonAPI.post(insert(:user), %{"status" => text}) + +    result = ActivityView.render("activity.json", activity: activity) + +    assert result["statusnet_html"] == +             "<a class=\"hashtag\" data-tag=\"bike\" href=\"http://localhost:4001/tag/bike\" rel=\"tag\">#Bike</a> log - Commute Tuesday<br /><a href=\"https://pla.bike/posts/20181211/\">https://pla.bike/posts/20181211/</a><br /><a class=\"hashtag\" data-tag=\"cycling\" href=\"http://localhost:4001/tag/cycling\" rel=\"tag\">#cycling</a> <a class=\"hashtag\" data-tag=\"chscycling\" href=\"http://localhost:4001/tag/chscycling\" rel=\"tag\">#CHScycling</a> <a class=\"hashtag\" data-tag=\"commute\" href=\"http://localhost:4001/tag/commute\" rel=\"tag\">#commute</a><br />MVIMG_20181211_054020.jpg" + +    assert result["text"] == +             "#Bike log - Commute Tuesday\nhttps://pla.bike/posts/20181211/\n#cycling #CHScycling #commute\nMVIMG_20181211_054020.jpg" +  end + +  test "a create activity with a summary containing emoji" do +    {:ok, activity} = +      CommonAPI.post(insert(:user), %{ +        "spoiler_text" => ":woollysocks: meow", +        "status" => "." +      }) + +    result = ActivityView.render("activity.json", activity: activity) + +    expected = ":woollysocks: meow" + +    expected_html = +      "<img height=\"32px\" width=\"32px\" alt=\"woollysocks\" title=\"woollysocks\" src=\"http://localhost:4001/finmoji/128px/woollysocks-128.png\" /> meow" + +    assert result["summary"] == expected +    assert result["summary_html"] == expected_html +  end + +  test "a create activity with a summary containing invalid HTML" do +    {:ok, activity} = +      CommonAPI.post(insert(:user), %{ +        "spoiler_text" => "<span style=\"color: magenta; font-size: 32px;\">meow</span>", +        "status" => "." +      }) + +    result = ActivityView.render("activity.json", activity: activity) + +    expected = "meow" + +    assert result["summary"] == expected +    assert result["summary_html"] == expected +  end +    test "a create activity with a note" do      user = insert(:user)      other_user = insert(:user, %{nickname: "shp"}) @@ -23,7 +130,7 @@ defmodule Pleroma.Web.TwitterAPI.ActivityViewTest do      result = ActivityView.render("activity.json", activity: activity) -    convo_id = TwitterAPI.context_to_conversation_id(object.data["context"]) +    convo_id = Utils.context_to_conversation_id(object.data["context"])      expected = %{        "activity_type" => "post", @@ -46,15 +153,21 @@ defmodule Pleroma.Web.TwitterAPI.ActivityViewTest do        "possibly_sensitive" => false,        "repeat_num" => 0,        "repeated" => false, +      "pinned" => false,        "statusnet_conversation_id" => convo_id, +      "summary" => "", +      "summary_html" => "",        "statusnet_html" => -        "Hey <span><a href=\"#{other_user.ap_id}\">@<span>shp</span></a></span>!", +        "Hey <span class=\"h-card\"><a data-user=\"#{other_user.id}\" class=\"u-url mention\" href=\"#{ +          other_user.ap_id +        }\">@<span>shp</span></a></span>!",        "tags" => [],        "text" => "Hey @shp!",        "uri" => object.data["id"],        "user" => UserView.render("show.json", %{user: user}),        "visibility" => "direct", -      "summary" => nil +      "card" => nil, +      "muted" => false      }      assert result == expected @@ -66,12 +179,12 @@ defmodule Pleroma.Web.TwitterAPI.ActivityViewTest do      {:ok, activity} = CommonAPI.post(user, %{"status" => "Hey @shp!"})      object = Object.normalize(activity.data["object"]) -    convo_id = TwitterAPI.context_to_conversation_id(object.data["context"]) +    convo_id = Utils.context_to_conversation_id(object.data["context"])      mocks = [        { -        TwitterAPI, -        [], +        Utils, +        [:passthrough],          [context_to_conversation_id: fn _ -> false end]        },        { @@ -86,7 +199,7 @@ defmodule Pleroma.Web.TwitterAPI.ActivityViewTest do        assert result["statusnet_conversation_id"] == convo_id        assert result["user"] -      refute called(TwitterAPI.context_to_conversation_id(:_)) +      refute called(Utils.context_to_conversation_id(:_))        refute called(User.get_cached_by_ap_id(user.ap_id))        refute called(User.get_cached_by_ap_id(other_user.ap_id))      end @@ -114,6 +227,7 @@ defmodule Pleroma.Web.TwitterAPI.ActivityViewTest do      {:ok, like, _object} = CommonAPI.favorite(activity.id, other_user)      result = ActivityView.render("activity.json", activity: like) +    activity = Pleroma.Activity.get_by_ap_id(activity.data["id"])      expected = %{        "activity_type" => "like", @@ -123,6 +237,7 @@ defmodule Pleroma.Web.TwitterAPI.ActivityViewTest do        "in_reply_to_status_id" => activity.id,        "is_local" => true,        "is_post_verb" => false, +      "favorited_status" => ActivityView.render("activity.json", activity: activity),        "statusnet_html" => "shp favorited a status.",        "text" => "shp favorited a status.",        "uri" => "tag:#{like.data["id"]}:objectType=Favourite", @@ -150,6 +265,7 @@ defmodule Pleroma.Web.TwitterAPI.ActivityViewTest do        "in_reply_to_status_id" => nil,        "is_local" => true,        "is_post_verb" => false, +      "favorited_status" => nil,        "statusnet_html" => "shp favorited a status.",        "text" => "shp favorited a status.",        "uri" => "tag:#{like.data["id"]}:objectType=Favourite", @@ -166,9 +282,9 @@ defmodule Pleroma.Web.TwitterAPI.ActivityViewTest do      {:ok, activity} = CommonAPI.post(user, %{"status" => "Hey @shp!"})      {:ok, announce, object} = CommonAPI.repeat(activity.id, other_user) -    convo_id = TwitterAPI.context_to_conversation_id(object.data["context"]) +    convo_id = Utils.context_to_conversation_id(object.data["context"]) -    activity = Repo.get(Activity, activity.id) +    activity = Activity.get_by_id(activity.id)      result = ActivityView.render("activity.json", activity: announce) @@ -241,4 +357,18 @@ defmodule Pleroma.Web.TwitterAPI.ActivityViewTest do      assert result == expected    end + +  test "a peertube video" do +    {:ok, object} = +      ActivityPub.fetch_object_from_id( +        "https://peertube.moe/videos/watch/df5f464b-be8d-46fb-ad81-2d4c2d1630e3" +      ) + +    %Activity{} = activity = Activity.get_create_by_object_ap_id(object.data["id"]) + +    result = ActivityView.render("activity.json", activity: activity) + +    assert length(result["attachments"]) == 1 +    assert result["summary"] == "Friday Night" +  end  end diff --git a/test/web/twitter_api/views/notification_view_test.exs b/test/web/twitter_api/views/notification_view_test.exs index 79eafda7d..6baeeaf63 100644 --- a/test/web/twitter_api/views/notification_view_test.exs +++ b/test/web/twitter_api/views/notification_view_test.exs @@ -1,14 +1,18 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only +  defmodule Pleroma.Web.TwitterAPI.NotificationViewTest do    use Pleroma.DataCase -  alias Pleroma.{User, Notification} -  alias Pleroma.Web.TwitterAPI.TwitterAPI +  alias Pleroma.Notification +  alias Pleroma.User +  alias Pleroma.Web.ActivityPub.ActivityPub +  alias Pleroma.Web.CommonAPI.Utils +  alias Pleroma.Web.TwitterAPI.ActivityView    alias Pleroma.Web.TwitterAPI.NotificationView +  alias Pleroma.Web.TwitterAPI.TwitterAPI    alias Pleroma.Web.TwitterAPI.UserView -  alias Pleroma.Web.TwitterAPI.ActivityView -  alias Pleroma.Web.CommonAPI.Utils -  alias Pleroma.Web.ActivityPub.ActivityPub -  alias Pleroma.Builders.UserBuilder    import Pleroma.Factory @@ -67,7 +71,7 @@ defmodule Pleroma.Web.TwitterAPI.NotificationViewTest do      user = User.get_cached_by_ap_id(note_activity.data["actor"])      repeater = insert(:user) -    {:ok, activity} = TwitterAPI.repeat(repeater, note_activity.id) +    {:ok, _activity} = TwitterAPI.repeat(repeater, note_activity.id)      [notification] = Notification.for_user(user)      represented = %{ @@ -89,7 +93,7 @@ defmodule Pleroma.Web.TwitterAPI.NotificationViewTest do      user = User.get_cached_by_ap_id(note_activity.data["actor"])      liker = insert(:user) -    {:ok, activity} = TwitterAPI.fav(liker, note_activity.id) +    {:ok, _activity} = TwitterAPI.fav(liker, note_activity.id)      [notification] = Notification.for_user(user)      represented = %{ diff --git a/test/web/twitter_api/views/user_view_test.exs b/test/web/twitter_api/views/user_view_test.exs index e69ca24a9..0feaf4b64 100644 --- a/test/web/twitter_api/views/user_view_test.exs +++ b/test/web/twitter_api/views/user_view_test.exs @@ -1,10 +1,13 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only +  defmodule Pleroma.Web.TwitterAPI.UserViewTest do    use Pleroma.DataCase    alias Pleroma.User -  alias Pleroma.Web.TwitterAPI.UserView    alias Pleroma.Web.CommonAPI.Utils -  alias Pleroma.Builders.UserBuilder +  alias Pleroma.Web.TwitterAPI.UserView    import Pleroma.Factory @@ -27,7 +30,7 @@ defmodule Pleroma.Web.TwitterAPI.UserViewTest do      assert represented["profile_image_url"] == image    end -  test "A user with emoji in username", %{user: user} do +  test "A user with emoji in username" do      expected =        "<img height=\"32px\" width=\"32px\" alt=\"karjalanpiirakka\" title=\"karjalanpiirakka\" src=\"/file.png\" /> man" @@ -87,7 +90,8 @@ defmodule Pleroma.Web.TwitterAPI.UserViewTest do        "follows_you" => false,        "statusnet_blocking" => false,        "rights" => %{ -        "delete_others_notice" => false +        "delete_others_notice" => false, +        "admin" => false        },        "statusnet_profile_url" => user.ap_id,        "cover_photo" => banner, @@ -96,7 +100,13 @@ defmodule Pleroma.Web.TwitterAPI.UserViewTest do        "locked" => false,        "default_scope" => "public",        "no_rich_text" => false, -      "fields" => [] +      "hide_follows" => false, +      "hide_followers" => false, +      "fields" => [], +      "pleroma" => %{ +        "confirmation_pending" => false, +        "tags" => [] +      }      }      assert represented == UserView.render("show.json", %{user: user}) @@ -128,7 +138,8 @@ defmodule Pleroma.Web.TwitterAPI.UserViewTest do        "follows_you" => false,        "statusnet_blocking" => false,        "rights" => %{ -        "delete_others_notice" => false +        "delete_others_notice" => false, +        "admin" => false        },        "statusnet_profile_url" => user.ap_id,        "cover_photo" => banner, @@ -137,7 +148,13 @@ defmodule Pleroma.Web.TwitterAPI.UserViewTest do        "locked" => false,        "default_scope" => "public",        "no_rich_text" => false, -      "fields" => [] +      "hide_follows" => false, +      "hide_followers" => false, +      "fields" => [], +      "pleroma" => %{ +        "confirmation_pending" => false, +        "tags" => [] +      }      }      assert represented == UserView.render("show.json", %{user: user, for: follower}) @@ -170,7 +187,8 @@ defmodule Pleroma.Web.TwitterAPI.UserViewTest do        "follows_you" => true,        "statusnet_blocking" => false,        "rights" => %{ -        "delete_others_notice" => false +        "delete_others_notice" => false, +        "admin" => false        },        "statusnet_profile_url" => follower.ap_id,        "cover_photo" => banner, @@ -179,7 +197,13 @@ defmodule Pleroma.Web.TwitterAPI.UserViewTest do        "locked" => false,        "default_scope" => "public",        "no_rich_text" => false, -      "fields" => [] +      "hide_follows" => false, +      "hide_followers" => false, +      "fields" => [], +      "pleroma" => %{ +        "confirmation_pending" => false, +        "tags" => [] +      }      }      assert represented == UserView.render("show.json", %{user: follower, for: user}) @@ -190,6 +214,36 @@ defmodule Pleroma.Web.TwitterAPI.UserViewTest do      represented = UserView.render("show.json", %{user: user, for: user})      assert represented["rights"]["delete_others_notice"] +    assert represented["role"] == "moderator" +  end + +  test "a user that is a admin" do +    user = insert(:user, %{info: %{is_admin: true}}) +    represented = UserView.render("show.json", %{user: user, for: user}) + +    assert represented["rights"]["admin"] +    assert represented["role"] == "admin" +  end + +  test "A moderator with hidden role for another user", %{user: user} do +    admin = insert(:user, %{info: %{is_moderator: true, show_role: false}}) +    represented = UserView.render("show.json", %{user: admin, for: user}) + +    assert represented["role"] == nil +  end + +  test "An admin with hidden role for another user", %{user: user} do +    admin = insert(:user, %{info: %{is_admin: true, show_role: false}}) +    represented = UserView.render("show.json", %{user: admin, for: user}) + +    assert represented["role"] == nil +  end + +  test "A regular user for the admin", %{user: user} do +    admin = insert(:user, %{info: %{is_admin: true}}) +    represented = UserView.render("show.json", %{user: user, for: admin}) + +    assert represented["pleroma"]["deactivated"] == false    end    test "A blocked user for the blocker" do @@ -219,7 +273,8 @@ defmodule Pleroma.Web.TwitterAPI.UserViewTest do        "follows_you" => false,        "statusnet_blocking" => true,        "rights" => %{ -        "delete_others_notice" => false +        "delete_others_notice" => false, +        "admin" => false        },        "statusnet_profile_url" => user.ap_id,        "cover_photo" => banner, @@ -228,10 +283,16 @@ defmodule Pleroma.Web.TwitterAPI.UserViewTest do        "locked" => false,        "default_scope" => "public",        "no_rich_text" => false, -      "fields" => [] +      "hide_follows" => false, +      "hide_followers" => false, +      "fields" => [], +      "pleroma" => %{ +        "confirmation_pending" => false, +        "tags" => [] +      }      } -    blocker = Repo.get(User, blocker.id) +    blocker = User.get_by_id(blocker.id)      assert represented == UserView.render("show.json", %{user: user, for: blocker})    end | 
