1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
5 defmodule Pleroma.Web.TwitterAPI.UserViewTest do
9 alias Pleroma.Web.TwitterAPI.UserView
10 alias Pleroma.Web.CommonAPI.Utils
12 import Pleroma.Factory
15 user = insert(:user, bio: "<span>Here's some html</span>")
19 test "A user with only a nickname", %{user: user} do
20 user = %{user | name: nil, nickname: "scarlett@catgirl.science"}
21 represented = UserView.render("show.json", %{user: user})
22 assert represented["name"] == user.nickname
23 assert represented["name_html"] == user.nickname
26 test "A user with an avatar object", %{user: user} do
28 user = %{user | avatar: %{"url" => [%{"href" => image}]}}
29 represented = UserView.render("show.json", %{user: user})
30 assert represented["profile_image_url"] == image
33 test "A user with emoji in username" do
35 "<img height=\"32px\" width=\"32px\" alt=\"karjalanpiirakka\" title=\"karjalanpiirakka\" src=\"/file.png\" /> man"
44 "icon" => %{"url" => "/file.png"},
45 "name" => ":karjalanpiirakka:"
50 name: ":karjalanpiirakka: man"
53 represented = UserView.render("show.json", %{user: user})
54 assert represented["name_html"] == expected
58 note_activity = insert(:note_activity)
59 user = User.get_cached_by_ap_id(note_activity.data["actor"])
60 {:ok, user} = User.update_note_count(user)
61 follower = insert(:user)
62 second_follower = insert(:user)
64 User.follow(follower, user)
65 User.follow(second_follower, user)
66 User.follow(user, follower)
67 {:ok, user} = User.update_follower_count(user)
68 Cachex.put(:user_cache, "user_info:#{user.id}", User.user_info(Repo.get!(User, user.id)))
70 image = "http://localhost:4001/images/avi.png"
71 banner = "http://localhost:4001/images/banner.png"
76 "screen_name" => user.nickname,
77 "name_html" => user.name,
78 "description" => HtmlSanitizeEx.strip_tags(user.bio |> String.replace("<br>", "\n")),
79 "description_html" => HtmlSanitizeEx.basic_html(user.bio),
80 "created_at" => user.inserted_at |> Utils.format_naive_asctime(),
81 "favourites_count" => 0,
82 "statuses_count" => 1,
84 "followers_count" => 2,
85 "profile_image_url" => image,
86 "profile_image_url_https" => image,
87 "profile_image_url_profile_size" => image,
88 "profile_image_url_original" => image,
90 "follows_you" => false,
91 "statusnet_blocking" => false,
93 "delete_others_notice" => false,
96 "statusnet_profile_url" => user.ap_id,
97 "cover_photo" => banner,
98 "background_image" => nil,
101 "default_scope" => "public",
102 "no_rich_text" => false,
103 "hide_network" => false,
106 "confirmation_pending" => false,
111 assert represented == UserView.render("show.json", %{user: user})
114 test "A user for a given other follower", %{user: user} do
115 follower = insert(:user, %{following: [User.ap_followers(user)]})
116 {:ok, user} = User.update_follower_count(user)
117 image = "http://localhost:4001/images/avi.png"
118 banner = "http://localhost:4001/images/banner.png"
123 "screen_name" => user.nickname,
124 "name_html" => user.name,
125 "description" => HtmlSanitizeEx.strip_tags(user.bio |> String.replace("<br>", "\n")),
126 "description_html" => HtmlSanitizeEx.basic_html(user.bio),
127 "created_at" => user.inserted_at |> Utils.format_naive_asctime(),
128 "favourites_count" => 0,
129 "statuses_count" => 0,
130 "friends_count" => 0,
131 "followers_count" => 1,
132 "profile_image_url" => image,
133 "profile_image_url_https" => image,
134 "profile_image_url_profile_size" => image,
135 "profile_image_url_original" => image,
137 "follows_you" => false,
138 "statusnet_blocking" => false,
140 "delete_others_notice" => false,
143 "statusnet_profile_url" => user.ap_id,
144 "cover_photo" => banner,
145 "background_image" => nil,
148 "default_scope" => "public",
149 "no_rich_text" => false,
150 "hide_network" => false,
153 "confirmation_pending" => false,
158 assert represented == UserView.render("show.json", %{user: user, for: follower})
161 test "A user that follows you", %{user: user} do
162 follower = insert(:user)
163 {:ok, follower} = User.follow(follower, user)
164 {:ok, user} = User.update_follower_count(user)
165 image = "http://localhost:4001/images/avi.png"
166 banner = "http://localhost:4001/images/banner.png"
170 "name" => follower.name,
171 "screen_name" => follower.nickname,
172 "name_html" => follower.name,
173 "description" => HtmlSanitizeEx.strip_tags(follower.bio |> String.replace("<br>", "\n")),
174 "description_html" => HtmlSanitizeEx.basic_html(follower.bio),
175 "created_at" => follower.inserted_at |> Utils.format_naive_asctime(),
176 "favourites_count" => 0,
177 "statuses_count" => 0,
178 "friends_count" => 1,
179 "followers_count" => 0,
180 "profile_image_url" => image,
181 "profile_image_url_https" => image,
182 "profile_image_url_profile_size" => image,
183 "profile_image_url_original" => image,
184 "following" => false,
185 "follows_you" => true,
186 "statusnet_blocking" => false,
188 "delete_others_notice" => false,
191 "statusnet_profile_url" => follower.ap_id,
192 "cover_photo" => banner,
193 "background_image" => nil,
196 "default_scope" => "public",
197 "no_rich_text" => false,
198 "hide_network" => false,
201 "confirmation_pending" => false,
206 assert represented == UserView.render("show.json", %{user: follower, for: user})
209 test "a user that is a moderator" do
210 user = insert(:user, %{info: %{is_moderator: true}})
211 represented = UserView.render("show.json", %{user: user, for: user})
213 assert represented["rights"]["delete_others_notice"]
216 test "a user that is a admin" do
217 user = insert(:user, %{info: %{is_admin: true}})
218 represented = UserView.render("show.json", %{user: user, for: user})
220 assert represented["rights"]["admin"]
223 test "A blocked user for the blocker" do
225 blocker = insert(:user)
226 User.block(blocker, user)
227 image = "http://localhost:4001/images/avi.png"
228 banner = "http://localhost:4001/images/banner.png"
233 "screen_name" => user.nickname,
234 "name_html" => user.name,
235 "description" => HtmlSanitizeEx.strip_tags(user.bio |> String.replace("<br>", "\n")),
236 "description_html" => HtmlSanitizeEx.basic_html(user.bio),
237 "created_at" => user.inserted_at |> Utils.format_naive_asctime(),
238 "favourites_count" => 0,
239 "statuses_count" => 0,
240 "friends_count" => 0,
241 "followers_count" => 0,
242 "profile_image_url" => image,
243 "profile_image_url_https" => image,
244 "profile_image_url_profile_size" => image,
245 "profile_image_url_original" => image,
246 "following" => false,
247 "follows_you" => false,
248 "statusnet_blocking" => true,
250 "delete_others_notice" => false,
253 "statusnet_profile_url" => user.ap_id,
254 "cover_photo" => banner,
255 "background_image" => nil,
258 "default_scope" => "public",
259 "no_rich_text" => false,
260 "hide_network" => false,
263 "confirmation_pending" => false,
268 blocker = Repo.get(User, blocker.id)
269 assert represented == UserView.render("show.json", %{user: user, for: blocker})
272 test "a user with mastodon fields" do
275 "name" => "Pronouns",
280 "value" => "https://example.org/"
289 Enum.map(fields, fn field -> Map.put(field, "type", "PropertyValue") end)
294 userview = UserView.render("show.json", %{user: user})
295 assert userview["fields"] == fields