Merge branch 'bugfix/formatter-single-char-nicks' into 'develop'
formatter: fix single char local nicknames Closes #163 See merge request pleroma/pleroma!290
This commit is contained in:
commit
be7a6db1f5
@ -16,7 +16,7 @@ defmodule Pleroma.Formatter do
|
|||||||
def parse_mentions(text) do
|
def parse_mentions(text) do
|
||||||
# Modified from https://www.w3.org/TR/html5/forms.html#valid-e-mail-address
|
# Modified from https://www.w3.org/TR/html5/forms.html#valid-e-mail-address
|
||||||
regex =
|
regex =
|
||||||
~r/@[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@?[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*/u
|
~r/@[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]*@?[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*/u
|
||||||
|
|
||||||
Regex.scan(regex, text)
|
Regex.scan(regex, text)
|
||||||
|> List.flatten()
|
|> List.flatten()
|
||||||
|
@ -123,6 +123,35 @@ defmodule Pleroma.FormatterTest do
|
|||||||
|
|
||||||
assert expected_text == Formatter.finalize({subs, text})
|
assert expected_text == Formatter.finalize({subs, text})
|
||||||
end
|
end
|
||||||
|
|
||||||
|
test "gives a replacement for single-character local nicknames" do
|
||||||
|
text = "@o hi"
|
||||||
|
o = insert(:user, %{nickname: "o"})
|
||||||
|
|
||||||
|
mentions = Formatter.parse_mentions(text)
|
||||||
|
|
||||||
|
{subs, text} = Formatter.add_user_links({[], text}, mentions)
|
||||||
|
|
||||||
|
assert length(subs) == 1
|
||||||
|
Enum.each(subs, fn {uuid, _} -> assert String.contains?(text, uuid) end)
|
||||||
|
|
||||||
|
expected_text = "<span><a class='mention' href='#{o.ap_id}'>@<span>o</span></a></span> hi"
|
||||||
|
assert expected_text == Formatter.finalize({subs, text})
|
||||||
|
end
|
||||||
|
|
||||||
|
test "does not give a replacement for single-character local nicknames who don't exist" do
|
||||||
|
text = "@a hi"
|
||||||
|
|
||||||
|
mentions = Formatter.parse_mentions(text)
|
||||||
|
|
||||||
|
{subs, text} = Formatter.add_user_links({[], text}, mentions)
|
||||||
|
|
||||||
|
assert length(subs) == 0
|
||||||
|
Enum.each(subs, fn {uuid, _} -> assert String.contains?(text, uuid) end)
|
||||||
|
|
||||||
|
expected_text = "@a hi"
|
||||||
|
assert expected_text == Formatter.finalize({subs, text})
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe ".parse_tags" do
|
describe ".parse_tags" do
|
||||||
|
Loading…
Reference in New Issue
Block a user