2018-12-23 13:11:29 -07:00
|
|
|
|
# Pleroma: A lightweight social networking server
|
|
|
|
|
# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/>
|
|
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
2017-09-15 06:17:36 -06:00
|
|
|
|
defmodule Pleroma.Web.CommonAPI.UtilsTest do
|
2019-03-04 19:52:23 -07:00
|
|
|
|
alias Pleroma.Builders.UserBuilder
|
2019-03-21 17:37:00 -06:00
|
|
|
|
alias Pleroma.Object
|
2019-06-03 11:08:38 -06:00
|
|
|
|
alias Pleroma.Web.CommonAPI
|
2017-09-15 06:17:36 -06:00
|
|
|
|
alias Pleroma.Web.CommonAPI.Utils
|
2018-08-12 13:24:10 -06:00
|
|
|
|
alias Pleroma.Web.Endpoint
|
2017-06-14 06:46:18 -06:00
|
|
|
|
use Pleroma.DataCase
|
|
|
|
|
|
2019-07-15 13:47:23 -06:00
|
|
|
|
import ExUnit.CaptureLog
|
2019-06-03 11:08:38 -06:00
|
|
|
|
import Pleroma.Factory
|
|
|
|
|
|
|
|
|
|
@public_address "https://www.w3.org/ns/activitystreams#Public"
|
|
|
|
|
|
2017-06-14 06:46:18 -06:00
|
|
|
|
test "it adds attachment links to a given text and attachment set" do
|
2018-03-30 07:01:53 -06:00
|
|
|
|
name =
|
|
|
|
|
"Sakura%20Mana%20%E2%80%93%20Turned%20on%20by%20a%20Senior%20OL%20with%20a%20Temptating%20Tight%20Skirt-s%20Full%20Hipline%20and%20Panty%20Shot-%20Beautiful%20Thick%20Thighs-%20and%20Erotic%20Ass-%20-2015-%20--%20Oppaitime%208-28-2017%206-50-33%20PM.png"
|
2017-08-28 11:17:38 -06:00
|
|
|
|
|
2017-06-14 06:46:18 -06:00
|
|
|
|
attachment = %{
|
2017-08-28 11:17:38 -06:00
|
|
|
|
"url" => [%{"href" => name}]
|
2017-06-14 06:46:18 -06:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
res = Utils.add_attachments("", [attachment])
|
|
|
|
|
|
2018-03-30 07:01:53 -06:00
|
|
|
|
assert res ==
|
|
|
|
|
"<br><a href=\"#{name}\" class='attachment'>Sakura Mana – Turned on by a Se…</a>"
|
2017-06-14 06:46:18 -06:00
|
|
|
|
end
|
2018-05-11 05:32:59 -06:00
|
|
|
|
|
|
|
|
|
describe "it confirms the password given is the current users password" do
|
2018-05-13 07:56:59 -06:00
|
|
|
|
test "incorrect password given" do
|
2018-05-11 05:32:59 -06:00
|
|
|
|
{:ok, user} = UserBuilder.insert()
|
|
|
|
|
|
2018-05-21 15:32:28 -06:00
|
|
|
|
assert Utils.confirm_current_password(user, "") == {:error, "Invalid password."}
|
2018-05-11 05:32:59 -06:00
|
|
|
|
end
|
|
|
|
|
|
2018-05-13 07:56:59 -06:00
|
|
|
|
test "correct password given" do
|
2018-05-11 05:32:59 -06:00
|
|
|
|
{:ok, user} = UserBuilder.insert()
|
2018-05-21 15:32:28 -06:00
|
|
|
|
assert Utils.confirm_current_password(user, "test") == {:ok, user}
|
2018-05-11 05:32:59 -06:00
|
|
|
|
end
|
|
|
|
|
end
|
2018-08-12 13:24:10 -06:00
|
|
|
|
|
|
|
|
|
test "parses emoji from name and bio" do
|
2019-04-18 13:04:37 -06:00
|
|
|
|
{:ok, user} = UserBuilder.insert(%{name: ":blank:", bio: ":firefox:"})
|
2018-08-12 13:24:10 -06:00
|
|
|
|
|
|
|
|
|
expected = [
|
|
|
|
|
%{
|
|
|
|
|
"type" => "Emoji",
|
2019-04-18 13:04:37 -06:00
|
|
|
|
"icon" => %{"type" => "Image", "url" => "#{Endpoint.url()}/emoji/Firefox.gif"},
|
|
|
|
|
"name" => ":firefox:"
|
2018-08-12 13:24:10 -06:00
|
|
|
|
},
|
|
|
|
|
%{
|
|
|
|
|
"type" => "Emoji",
|
2018-08-26 17:19:45 -06:00
|
|
|
|
"icon" => %{
|
|
|
|
|
"type" => "Image",
|
2019-04-18 13:04:37 -06:00
|
|
|
|
"url" => "#{Endpoint.url()}/emoji/blank.png"
|
2018-08-26 17:19:45 -06:00
|
|
|
|
},
|
2019-04-18 13:04:37 -06:00
|
|
|
|
"name" => ":blank:"
|
2018-08-12 13:24:10 -06:00
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
assert expected == Utils.emoji_from_profile(user)
|
|
|
|
|
end
|
2019-01-09 20:46:34 -07:00
|
|
|
|
|
2019-02-26 16:32:26 -07:00
|
|
|
|
describe "format_input/3" do
|
2019-01-09 20:46:34 -07:00
|
|
|
|
test "works for bare text/plain" do
|
|
|
|
|
text = "hello world!"
|
|
|
|
|
expected = "hello world!"
|
|
|
|
|
|
2019-02-26 16:32:26 -07:00
|
|
|
|
{output, [], []} = Utils.format_input(text, "text/plain")
|
2019-01-09 20:46:34 -07:00
|
|
|
|
|
|
|
|
|
assert output == expected
|
|
|
|
|
|
|
|
|
|
text = "hello world!\n\nsecond paragraph!"
|
|
|
|
|
expected = "hello world!<br><br>second paragraph!"
|
|
|
|
|
|
2019-02-26 16:32:26 -07:00
|
|
|
|
{output, [], []} = Utils.format_input(text, "text/plain")
|
2019-01-09 20:46:34 -07:00
|
|
|
|
|
|
|
|
|
assert output == expected
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "works for bare text/html" do
|
|
|
|
|
text = "<p>hello world!</p>"
|
|
|
|
|
expected = "<p>hello world!</p>"
|
|
|
|
|
|
2019-02-26 16:32:26 -07:00
|
|
|
|
{output, [], []} = Utils.format_input(text, "text/html")
|
2019-01-09 20:46:34 -07:00
|
|
|
|
|
|
|
|
|
assert output == expected
|
|
|
|
|
|
|
|
|
|
text = "<p>hello world!</p>\n\n<p>second paragraph</p>"
|
|
|
|
|
expected = "<p>hello world!</p>\n\n<p>second paragraph</p>"
|
|
|
|
|
|
2019-02-26 16:32:26 -07:00
|
|
|
|
{output, [], []} = Utils.format_input(text, "text/html")
|
2019-01-09 20:46:34 -07:00
|
|
|
|
|
|
|
|
|
assert output == expected
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "works for bare text/markdown" do
|
|
|
|
|
text = "**hello world**"
|
2019-07-29 13:42:26 -06:00
|
|
|
|
expected = "<p><strong>hello world</strong></p>\n"
|
2019-01-09 20:46:34 -07:00
|
|
|
|
|
2019-02-26 16:32:26 -07:00
|
|
|
|
{output, [], []} = Utils.format_input(text, "text/markdown")
|
2019-01-09 20:46:34 -07:00
|
|
|
|
|
|
|
|
|
assert output == expected
|
|
|
|
|
|
|
|
|
|
text = "**hello world**\n\n*another paragraph*"
|
2019-07-29 13:42:26 -06:00
|
|
|
|
expected = "<p><strong>hello world</strong></p>\n<p><em>another paragraph</em></p>\n"
|
2019-01-09 20:46:34 -07:00
|
|
|
|
|
2019-02-26 16:32:26 -07:00
|
|
|
|
{output, [], []} = Utils.format_input(text, "text/markdown")
|
|
|
|
|
|
|
|
|
|
assert output == expected
|
2019-02-27 01:40:30 -07:00
|
|
|
|
|
|
|
|
|
text = """
|
|
|
|
|
> cool quote
|
|
|
|
|
|
|
|
|
|
by someone
|
|
|
|
|
"""
|
|
|
|
|
|
2019-07-29 13:42:26 -06:00
|
|
|
|
expected = "<blockquote><p>cool quote</p>\n</blockquote>\n<p>by someone</p>\n"
|
2019-02-27 01:40:30 -07:00
|
|
|
|
|
|
|
|
|
{output, [], []} = Utils.format_input(text, "text/markdown")
|
|
|
|
|
|
|
|
|
|
assert output == expected
|
2019-02-26 16:32:26 -07:00
|
|
|
|
end
|
|
|
|
|
|
2019-04-26 04:17:57 -06:00
|
|
|
|
test "works for bare text/bbcode" do
|
|
|
|
|
text = "[b]hello world[/b]"
|
|
|
|
|
expected = "<strong>hello world</strong>"
|
|
|
|
|
|
|
|
|
|
{output, [], []} = Utils.format_input(text, "text/bbcode")
|
|
|
|
|
|
|
|
|
|
assert output == expected
|
|
|
|
|
|
|
|
|
|
text = "[b]hello world![/b]\n\nsecond paragraph!"
|
2019-04-26 16:38:56 -06:00
|
|
|
|
expected = "<strong>hello world!</strong><br>\n<br>\nsecond paragraph!"
|
|
|
|
|
|
|
|
|
|
{output, [], []} = Utils.format_input(text, "text/bbcode")
|
|
|
|
|
|
|
|
|
|
assert output == expected
|
|
|
|
|
|
|
|
|
|
text = "[b]hello world![/b]\n\n<strong>second paragraph!</strong>"
|
|
|
|
|
|
|
|
|
|
expected =
|
|
|
|
|
"<strong>hello world!</strong><br>\n<br>\n<strong>second paragraph!</strong>"
|
2019-04-26 04:17:57 -06:00
|
|
|
|
|
|
|
|
|
{output, [], []} = Utils.format_input(text, "text/bbcode")
|
|
|
|
|
|
|
|
|
|
assert output == expected
|
|
|
|
|
end
|
|
|
|
|
|
2019-02-26 16:32:26 -07:00
|
|
|
|
test "works for text/markdown with mentions" do
|
|
|
|
|
{:ok, user} =
|
|
|
|
|
UserBuilder.insert(%{nickname: "user__test", ap_id: "http://foo.com/user__test"})
|
|
|
|
|
|
|
|
|
|
text = "**hello world**\n\n*another @user__test and @user__test google.com paragraph*"
|
|
|
|
|
|
|
|
|
|
expected =
|
2019-07-29 13:42:26 -06:00
|
|
|
|
"<p><strong>hello world</strong></p>\n<p><em>another <span class=\"h-card\"><a data-user=\"#{
|
2019-02-26 16:32:26 -07:00
|
|
|
|
user.id
|
2019-02-27 01:40:30 -07:00
|
|
|
|
}\" class=\"u-url mention\" href=\"http://foo.com/user__test\">@<span>user__test</span></a></span> and <span class=\"h-card\"><a data-user=\"#{
|
2019-02-26 16:32:26 -07:00
|
|
|
|
user.id
|
2019-07-29 13:42:26 -06:00
|
|
|
|
}\" class=\"u-url mention\" href=\"http://foo.com/user__test\">@<span>user__test</span></a></span> <a href=\"http://google.com\">google.com</a> paragraph</em></p>\n"
|
2019-02-26 16:32:26 -07:00
|
|
|
|
|
|
|
|
|
{output, _, _} = Utils.format_input(text, "text/markdown")
|
2019-01-09 20:46:34 -07:00
|
|
|
|
|
|
|
|
|
assert output == expected
|
|
|
|
|
end
|
|
|
|
|
end
|
2019-03-21 17:17:53 -06:00
|
|
|
|
|
|
|
|
|
describe "context_to_conversation_id" do
|
|
|
|
|
test "creates a mapping object" do
|
|
|
|
|
conversation_id = Utils.context_to_conversation_id("random context")
|
|
|
|
|
object = Object.get_by_ap_id("random context")
|
|
|
|
|
|
|
|
|
|
assert conversation_id == object.id
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "returns an existing mapping for an existing object" do
|
|
|
|
|
{:ok, object} = Object.context_mapping("random context") |> Repo.insert()
|
|
|
|
|
conversation_id = Utils.context_to_conversation_id("random context")
|
|
|
|
|
|
|
|
|
|
assert conversation_id == object.id
|
|
|
|
|
end
|
|
|
|
|
end
|
2019-04-01 14:40:48 -06:00
|
|
|
|
|
|
|
|
|
describe "formats date to asctime" do
|
2019-04-02 03:25:51 -06:00
|
|
|
|
test "when date is in ISO 8601 format" do
|
|
|
|
|
date = DateTime.utc_now() |> DateTime.to_iso8601()
|
2019-04-01 14:40:48 -06:00
|
|
|
|
|
|
|
|
|
expected =
|
|
|
|
|
date
|
2019-04-02 03:25:51 -06:00
|
|
|
|
|> DateTime.from_iso8601()
|
|
|
|
|
|> elem(1)
|
2019-04-01 14:40:48 -06:00
|
|
|
|
|> Calendar.Strftime.strftime!("%a %b %d %H:%M:%S %z %Y")
|
|
|
|
|
|
|
|
|
|
assert Utils.date_to_asctime(date) == expected
|
|
|
|
|
end
|
|
|
|
|
|
2019-04-02 03:25:51 -06:00
|
|
|
|
test "when date is a binary in wrong format" do
|
|
|
|
|
date = DateTime.utc_now()
|
2019-04-01 14:40:48 -06:00
|
|
|
|
|
2019-04-02 03:25:51 -06:00
|
|
|
|
expected = ""
|
2019-04-01 14:40:48 -06:00
|
|
|
|
|
2019-07-15 13:47:23 -06:00
|
|
|
|
assert capture_log(fn ->
|
|
|
|
|
assert Utils.date_to_asctime(date) == expected
|
|
|
|
|
end) =~ "[warn] Date #{date} in wrong format, must be ISO 8601"
|
2019-04-01 14:40:48 -06:00
|
|
|
|
end
|
|
|
|
|
|
2019-04-02 03:25:51 -06:00
|
|
|
|
test "when date is a Unix timestamp" do
|
|
|
|
|
date = DateTime.utc_now() |> DateTime.to_unix()
|
2019-04-01 14:40:48 -06:00
|
|
|
|
|
2019-04-02 03:25:51 -06:00
|
|
|
|
expected = ""
|
2019-04-01 14:40:48 -06:00
|
|
|
|
|
2019-07-15 13:47:23 -06:00
|
|
|
|
assert capture_log(fn ->
|
|
|
|
|
assert Utils.date_to_asctime(date) == expected
|
|
|
|
|
end) =~ "[warn] Date #{date} in wrong format, must be ISO 8601"
|
2019-04-01 14:40:48 -06:00
|
|
|
|
end
|
2019-04-02 03:25:51 -06:00
|
|
|
|
|
|
|
|
|
test "when date is nil" do
|
|
|
|
|
expected = ""
|
|
|
|
|
|
2019-07-15 13:47:23 -06:00
|
|
|
|
assert capture_log(fn ->
|
|
|
|
|
assert Utils.date_to_asctime(nil) == expected
|
|
|
|
|
end) =~ "[warn] Date in wrong format, must be ISO 8601"
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "when date is a random string" do
|
|
|
|
|
assert capture_log(fn ->
|
|
|
|
|
assert Utils.date_to_asctime("foo") == ""
|
|
|
|
|
end) =~ "[warn] Date foo in wrong format, must be ISO 8601"
|
2019-04-02 03:25:51 -06:00
|
|
|
|
end
|
2019-04-01 14:40:48 -06:00
|
|
|
|
end
|
2019-06-03 11:08:38 -06:00
|
|
|
|
|
|
|
|
|
describe "get_to_and_cc" do
|
|
|
|
|
test "for public posts, not a reply" do
|
|
|
|
|
user = insert(:user)
|
|
|
|
|
mentioned_user = insert(:user)
|
|
|
|
|
mentions = [mentioned_user.ap_id]
|
|
|
|
|
|
|
|
|
|
{to, cc} = Utils.get_to_and_cc(user, mentions, nil, "public")
|
|
|
|
|
|
|
|
|
|
assert length(to) == 2
|
|
|
|
|
assert length(cc) == 1
|
|
|
|
|
|
|
|
|
|
assert @public_address in to
|
|
|
|
|
assert mentioned_user.ap_id in to
|
|
|
|
|
assert user.follower_address in cc
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "for public posts, a reply" do
|
|
|
|
|
user = insert(:user)
|
|
|
|
|
mentioned_user = insert(:user)
|
|
|
|
|
third_user = insert(:user)
|
|
|
|
|
{:ok, activity} = CommonAPI.post(third_user, %{"status" => "uguu"})
|
|
|
|
|
mentions = [mentioned_user.ap_id]
|
|
|
|
|
|
|
|
|
|
{to, cc} = Utils.get_to_and_cc(user, mentions, activity, "public")
|
|
|
|
|
|
|
|
|
|
assert length(to) == 3
|
|
|
|
|
assert length(cc) == 1
|
|
|
|
|
|
|
|
|
|
assert @public_address in to
|
|
|
|
|
assert mentioned_user.ap_id in to
|
|
|
|
|
assert third_user.ap_id in to
|
|
|
|
|
assert user.follower_address in cc
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "for unlisted posts, not a reply" do
|
|
|
|
|
user = insert(:user)
|
|
|
|
|
mentioned_user = insert(:user)
|
|
|
|
|
mentions = [mentioned_user.ap_id]
|
|
|
|
|
|
|
|
|
|
{to, cc} = Utils.get_to_and_cc(user, mentions, nil, "unlisted")
|
|
|
|
|
|
|
|
|
|
assert length(to) == 2
|
|
|
|
|
assert length(cc) == 1
|
|
|
|
|
|
|
|
|
|
assert @public_address in cc
|
|
|
|
|
assert mentioned_user.ap_id in to
|
|
|
|
|
assert user.follower_address in to
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "for unlisted posts, a reply" do
|
|
|
|
|
user = insert(:user)
|
|
|
|
|
mentioned_user = insert(:user)
|
|
|
|
|
third_user = insert(:user)
|
|
|
|
|
{:ok, activity} = CommonAPI.post(third_user, %{"status" => "uguu"})
|
|
|
|
|
mentions = [mentioned_user.ap_id]
|
|
|
|
|
|
|
|
|
|
{to, cc} = Utils.get_to_and_cc(user, mentions, activity, "unlisted")
|
|
|
|
|
|
|
|
|
|
assert length(to) == 3
|
|
|
|
|
assert length(cc) == 1
|
|
|
|
|
|
|
|
|
|
assert @public_address in cc
|
|
|
|
|
assert mentioned_user.ap_id in to
|
|
|
|
|
assert third_user.ap_id in to
|
|
|
|
|
assert user.follower_address in to
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "for private posts, not a reply" do
|
|
|
|
|
user = insert(:user)
|
|
|
|
|
mentioned_user = insert(:user)
|
|
|
|
|
mentions = [mentioned_user.ap_id]
|
|
|
|
|
|
|
|
|
|
{to, cc} = Utils.get_to_and_cc(user, mentions, nil, "private")
|
|
|
|
|
|
|
|
|
|
assert length(to) == 2
|
|
|
|
|
assert length(cc) == 0
|
|
|
|
|
|
|
|
|
|
assert mentioned_user.ap_id in to
|
|
|
|
|
assert user.follower_address in to
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "for private posts, a reply" do
|
|
|
|
|
user = insert(:user)
|
|
|
|
|
mentioned_user = insert(:user)
|
|
|
|
|
third_user = insert(:user)
|
|
|
|
|
{:ok, activity} = CommonAPI.post(third_user, %{"status" => "uguu"})
|
|
|
|
|
mentions = [mentioned_user.ap_id]
|
|
|
|
|
|
|
|
|
|
{to, cc} = Utils.get_to_and_cc(user, mentions, activity, "private")
|
|
|
|
|
|
|
|
|
|
assert length(to) == 3
|
|
|
|
|
assert length(cc) == 0
|
|
|
|
|
|
|
|
|
|
assert mentioned_user.ap_id in to
|
|
|
|
|
assert third_user.ap_id in to
|
|
|
|
|
assert user.follower_address in to
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "for direct posts, not a reply" do
|
|
|
|
|
user = insert(:user)
|
|
|
|
|
mentioned_user = insert(:user)
|
|
|
|
|
mentions = [mentioned_user.ap_id]
|
|
|
|
|
|
|
|
|
|
{to, cc} = Utils.get_to_and_cc(user, mentions, nil, "direct")
|
|
|
|
|
|
|
|
|
|
assert length(to) == 1
|
|
|
|
|
assert length(cc) == 0
|
|
|
|
|
|
|
|
|
|
assert mentioned_user.ap_id in to
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "for direct posts, a reply" do
|
|
|
|
|
user = insert(:user)
|
|
|
|
|
mentioned_user = insert(:user)
|
|
|
|
|
third_user = insert(:user)
|
|
|
|
|
{:ok, activity} = CommonAPI.post(third_user, %{"status" => "uguu"})
|
|
|
|
|
mentions = [mentioned_user.ap_id]
|
|
|
|
|
|
|
|
|
|
{to, cc} = Utils.get_to_and_cc(user, mentions, activity, "direct")
|
|
|
|
|
|
|
|
|
|
assert length(to) == 2
|
|
|
|
|
assert length(cc) == 0
|
|
|
|
|
|
|
|
|
|
assert mentioned_user.ap_id in to
|
|
|
|
|
assert third_user.ap_id in to
|
|
|
|
|
end
|
|
|
|
|
end
|
2019-07-31 12:35:15 -06:00
|
|
|
|
|
|
|
|
|
describe "get_by_id_or_ap_id/1" do
|
|
|
|
|
test "get activity by id" do
|
|
|
|
|
activity = insert(:note_activity)
|
|
|
|
|
%Pleroma.Activity{} = note = Utils.get_by_id_or_ap_id(activity.id)
|
|
|
|
|
assert note.id == activity.id
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "get activity by ap_id" do
|
|
|
|
|
activity = insert(:note_activity)
|
|
|
|
|
%Pleroma.Activity{} = note = Utils.get_by_id_or_ap_id(activity.data["object"])
|
|
|
|
|
assert note.id == activity.id
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "get activity by object when type isn't `Create` " do
|
|
|
|
|
activity = insert(:like_activity)
|
|
|
|
|
%Pleroma.Activity{} = like = Utils.get_by_id_or_ap_id(activity.id)
|
|
|
|
|
assert like.data["object"] == activity.data["object"]
|
|
|
|
|
end
|
|
|
|
|
end
|
2017-06-14 06:46:18 -06:00
|
|
|
|
end
|