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 "is_moderator" => false,
103 "default_scope" => "public",
104 "no_rich_text" => false,
105 "hide_followings" => false,
106 "hide_followers" => false,
109 "confirmation_pending" => false,
114 assert represented == UserView.render("show.json", %{user: user})
117 test "A user for a given other follower", %{user: user} do
118 follower = insert(:user, %{following: [User.ap_followers(user)]})
119 {:ok, user} = User.update_follower_count(user)
120 image = "http://localhost:4001/images/avi.png"
121 banner = "http://localhost:4001/images/banner.png"
126 "screen_name" => user.nickname,
127 "name_html" => user.name,
128 "description" => HtmlSanitizeEx.strip_tags(user.bio |> String.replace("<br>", "\n")),
129 "description_html" => HtmlSanitizeEx.basic_html(user.bio),
130 "created_at" => user.inserted_at |> Utils.format_naive_asctime(),
131 "favourites_count" => 0,
132 "statuses_count" => 0,
133 "friends_count" => 0,
134 "followers_count" => 1,
135 "profile_image_url" => image,
136 "profile_image_url_https" => image,
137 "profile_image_url_profile_size" => image,
138 "profile_image_url_original" => image,
140 "follows_you" => false,
141 "statusnet_blocking" => false,
143 "delete_others_notice" => false,
146 "statusnet_profile_url" => user.ap_id,
147 "cover_photo" => banner,
148 "background_image" => nil,
151 "is_moderator" => false,
153 "default_scope" => "public",
154 "no_rich_text" => false,
155 "hide_followings" => false,
156 "hide_followers" => false,
159 "confirmation_pending" => false,
164 assert represented == UserView.render("show.json", %{user: user, for: follower})
167 test "A user that follows you", %{user: user} do
168 follower = insert(:user)
169 {:ok, follower} = User.follow(follower, user)
170 {:ok, user} = User.update_follower_count(user)
171 image = "http://localhost:4001/images/avi.png"
172 banner = "http://localhost:4001/images/banner.png"
176 "name" => follower.name,
177 "screen_name" => follower.nickname,
178 "name_html" => follower.name,
179 "description" => HtmlSanitizeEx.strip_tags(follower.bio |> String.replace("<br>", "\n")),
180 "description_html" => HtmlSanitizeEx.basic_html(follower.bio),
181 "created_at" => follower.inserted_at |> Utils.format_naive_asctime(),
182 "favourites_count" => 0,
183 "statuses_count" => 0,
184 "friends_count" => 1,
185 "followers_count" => 0,
186 "profile_image_url" => image,
187 "profile_image_url_https" => image,
188 "profile_image_url_profile_size" => image,
189 "profile_image_url_original" => image,
190 "following" => false,
191 "follows_you" => true,
192 "statusnet_blocking" => false,
194 "delete_others_notice" => false,
197 "statusnet_profile_url" => follower.ap_id,
198 "cover_photo" => banner,
199 "background_image" => nil,
202 "is_moderator" => false,
204 "default_scope" => "public",
205 "no_rich_text" => false,
206 "hide_followings" => false,
207 "hide_followers" => false,
210 "confirmation_pending" => false,
215 assert represented == UserView.render("show.json", %{user: follower, for: user})
218 test "a user that is a moderator" do
219 user = insert(:user, %{info: %{is_moderator: true}})
220 represented = UserView.render("show.json", %{user: user, for: user})
222 assert represented["rights"]["delete_others_notice"]
225 test "a user that is a admin" do
226 user = insert(:user, %{info: %{is_admin: true}})
227 represented = UserView.render("show.json", %{user: user, for: user})
229 assert represented["rights"]["admin"]
232 test "A blocked user for the blocker" do
234 blocker = insert(:user)
235 User.block(blocker, user)
236 image = "http://localhost:4001/images/avi.png"
237 banner = "http://localhost:4001/images/banner.png"
242 "screen_name" => user.nickname,
243 "name_html" => user.name,
244 "description" => HtmlSanitizeEx.strip_tags(user.bio |> String.replace("<br>", "\n")),
245 "description_html" => HtmlSanitizeEx.basic_html(user.bio),
246 "created_at" => user.inserted_at |> Utils.format_naive_asctime(),
247 "favourites_count" => 0,
248 "statuses_count" => 0,
249 "friends_count" => 0,
250 "followers_count" => 0,
251 "profile_image_url" => image,
252 "profile_image_url_https" => image,
253 "profile_image_url_profile_size" => image,
254 "profile_image_url_original" => image,
255 "following" => false,
256 "follows_you" => false,
257 "statusnet_blocking" => true,
259 "delete_others_notice" => false,
262 "statusnet_profile_url" => user.ap_id,
263 "cover_photo" => banner,
264 "background_image" => nil,
267 "is_moderator" => false,
269 "default_scope" => "public",
270 "no_rich_text" => false,
271 "hide_followings" => false,
272 "hide_followers" => false,
275 "confirmation_pending" => false,
280 blocker = Repo.get(User, blocker.id)
281 assert represented == UserView.render("show.json", %{user: user, for: blocker})
284 test "a user with mastodon fields" do
287 "name" => "Pronouns",
292 "value" => "https://example.org/"
301 Enum.map(fields, fn field -> Map.put(field, "type", "PropertyValue") end)
306 userview = UserView.render("show.json", %{user: user})
307 assert userview["fields"] == fields