|
|
@ -570,22 +570,6 @@ defmodule Pleroma.UserTest do
|
|
|
|
refute cs.valid?
|
|
|
|
refute cs.valid?
|
|
|
|
end)
|
|
|
|
end)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
test "it restricts some sizes" do
|
|
|
|
|
|
|
|
bio_limit = Pleroma.Config.get([:instance, :user_bio_length], 5000)
|
|
|
|
|
|
|
|
name_limit = Pleroma.Config.get([:instance, :user_name_length], 100)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
[bio: bio_limit, name: name_limit]
|
|
|
|
|
|
|
|
|> Enum.each(fn {field, size} ->
|
|
|
|
|
|
|
|
string = String.pad_leading(".", size)
|
|
|
|
|
|
|
|
cs = User.remote_user_creation(Map.put(@valid_remote, field, string))
|
|
|
|
|
|
|
|
assert cs.valid?
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
string = String.pad_leading(".", size + 1)
|
|
|
|
|
|
|
|
cs = User.remote_user_creation(Map.put(@valid_remote, field, string))
|
|
|
|
|
|
|
|
refute cs.valid?
|
|
|
|
|
|
|
|
end)
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
describe "followers and friends" do
|
|
|
|
describe "followers and friends" do
|
|
|
@ -1117,11 +1101,60 @@ defmodule Pleroma.UserTest do
|
|
|
|
assert {:ok, _key} = User.get_public_key_for_ap_id("http://mastodon.example.org/users/admin")
|
|
|
|
assert {:ok, _key} = User.get_public_key_for_ap_id("http://mastodon.example.org/users/admin")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
test "insert or update a user from given data" do
|
|
|
|
describe "insert or update a user from given data" do
|
|
|
|
user = insert(:user, %{nickname: "nick@name.de"})
|
|
|
|
test "with normal data" do
|
|
|
|
data = %{ap_id: user.ap_id <> "xxx", name: user.name, nickname: user.nickname}
|
|
|
|
user = insert(:user, %{nickname: "nick@name.de"})
|
|
|
|
|
|
|
|
data = %{ap_id: user.ap_id <> "xxx", name: user.name, nickname: user.nickname}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
assert {:ok, %User{}} = User.insert_or_update_user(data)
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
test "with overly long fields" do
|
|
|
|
|
|
|
|
current_max_length = Pleroma.Config.get([:instance, :account_field_value_length], 255)
|
|
|
|
|
|
|
|
user = insert(:user, nickname: "nickname@supergood.domain")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data = %{
|
|
|
|
|
|
|
|
ap_id: user.ap_id,
|
|
|
|
|
|
|
|
name: user.name,
|
|
|
|
|
|
|
|
nickname: user.nickname,
|
|
|
|
|
|
|
|
info: %{
|
|
|
|
|
|
|
|
fields: [
|
|
|
|
|
|
|
|
%{"name" => "myfield", "value" => String.duplicate("h", current_max_length + 1)}
|
|
|
|
|
|
|
|
]
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
assert {:ok, %User{}} = User.insert_or_update_user(data)
|
|
|
|
assert {:ok, %User{}} = User.insert_or_update_user(data)
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
test "with an overly long bio" do
|
|
|
|
|
|
|
|
current_max_length = Pleroma.Config.get([:instance, :user_bio_length], 5000)
|
|
|
|
|
|
|
|
user = insert(:user, nickname: "nickname@supergood.domain")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data = %{
|
|
|
|
|
|
|
|
ap_id: user.ap_id,
|
|
|
|
|
|
|
|
name: user.name,
|
|
|
|
|
|
|
|
nickname: user.nickname,
|
|
|
|
|
|
|
|
bio: String.duplicate("h", current_max_length + 1),
|
|
|
|
|
|
|
|
info: %{}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
assert {:ok, %User{}} = User.insert_or_update_user(data)
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
test "with an overly long display name" do
|
|
|
|
|
|
|
|
current_max_length = Pleroma.Config.get([:instance, :user_name_length], 100)
|
|
|
|
|
|
|
|
user = insert(:user, nickname: "nickname@supergood.domain")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data = %{
|
|
|
|
|
|
|
|
ap_id: user.ap_id,
|
|
|
|
|
|
|
|
name: String.duplicate("h", current_max_length + 1),
|
|
|
|
|
|
|
|
nickname: user.nickname,
|
|
|
|
|
|
|
|
info: %{}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
assert {:ok, %User{}} = User.insert_or_update_user(data)
|
|
|
|
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
describe "per-user rich-text filtering" do
|
|
|
|
describe "per-user rich-text filtering" do
|
|
|
|