Add default_scope to /api/v1/update_credentials
[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.CommonAPI.Utils
10 alias Pleroma.Web.TwitterAPI.UserView
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 "statusnet_profile_url" => user.ap_id,
93 "cover_photo" => banner,
94 "background_image" => nil,
95 "is_local" => true,
96 "locked" => false,
97 "hide_follows" => false,
98 "hide_followers" => false,
99 "fields" => [],
100 "pleroma" => %{
101 "confirmation_pending" => false,
102 "tags" => []
103 }
104 }
105
106 assert represented == UserView.render("show.json", %{user: user})
107 end
108
109 test "User exposes settings for themselves and only for themselves", %{user: user} do
110 as_user = UserView.render("show.json", %{user: user, for: user})
111 assert as_user["default_scope"] == user.info.default_scope
112 assert as_user["no_rich_text"] == user.info.no_rich_text
113 as_stranger = UserView.render("show.json", %{user: user})
114 refute as_stranger["default_scope"]
115 refute as_stranger["no_rich_text"]
116 end
117
118 test "A user for a given other follower", %{user: user} do
119 follower = insert(:user, %{following: [User.ap_followers(user)]})
120 {:ok, user} = User.update_follower_count(user)
121 image = "http://localhost:4001/images/avi.png"
122 banner = "http://localhost:4001/images/banner.png"
123
124 represented = %{
125 "id" => user.id,
126 "name" => user.name,
127 "screen_name" => user.nickname,
128 "name_html" => user.name,
129 "description" => HtmlSanitizeEx.strip_tags(user.bio |> String.replace("<br>", "\n")),
130 "description_html" => HtmlSanitizeEx.basic_html(user.bio),
131 "created_at" => user.inserted_at |> Utils.format_naive_asctime(),
132 "favourites_count" => 0,
133 "statuses_count" => 0,
134 "friends_count" => 0,
135 "followers_count" => 1,
136 "profile_image_url" => image,
137 "profile_image_url_https" => image,
138 "profile_image_url_profile_size" => image,
139 "profile_image_url_original" => image,
140 "following" => true,
141 "follows_you" => false,
142 "statusnet_blocking" => false,
143 "statusnet_profile_url" => user.ap_id,
144 "cover_photo" => banner,
145 "background_image" => nil,
146 "is_local" => true,
147 "locked" => false,
148 "hide_follows" => false,
149 "hide_followers" => false,
150 "fields" => [],
151 "pleroma" => %{
152 "confirmation_pending" => false,
153 "tags" => []
154 }
155 }
156
157 assert represented == UserView.render("show.json", %{user: user, for: follower})
158 end
159
160 test "A user that follows you", %{user: user} do
161 follower = insert(:user)
162 {:ok, follower} = User.follow(follower, user)
163 {:ok, user} = User.update_follower_count(user)
164 image = "http://localhost:4001/images/avi.png"
165 banner = "http://localhost:4001/images/banner.png"
166
167 represented = %{
168 "id" => follower.id,
169 "name" => follower.name,
170 "screen_name" => follower.nickname,
171 "name_html" => follower.name,
172 "description" => HtmlSanitizeEx.strip_tags(follower.bio |> String.replace("<br>", "\n")),
173 "description_html" => HtmlSanitizeEx.basic_html(follower.bio),
174 "created_at" => follower.inserted_at |> Utils.format_naive_asctime(),
175 "favourites_count" => 0,
176 "statuses_count" => 0,
177 "friends_count" => 1,
178 "followers_count" => 0,
179 "profile_image_url" => image,
180 "profile_image_url_https" => image,
181 "profile_image_url_profile_size" => image,
182 "profile_image_url_original" => image,
183 "following" => false,
184 "follows_you" => true,
185 "statusnet_blocking" => false,
186 "statusnet_profile_url" => follower.ap_id,
187 "cover_photo" => banner,
188 "background_image" => nil,
189 "is_local" => true,
190 "locked" => false,
191 "hide_follows" => false,
192 "hide_followers" => false,
193 "fields" => [],
194 "pleroma" => %{
195 "confirmation_pending" => false,
196 "tags" => []
197 }
198 }
199
200 assert represented == UserView.render("show.json", %{user: follower, for: user})
201 end
202
203 test "a user that is a moderator" do
204 user = insert(:user, %{info: %{is_moderator: true}})
205 represented = UserView.render("show.json", %{user: user, for: user})
206
207 assert represented["rights"]["delete_others_notice"]
208 assert represented["role"] == "moderator"
209 end
210
211 test "a user that is a admin" do
212 user = insert(:user, %{info: %{is_admin: true}})
213 represented = UserView.render("show.json", %{user: user, for: user})
214
215 assert represented["rights"]["admin"]
216 assert represented["role"] == "admin"
217 end
218
219 test "A moderator with hidden role for another user", %{user: user} do
220 admin = insert(:user, %{info: %{is_moderator: true, show_role: false}})
221 represented = UserView.render("show.json", %{user: admin, for: user})
222
223 assert represented["role"] == nil
224 end
225
226 test "An admin with hidden role for another user", %{user: user} do
227 admin = insert(:user, %{info: %{is_admin: true, show_role: false}})
228 represented = UserView.render("show.json", %{user: admin, for: user})
229
230 assert represented["role"] == nil
231 end
232
233 test "A regular user for the admin", %{user: user} do
234 admin = insert(:user, %{info: %{is_admin: true}})
235 represented = UserView.render("show.json", %{user: user, for: admin})
236
237 assert represented["pleroma"]["deactivated"] == false
238 end
239
240 test "A blocked user for the blocker" do
241 user = insert(:user)
242 blocker = insert(:user)
243 User.block(blocker, user)
244 image = "http://localhost:4001/images/avi.png"
245 banner = "http://localhost:4001/images/banner.png"
246
247 represented = %{
248 "id" => user.id,
249 "name" => user.name,
250 "screen_name" => user.nickname,
251 "name_html" => user.name,
252 "description" => HtmlSanitizeEx.strip_tags(user.bio |> String.replace("<br>", "\n")),
253 "description_html" => HtmlSanitizeEx.basic_html(user.bio),
254 "created_at" => user.inserted_at |> Utils.format_naive_asctime(),
255 "favourites_count" => 0,
256 "statuses_count" => 0,
257 "friends_count" => 0,
258 "followers_count" => 0,
259 "profile_image_url" => image,
260 "profile_image_url_https" => image,
261 "profile_image_url_profile_size" => image,
262 "profile_image_url_original" => image,
263 "following" => false,
264 "follows_you" => false,
265 "statusnet_blocking" => true,
266 "statusnet_profile_url" => user.ap_id,
267 "cover_photo" => banner,
268 "background_image" => nil,
269 "is_local" => true,
270 "locked" => false,
271 "hide_follows" => false,
272 "hide_followers" => false,
273 "fields" => [],
274 "pleroma" => %{
275 "confirmation_pending" => false,
276 "tags" => []
277 }
278 }
279
280 blocker = User.get_cached_by_id(blocker.id)
281 assert represented == UserView.render("show.json", %{user: user, for: blocker})
282 end
283
284 test "a user with mastodon fields" do
285 fields = [
286 %{
287 "name" => "Pronouns",
288 "value" => "she/her"
289 },
290 %{
291 "name" => "Website",
292 "value" => "https://example.org/"
293 }
294 ]
295
296 user =
297 insert(:user, %{
298 info: %{
299 source_data: %{
300 "attachment" =>
301 Enum.map(fields, fn field -> Map.put(field, "type", "PropertyValue") end)
302 }
303 }
304 })
305
306 userview = UserView.render("show.json", %{user: user})
307 assert userview["fields"] == fields
308 end
309 end