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"},
28 %{"name" => "website", "value" => "cofe.my"}
31 user = insert(:user, info: %{fields: fields})
35 %{"name" => "foo", "type" => "PropertyValue", "value" => "bar"},
36 %{"name" => "website", "type" => "PropertyValue", "value" => "cofe.my"}
38 } = UserView.render("user.json", %{user: user})
41 test "Does not add an avatar image if the user hasn't set one" do
43 {:ok, user} = User.ensure_keys_present(user)
45 result = UserView.render("user.json", %{user: user})
47 refute result["image"]
51 avatar: %{"url" => [%{"href" => "https://someurl"}]},
53 banner: %{"url" => [%{"href" => "https://somebanner"}]}
57 {:ok, user} = User.ensure_keys_present(user)
59 result = UserView.render("user.json", %{user: user})
60 assert result["icon"]["url"] == "https://someurl"
61 assert result["image"]["url"] == "https://somebanner"
64 describe "endpoints" do
65 test "local users have a usable endpoints structure" do
67 {:ok, user} = User.ensure_keys_present(user)
69 result = UserView.render("user.json", %{user: user})
71 assert result["id"] == user.ap_id
75 "oauthAuthorizationEndpoint" => _,
76 "oauthRegistrationEndpoint" => _,
77 "oauthTokenEndpoint" => _
78 } = result["endpoints"]
81 test "remote users have an empty endpoints structure" do
82 user = insert(:user, local: false)
83 {:ok, user} = User.ensure_keys_present(user)
85 result = UserView.render("user.json", %{user: user})
87 assert result["id"] == user.ap_id
88 assert result["endpoints"] == %{}
91 test "instance users do not expose oAuth endpoints" do
92 user = insert(:user, nickname: nil, local: true)
93 {:ok, user} = User.ensure_keys_present(user)
95 result = UserView.render("user.json", %{user: user})
97 refute result["endpoints"]["oauthAuthorizationEndpoint"]
98 refute result["endpoints"]["oauthRegistrationEndpoint"]
99 refute result["endpoints"]["oauthTokenEndpoint"]
103 describe "followers" do
104 test "sets totalItems to zero when followers are hidden" do
106 other_user = insert(:user)
107 {:ok, _other_user, user, _activity} = CommonAPI.follow(other_user, user)
108 assert %{"totalItems" => 1} = UserView.render("followers.json", %{user: user})
109 info = Map.put(user.info, :hide_followers, true)
110 user = Map.put(user, :info, info)
111 assert %{"totalItems" => 0} = UserView.render("followers.json", %{user: user})
115 describe "following" do
116 test "sets totalItems to zero when follows are hidden" do
118 other_user = insert(:user)
119 {:ok, user, _other_user, _activity} = CommonAPI.follow(user, other_user)
120 assert %{"totalItems" => 1} = UserView.render("following.json", %{user: user})
121 info = Map.put(user.info, :hide_follows, true)
122 user = Map.put(user, :info, info)
123 assert %{"totalItems" => 0} = UserView.render("following.json", %{user: user})