This repository has been archived on 2020-02-06. You can view files and clone it, but cannot push or open issues/pull-requests.
pleroma/test/web/twitter_api/views/user_view_test.exs

324 lines
11 KiB
Elixir
Raw Normal View History

2018-12-23 15:11:29 -05:00
# Pleroma: A lightweight social networking server
# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only
2017-06-19 17:12:37 -04:00
defmodule Pleroma.Web.TwitterAPI.UserViewTest do
2017-03-20 16:30:18 -04:00
use Pleroma.DataCase
alias Pleroma.User
alias Pleroma.Web.CommonAPI.Utils
alias Pleroma.Web.TwitterAPI.UserView
2017-03-20 16:30:18 -04:00
2017-04-16 09:28:28 -04:00
import Pleroma.Factory
2017-03-20 16:30:18 -04:00
setup do
user = insert(:user, bio: "<span>Here's some html</span>")
2017-03-20 16:30:18 -04:00
[user: user]
end
2018-11-12 11:40:34 -05:00
test "A user with only a nickname", %{user: user} do
user = %{user | name: nil, nickname: "scarlett@catgirl.science"}
represented = UserView.render("show.json", %{user: user})
assert represented["name"] == user.nickname
assert represented["name_html"] == user.nickname
end
test "A user with an avatar object", %{user: user} do
image = "image"
2018-03-30 09:01:53 -04:00
user = %{user | avatar: %{"url" => [%{"href" => image}]}}
2017-06-19 17:12:37 -04:00
represented = UserView.render("show.json", %{user: user})
assert represented["profile_image_url"] == image
end
2018-12-11 07:31:52 -05:00
test "A user with emoji in username" do
expected =
"<img class=\"emoji\" alt=\"karjalanpiirakka\" title=\"karjalanpiirakka\" src=\"/file.png\" /> man"
2018-11-30 11:08:02 -05:00
user =
insert(:user, %{
info: %{
source_data: %{
"tag" => [
%{
"type" => "Emoji",
"icon" => %{"url" => "/file.png"},
"name" => ":karjalanpiirakka:"
}
]
}
2018-11-30 11:08:02 -05:00
},
name: ":karjalanpiirakka: man"
})
represented = UserView.render("show.json", %{user: user})
assert represented["name_html"] == expected
end
2017-04-20 18:51:09 -04:00
test "A user" do
note_activity = insert(:note_activity)
user = User.get_cached_by_ap_id(note_activity.data["actor"])
{:ok, user} = User.update_note_count(user)
2017-04-20 18:51:09 -04:00
follower = insert(:user)
second_follower = insert(:user)
User.follow(follower, user)
User.follow(second_follower, user)
User.follow(user, follower)
2017-12-11 14:01:36 -05:00
{:ok, user} = User.update_follower_count(user)
Cachex.put(:user_cache, "user_info:#{user.id}", User.user_info(Repo.get!(User, user.id)))
2017-04-20 18:51:09 -04:00
image = "http://localhost:4001/images/avi.png"
banner = "http://localhost:4001/images/banner.png"
2017-04-16 09:28:28 -04:00
2017-03-20 16:30:18 -04:00
represented = %{
"id" => user.id,
"name" => user.name,
"screen_name" => user.nickname,
"name_html" => user.name,
2018-08-21 10:24:06 -04:00
"description" => HtmlSanitizeEx.strip_tags(user.bio |> String.replace("<br>", "\n")),
"description_html" => HtmlSanitizeEx.basic_html(user.bio),
2018-03-30 09:01:53 -04:00
"created_at" => user.inserted_at |> Utils.format_naive_asctime(),
2017-03-20 16:30:18 -04:00
"favourites_count" => 0,
2017-04-20 18:51:09 -04:00
"statuses_count" => 1,
"friends_count" => 1,
"followers_count" => 2,
2017-03-20 16:30:18 -04:00
"profile_image_url" => image,
"profile_image_url_https" => image,
"profile_image_url_profile_size" => image,
"profile_image_url_original" => image,
"following" => false,
2017-11-08 12:13:03 -05:00
"follows_you" => false,
2017-11-08 06:02:00 -05:00
"statusnet_blocking" => false,
2017-08-29 11:22:22 -04:00
"statusnet_profile_url" => user.ap_id,
"cover_photo" => banner,
2018-02-01 14:41:19 -05:00
"background_image" => nil,
"is_local" => true,
"locked" => false,
"hide_follows" => false,
"hide_followers" => false,
2018-12-06 12:38:52 -05:00
"fields" => [],
"pleroma" => %{
"confirmation_pending" => false,
2019-06-03 15:51:14 -04:00
"tags" => [],
"skip_thread_containment" => false
},
"rights" => %{"admin" => false, "delete_others_notice" => false},
"role" => "member"
2017-03-20 16:30:18 -04:00
}
2017-06-19 17:12:37 -04:00
assert represented == UserView.render("show.json", %{user: user})
2017-03-20 16:30:18 -04:00
end
test "User exposes settings for themselves and only for themselves", %{user: user} do
as_user = UserView.render("show.json", %{user: user, for: user})
assert as_user["default_scope"] == user.info.default_scope
assert as_user["no_rich_text"] == user.info.no_rich_text
assert as_user["pleroma"]["notification_settings"] == user.info.notification_settings
as_stranger = UserView.render("show.json", %{user: user})
refute as_stranger["default_scope"]
refute as_stranger["no_rich_text"]
refute as_stranger["pleroma"]["notification_settings"]
end
test "A user for a given other follower", %{user: user} do
2018-11-30 11:08:02 -05:00
follower = insert(:user, %{following: [User.ap_followers(user)]})
{:ok, user} = User.update_follower_count(user)
image = "http://localhost:4001/images/avi.png"
banner = "http://localhost:4001/images/banner.png"
represented = %{
"id" => user.id,
"name" => user.name,
"screen_name" => user.nickname,
"name_html" => user.name,
2018-08-21 10:24:06 -04:00
"description" => HtmlSanitizeEx.strip_tags(user.bio |> String.replace("<br>", "\n")),
"description_html" => HtmlSanitizeEx.basic_html(user.bio),
2018-03-30 09:01:53 -04:00
"created_at" => user.inserted_at |> Utils.format_naive_asctime(),
"favourites_count" => 0,
"statuses_count" => 0,
"friends_count" => 0,
2017-04-20 18:51:09 -04:00
"followers_count" => 1,
"profile_image_url" => image,
"profile_image_url_https" => image,
"profile_image_url_profile_size" => image,
"profile_image_url_original" => image,
"following" => true,
2017-11-08 12:13:03 -05:00
"follows_you" => false,
2017-11-08 06:02:00 -05:00
"statusnet_blocking" => false,
2017-08-29 11:22:22 -04:00
"statusnet_profile_url" => user.ap_id,
"cover_photo" => banner,
2018-02-01 14:41:19 -05:00
"background_image" => nil,
"is_local" => true,
"locked" => false,
"hide_follows" => false,
"hide_followers" => false,
2018-12-06 12:38:52 -05:00
"fields" => [],
"pleroma" => %{
"confirmation_pending" => false,
2019-06-03 15:51:14 -04:00
"tags" => [],
"skip_thread_containment" => false
},
"rights" => %{"admin" => false, "delete_others_notice" => false},
"role" => "member"
}
2017-06-19 17:12:37 -04:00
assert represented == UserView.render("show.json", %{user: user, for: follower})
end
2017-11-08 06:02:00 -05:00
2017-11-08 12:13:03 -05:00
test "A user that follows you", %{user: user} do
follower = insert(:user)
{:ok, follower} = User.follow(follower, user)
2017-11-08 12:13:03 -05:00
{:ok, user} = User.update_follower_count(user)
image = "http://localhost:4001/images/avi.png"
banner = "http://localhost:4001/images/banner.png"
2017-11-08 12:13:03 -05:00
represented = %{
"id" => follower.id,
"name" => follower.name,
"screen_name" => follower.nickname,
"name_html" => follower.name,
"description" => HtmlSanitizeEx.strip_tags(follower.bio |> String.replace("<br>", "\n")),
"description_html" => HtmlSanitizeEx.basic_html(follower.bio),
2018-03-30 09:01:53 -04:00
"created_at" => follower.inserted_at |> Utils.format_naive_asctime(),
2017-11-08 12:13:03 -05:00
"favourites_count" => 0,
"statuses_count" => 0,
"friends_count" => 1,
"followers_count" => 0,
"profile_image_url" => image,
"profile_image_url_https" => image,
"profile_image_url_profile_size" => image,
"profile_image_url_original" => image,
"following" => false,
"follows_you" => true,
"statusnet_blocking" => false,
"statusnet_profile_url" => follower.ap_id,
"cover_photo" => banner,
2018-02-01 14:41:19 -05:00
"background_image" => nil,
"is_local" => true,
"locked" => false,
"hide_follows" => false,
"hide_followers" => false,
2018-12-06 12:38:52 -05:00
"fields" => [],
"pleroma" => %{
"confirmation_pending" => false,
2019-06-03 15:51:14 -04:00
"tags" => [],
"skip_thread_containment" => false
},
"rights" => %{"admin" => false, "delete_others_notice" => false},
"role" => "member"
2017-11-08 12:13:03 -05:00
}
assert represented == UserView.render("show.json", %{user: follower, for: user})
end
2018-02-20 12:44:50 -05:00
test "a user that is a moderator" do
2018-11-30 11:08:02 -05:00
user = insert(:user, %{info: %{is_moderator: true}})
2018-02-20 12:44:50 -05:00
represented = UserView.render("show.json", %{user: user, for: user})
assert represented["rights"]["delete_others_notice"]
assert represented["role"] == "moderator"
2018-02-20 12:44:50 -05:00
end
test "a user that is a admin" do
user = insert(:user, %{info: %{is_admin: true}})
represented = UserView.render("show.json", %{user: user, for: user})
assert represented["rights"]["admin"]
assert represented["role"] == "admin"
end
test "A moderator with hidden role for another user", %{user: user} do
admin = insert(:user, %{info: %{is_moderator: true, show_role: false}})
represented = UserView.render("show.json", %{user: admin, for: user})
assert represented["role"] == nil
end
test "An admin with hidden role for another user", %{user: user} do
admin = insert(:user, %{info: %{is_admin: true, show_role: false}})
represented = UserView.render("show.json", %{user: admin, for: user})
assert represented["role"] == nil
end
2019-02-28 00:31:33 -05:00
test "A regular user for the admin", %{user: user} do
admin = insert(:user, %{info: %{is_admin: true}})
represented = UserView.render("show.json", %{user: user, for: admin})
assert represented["pleroma"]["deactivated"] == false
end
2018-02-12 04:13:54 -05:00
test "A blocked user for the blocker" do
2017-11-08 06:02:00 -05:00
user = insert(:user)
blocker = insert(:user)
User.block(blocker, user)
image = "http://localhost:4001/images/avi.png"
banner = "http://localhost:4001/images/banner.png"
2017-11-08 06:02:00 -05:00
represented = %{
"id" => user.id,
"name" => user.name,
"screen_name" => user.nickname,
"name_html" => user.name,
2018-08-21 10:24:06 -04:00
"description" => HtmlSanitizeEx.strip_tags(user.bio |> String.replace("<br>", "\n")),
"description_html" => HtmlSanitizeEx.basic_html(user.bio),
2018-03-30 09:01:53 -04:00
"created_at" => user.inserted_at |> Utils.format_naive_asctime(),
2017-11-08 06:02:00 -05:00
"favourites_count" => 0,
"statuses_count" => 0,
"friends_count" => 0,
"followers_count" => 0,
"profile_image_url" => image,
"profile_image_url_https" => image,
"profile_image_url_profile_size" => image,
"profile_image_url_original" => image,
"following" => false,
2017-11-08 12:13:03 -05:00
"follows_you" => false,
2017-11-08 06:02:00 -05:00
"statusnet_blocking" => true,
"statusnet_profile_url" => user.ap_id,
"cover_photo" => banner,
2018-02-01 14:41:19 -05:00
"background_image" => nil,
"is_local" => true,
"locked" => false,
"hide_follows" => false,
"hide_followers" => false,
2018-12-06 12:38:52 -05:00
"fields" => [],
"pleroma" => %{
"confirmation_pending" => false,
2019-06-03 15:51:14 -04:00
"tags" => [],
"skip_thread_containment" => false
},
"rights" => %{"admin" => false, "delete_others_notice" => false},
"role" => "member"
2017-11-08 06:02:00 -05:00
}
2019-04-22 03:20:43 -04:00
blocker = User.get_cached_by_id(blocker.id)
2017-11-08 06:02:00 -05:00
assert represented == UserView.render("show.json", %{user: user, for: blocker})
end
test "a user with mastodon fields" do
fields = [
%{
"name" => "Pronouns",
"value" => "she/her"
},
%{
"name" => "Website",
"value" => "https://example.org/"
}
]
user =
insert(:user, %{
info: %{
2018-11-30 11:08:02 -05:00
source_data: %{
"attachment" =>
Enum.map(fields, fn field -> Map.put(field, "type", "PropertyValue") end)
}
}
})
userview = UserView.render("show.json", %{user: user})
assert userview["fields"] == fields
end
2017-03-20 16:30:18 -04:00
end