Merge branch 'fix_486' into 'develop'
[akkoma] / test / web / twitter_api / views / user_view_test.exs
1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
4
5 defmodule Pleroma.Web.TwitterAPI.UserViewTest do
6 use Pleroma.DataCase
7
8 alias Pleroma.User
9 alias Pleroma.Web.TwitterAPI.UserView
10 alias Pleroma.Web.CommonAPI.Utils
11
12 import Pleroma.Factory
13
14 setup do
15 user = insert(:user, bio: "<span>Here's some html</span>")
16 [user: user]
17 end
18
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
24 end
25
26 test "A user with an avatar object", %{user: user} do
27 image = "image"
28 user = %{user | avatar: %{"url" => [%{"href" => image}]}}
29 represented = UserView.render("show.json", %{user: user})
30 assert represented["profile_image_url"] == image
31 end
32
33 test "A user with emoji in username" do
34 expected =
35 "<img height=\"32px\" width=\"32px\" alt=\"karjalanpiirakka\" title=\"karjalanpiirakka\" src=\"/file.png\" /> man"
36
37 user =
38 insert(:user, %{
39 info: %{
40 source_data: %{
41 "tag" => [
42 %{
43 "type" => "Emoji",
44 "icon" => %{"url" => "/file.png"},
45 "name" => ":karjalanpiirakka:"
46 }
47 ]
48 }
49 },
50 name: ":karjalanpiirakka: man"
51 })
52
53 represented = UserView.render("show.json", %{user: user})
54 assert represented["name_html"] == expected
55 end
56
57 test "A user" do
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)
63
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)))
69
70 image = "http://localhost:4001/images/avi.png"
71 banner = "http://localhost:4001/images/banner.png"
72
73 represented = %{
74 "id" => user.id,
75 "name" => user.name,
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,
83 "friends_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,
89 "following" => false,
90 "follows_you" => false,
91 "statusnet_blocking" => false,
92 "rights" => %{
93 "delete_others_notice" => false,
94 "admin" => false
95 },
96 "statusnet_profile_url" => user.ap_id,
97 "cover_photo" => banner,
98 "background_image" => nil,
99 "is_local" => true,
100 "locked" => false,
101 "default_scope" => "public",
102 "no_rich_text" => false,
103 "fields" => [],
104 "pleroma" => %{
105 "confirmation_pending" => false,
106 "tags" => []
107 }
108 }
109
110 assert represented == UserView.render("show.json", %{user: user})
111 end
112
113 test "A user for a given other follower", %{user: user} do
114 follower = insert(:user, %{following: [User.ap_followers(user)]})
115 {:ok, user} = User.update_follower_count(user)
116 image = "http://localhost:4001/images/avi.png"
117 banner = "http://localhost:4001/images/banner.png"
118
119 represented = %{
120 "id" => user.id,
121 "name" => user.name,
122 "screen_name" => user.nickname,
123 "name_html" => user.name,
124 "description" => HtmlSanitizeEx.strip_tags(user.bio |> String.replace("<br>", "\n")),
125 "description_html" => HtmlSanitizeEx.basic_html(user.bio),
126 "created_at" => user.inserted_at |> Utils.format_naive_asctime(),
127 "favourites_count" => 0,
128 "statuses_count" => 0,
129 "friends_count" => 0,
130 "followers_count" => 1,
131 "profile_image_url" => image,
132 "profile_image_url_https" => image,
133 "profile_image_url_profile_size" => image,
134 "profile_image_url_original" => image,
135 "following" => true,
136 "follows_you" => false,
137 "statusnet_blocking" => false,
138 "rights" => %{
139 "delete_others_notice" => false,
140 "admin" => false
141 },
142 "statusnet_profile_url" => user.ap_id,
143 "cover_photo" => banner,
144 "background_image" => nil,
145 "is_local" => true,
146 "locked" => false,
147 "default_scope" => "public",
148 "no_rich_text" => false,
149 "fields" => [],
150 "pleroma" => %{
151 "confirmation_pending" => false,
152 "tags" => []
153 }
154 }
155
156 assert represented == UserView.render("show.json", %{user: user, for: follower})
157 end
158
159 test "A user that follows you", %{user: user} do
160 follower = insert(:user)
161 {:ok, follower} = User.follow(follower, user)
162 {:ok, user} = User.update_follower_count(user)
163 image = "http://localhost:4001/images/avi.png"
164 banner = "http://localhost:4001/images/banner.png"
165
166 represented = %{
167 "id" => follower.id,
168 "name" => follower.name,
169 "screen_name" => follower.nickname,
170 "name_html" => follower.name,
171 "description" => HtmlSanitizeEx.strip_tags(follower.bio |> String.replace("<br>", "\n")),
172 "description_html" => HtmlSanitizeEx.basic_html(follower.bio),
173 "created_at" => follower.inserted_at |> Utils.format_naive_asctime(),
174 "favourites_count" => 0,
175 "statuses_count" => 0,
176 "friends_count" => 1,
177 "followers_count" => 0,
178 "profile_image_url" => image,
179 "profile_image_url_https" => image,
180 "profile_image_url_profile_size" => image,
181 "profile_image_url_original" => image,
182 "following" => false,
183 "follows_you" => true,
184 "statusnet_blocking" => false,
185 "rights" => %{
186 "delete_others_notice" => false,
187 "admin" => false
188 },
189 "statusnet_profile_url" => follower.ap_id,
190 "cover_photo" => banner,
191 "background_image" => nil,
192 "is_local" => true,
193 "locked" => false,
194 "default_scope" => "public",
195 "no_rich_text" => false,
196 "fields" => [],
197 "pleroma" => %{
198 "confirmation_pending" => false,
199 "tags" => []
200 }
201 }
202
203 assert represented == UserView.render("show.json", %{user: follower, for: user})
204 end
205
206 test "a user that is a moderator" do
207 user = insert(:user, %{info: %{is_moderator: true}})
208 represented = UserView.render("show.json", %{user: user, for: user})
209
210 assert represented["rights"]["delete_others_notice"]
211 end
212
213 test "a user that is a admin" do
214 user = insert(:user, %{info: %{is_admin: true}})
215 represented = UserView.render("show.json", %{user: user, for: user})
216
217 assert represented["rights"]["admin"]
218 end
219
220 test "A blocked user for the blocker" do
221 user = insert(:user)
222 blocker = insert(:user)
223 User.block(blocker, user)
224 image = "http://localhost:4001/images/avi.png"
225 banner = "http://localhost:4001/images/banner.png"
226
227 represented = %{
228 "id" => user.id,
229 "name" => user.name,
230 "screen_name" => user.nickname,
231 "name_html" => user.name,
232 "description" => HtmlSanitizeEx.strip_tags(user.bio |> String.replace("<br>", "\n")),
233 "description_html" => HtmlSanitizeEx.basic_html(user.bio),
234 "created_at" => user.inserted_at |> Utils.format_naive_asctime(),
235 "favourites_count" => 0,
236 "statuses_count" => 0,
237 "friends_count" => 0,
238 "followers_count" => 0,
239 "profile_image_url" => image,
240 "profile_image_url_https" => image,
241 "profile_image_url_profile_size" => image,
242 "profile_image_url_original" => image,
243 "following" => false,
244 "follows_you" => false,
245 "statusnet_blocking" => true,
246 "rights" => %{
247 "delete_others_notice" => false,
248 "admin" => false
249 },
250 "statusnet_profile_url" => user.ap_id,
251 "cover_photo" => banner,
252 "background_image" => nil,
253 "is_local" => true,
254 "locked" => false,
255 "default_scope" => "public",
256 "no_rich_text" => false,
257 "fields" => [],
258 "pleroma" => %{
259 "confirmation_pending" => false,
260 "tags" => []
261 }
262 }
263
264 blocker = Repo.get(User, blocker.id)
265 assert represented == UserView.render("show.json", %{user: user, for: blocker})
266 end
267
268 test "a user with mastodon fields" do
269 fields = [
270 %{
271 "name" => "Pronouns",
272 "value" => "she/her"
273 },
274 %{
275 "name" => "Website",
276 "value" => "https://example.org/"
277 }
278 ]
279
280 user =
281 insert(:user, %{
282 info: %{
283 source_data: %{
284 "attachment" =>
285 Enum.map(fields, fn field -> Map.put(field, "type", "PropertyValue") end)
286 }
287 }
288 })
289
290 userview = UserView.render("show.json", %{user: user})
291 assert userview["fields"] == fields
292 end
293 end