1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
5 defmodule Pleroma.Web.ActivityPub.UserViewTest do
10 alias Pleroma.Web.ActivityPub.UserView
11 alias Pleroma.Web.CommonAPI
13 test "Renders a user, including the public key" do
15 {:ok, user} = User.ensure_keys_present(user)
17 result = UserView.render("user.json", %{user: user})
19 assert result["id"] == user.ap_id
20 assert result["preferredUsername"] == user.nickname
22 assert String.contains?(result["publicKey"]["publicKeyPem"], "BEGIN PUBLIC KEY")
25 test "Renders profile fields" do
27 %{"name" => "foo", "value" => "bar"}
32 |> User.upgrade_changeset(%{info: %{fields: fields}})
33 |> User.update_and_set_cache()
36 "attachment" => [%{"name" => "foo", "type" => "PropertyValue", "value" => "bar"}]
37 } = UserView.render("user.json", %{user: user})
40 test "Renders with emoji tags" do
41 user = insert(:user, %{info: %{emoji: [%{"bib" => "/test"}]}})
46 "icon" => %{"type" => "Image", "url" => "/test"},
50 "updated" => "1970-01-01T00:00:00Z"
53 } = UserView.render("user.json", %{user: user})
56 test "Does not add an avatar image if the user hasn't set one" do
58 {:ok, user} = User.ensure_keys_present(user)
60 result = UserView.render("user.json", %{user: user})
62 refute result["image"]
66 avatar: %{"url" => [%{"href" => "https://someurl"}]},
68 banner: %{"url" => [%{"href" => "https://somebanner"}]}
72 {:ok, user} = User.ensure_keys_present(user)
74 result = UserView.render("user.json", %{user: user})
75 assert result["icon"]["url"] == "https://someurl"
76 assert result["image"]["url"] == "https://somebanner"
79 describe "endpoints" do
80 test "local users have a usable endpoints structure" do
82 {:ok, user} = User.ensure_keys_present(user)
84 result = UserView.render("user.json", %{user: user})
86 assert result["id"] == user.ap_id
90 "oauthAuthorizationEndpoint" => _,
91 "oauthRegistrationEndpoint" => _,
92 "oauthTokenEndpoint" => _
93 } = result["endpoints"]
96 test "remote users have an empty endpoints structure" do
97 user = insert(:user, local: false)
98 {:ok, user} = User.ensure_keys_present(user)
100 result = UserView.render("user.json", %{user: user})
102 assert result["id"] == user.ap_id
103 assert result["endpoints"] == %{}
106 test "instance users do not expose oAuth endpoints" do
107 user = insert(:user, nickname: nil, local: true)
108 {:ok, user} = User.ensure_keys_present(user)
110 result = UserView.render("user.json", %{user: user})
112 refute result["endpoints"]["oauthAuthorizationEndpoint"]
113 refute result["endpoints"]["oauthRegistrationEndpoint"]
114 refute result["endpoints"]["oauthTokenEndpoint"]
118 describe "followers" do
119 test "sets totalItems to zero when followers are hidden" do
121 other_user = insert(:user)
122 {:ok, _other_user, user, _activity} = CommonAPI.follow(other_user, user)
123 assert %{"totalItems" => 1} = UserView.render("followers.json", %{user: user})
124 info = Map.put(user.info, :hide_followers, true)
125 user = Map.put(user, :info, info)
126 assert %{"totalItems" => 0} = UserView.render("followers.json", %{user: user})
130 describe "following" do
131 test "sets totalItems to zero when follows are hidden" do
133 other_user = insert(:user)
134 {:ok, user, _other_user, _activity} = CommonAPI.follow(user, other_user)
135 assert %{"totalItems" => 1} = UserView.render("following.json", %{user: user})
136 info = Map.put(user.info, :hide_follows, true)
137 user = Map.put(user, :info, info)
138 assert %{"totalItems" => 0} = UserView.render("following.json", %{user: user})