Merge branch 'followup/twitterapi-no-rich-text-field' into 'develop'
[akkoma] / test / web / twitter_api / views / user_view_test.exs
1 defmodule Pleroma.Web.TwitterAPI.UserViewTest do
2 use Pleroma.DataCase
3
4 alias Pleroma.User
5 alias Pleroma.Web.TwitterAPI.UserView
6 alias Pleroma.Web.CommonAPI.Utils
7 alias Pleroma.Builders.UserBuilder
8
9 import Pleroma.Factory
10
11 setup do
12 user = insert(:user, bio: "<span>Here's some html</span>")
13 [user: user]
14 end
15
16 test "A user with an avatar object", %{user: user} do
17 image = "image"
18 user = %{user | avatar: %{"url" => [%{"href" => image}]}}
19 represented = UserView.render("show.json", %{user: user})
20 assert represented["profile_image_url"] == image
21 end
22
23 test "A user with emoji in username", %{user: user} do
24 expected =
25 "<img height=\"32px\" width=\"32px\" alt=\"karjalanpiirakka\" title=\"karjalanpiirakka\" src=\"/file.png\" /> man"
26
27 user = %{
28 user
29 | info: %{
30 "source_data" => %{
31 "tag" => [
32 %{
33 "type" => "Emoji",
34 "icon" => %{"url" => "/file.png"},
35 "name" => ":karjalanpiirakka:"
36 }
37 ]
38 }
39 }
40 }
41
42 user = %{user | name: ":karjalanpiirakka: man"}
43 represented = UserView.render("show.json", %{user: user})
44 assert represented["name_html"] == expected
45 end
46
47 test "A user" do
48 note_activity = insert(:note_activity)
49 user = User.get_cached_by_ap_id(note_activity.data["actor"])
50 {:ok, user} = User.update_note_count(user)
51 follower = insert(:user)
52 second_follower = insert(:user)
53
54 User.follow(follower, user)
55 User.follow(second_follower, user)
56 User.follow(user, follower)
57 {:ok, user} = User.update_follower_count(user)
58 Cachex.put(:user_cache, "user_info:#{user.id}", User.user_info(Repo.get!(User, user.id)))
59
60 image = "http://localhost:4001/images/avi.png"
61 banner = "http://localhost:4001/images/banner.png"
62
63 represented = %{
64 "id" => user.id,
65 "name" => user.name,
66 "screen_name" => user.nickname,
67 "name_html" => user.name,
68 "description" => HtmlSanitizeEx.strip_tags(user.bio |> String.replace("<br>", "\n")),
69 "description_html" => HtmlSanitizeEx.basic_html(user.bio),
70 "created_at" => user.inserted_at |> Utils.format_naive_asctime(),
71 "favourites_count" => 0,
72 "statuses_count" => 1,
73 "friends_count" => 1,
74 "followers_count" => 2,
75 "profile_image_url" => image,
76 "profile_image_url_https" => image,
77 "profile_image_url_profile_size" => image,
78 "profile_image_url_original" => image,
79 "following" => false,
80 "follows_you" => false,
81 "statusnet_blocking" => false,
82 "rights" => %{
83 "delete_others_notice" => false
84 },
85 "statusnet_profile_url" => user.ap_id,
86 "cover_photo" => banner,
87 "background_image" => nil,
88 "is_local" => true,
89 "locked" => false,
90 "default_scope" => "public",
91 "no_rich_text" => false
92 }
93
94 assert represented == UserView.render("show.json", %{user: user})
95 end
96
97 test "A user for a given other follower", %{user: user} do
98 {:ok, follower} = UserBuilder.insert(%{following: [User.ap_followers(user)]})
99 {:ok, user} = User.update_follower_count(user)
100 image = "http://localhost:4001/images/avi.png"
101 banner = "http://localhost:4001/images/banner.png"
102
103 represented = %{
104 "id" => user.id,
105 "name" => user.name,
106 "screen_name" => user.nickname,
107 "name_html" => user.name,
108 "description" => HtmlSanitizeEx.strip_tags(user.bio |> String.replace("<br>", "\n")),
109 "description_html" => HtmlSanitizeEx.basic_html(user.bio),
110 "created_at" => user.inserted_at |> Utils.format_naive_asctime(),
111 "favourites_count" => 0,
112 "statuses_count" => 0,
113 "friends_count" => 0,
114 "followers_count" => 1,
115 "profile_image_url" => image,
116 "profile_image_url_https" => image,
117 "profile_image_url_profile_size" => image,
118 "profile_image_url_original" => image,
119 "following" => true,
120 "follows_you" => false,
121 "statusnet_blocking" => false,
122 "rights" => %{
123 "delete_others_notice" => false
124 },
125 "statusnet_profile_url" => user.ap_id,
126 "cover_photo" => banner,
127 "background_image" => nil,
128 "is_local" => true,
129 "locked" => false,
130 "default_scope" => "public",
131 "no_rich_text" => false
132 }
133
134 assert represented == UserView.render("show.json", %{user: user, for: follower})
135 end
136
137 test "A user that follows you", %{user: user} do
138 follower = insert(:user)
139 {:ok, follower} = User.follow(follower, user)
140 {:ok, user} = User.update_follower_count(user)
141 image = "http://localhost:4001/images/avi.png"
142 banner = "http://localhost:4001/images/banner.png"
143
144 represented = %{
145 "id" => follower.id,
146 "name" => follower.name,
147 "screen_name" => follower.nickname,
148 "name_html" => follower.name,
149 "description" => HtmlSanitizeEx.strip_tags(follower.bio |> String.replace("<br>", "\n")),
150 "description_html" => HtmlSanitizeEx.basic_html(follower.bio),
151 "created_at" => follower.inserted_at |> Utils.format_naive_asctime(),
152 "favourites_count" => 0,
153 "statuses_count" => 0,
154 "friends_count" => 1,
155 "followers_count" => 0,
156 "profile_image_url" => image,
157 "profile_image_url_https" => image,
158 "profile_image_url_profile_size" => image,
159 "profile_image_url_original" => image,
160 "following" => false,
161 "follows_you" => true,
162 "statusnet_blocking" => false,
163 "rights" => %{
164 "delete_others_notice" => false
165 },
166 "statusnet_profile_url" => follower.ap_id,
167 "cover_photo" => banner,
168 "background_image" => nil,
169 "is_local" => true,
170 "locked" => false,
171 "default_scope" => "public",
172 "no_rich_text" => false
173 }
174
175 assert represented == UserView.render("show.json", %{user: follower, for: user})
176 end
177
178 test "a user that is a moderator" do
179 user = insert(:user, %{info: %{"is_moderator" => true}})
180 represented = UserView.render("show.json", %{user: user, for: user})
181
182 assert represented["rights"]["delete_others_notice"]
183 end
184
185 test "A blocked user for the blocker" do
186 user = insert(:user)
187 blocker = insert(:user)
188 User.block(blocker, user)
189 image = "http://localhost:4001/images/avi.png"
190 banner = "http://localhost:4001/images/banner.png"
191
192 represented = %{
193 "id" => user.id,
194 "name" => user.name,
195 "screen_name" => user.nickname,
196 "name_html" => user.name,
197 "description" => HtmlSanitizeEx.strip_tags(user.bio |> String.replace("<br>", "\n")),
198 "description_html" => HtmlSanitizeEx.basic_html(user.bio),
199 "created_at" => user.inserted_at |> Utils.format_naive_asctime(),
200 "favourites_count" => 0,
201 "statuses_count" => 0,
202 "friends_count" => 0,
203 "followers_count" => 0,
204 "profile_image_url" => image,
205 "profile_image_url_https" => image,
206 "profile_image_url_profile_size" => image,
207 "profile_image_url_original" => image,
208 "following" => false,
209 "follows_you" => false,
210 "statusnet_blocking" => true,
211 "rights" => %{
212 "delete_others_notice" => false
213 },
214 "statusnet_profile_url" => user.ap_id,
215 "cover_photo" => banner,
216 "background_image" => nil,
217 "is_local" => true,
218 "locked" => false,
219 "default_scope" => "public",
220 "no_rich_text" => false
221 }
222
223 blocker = Repo.get(User, blocker.id)
224 assert represented == UserView.render("show.json", %{user: user, for: blocker})
225 end
226 end