forked from AkkomaGang/akkoma
37 lines
1.2 KiB
Elixir
37 lines
1.2 KiB
Elixir
|
# Pleroma: A lightweight social networking server
|
||
|
# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
|
||
|
# SPDX-License-Identifier: AGPL-3.0-only
|
||
|
defmodule Pleroma.Web.ActivityPub.MRF.UserAllowListPolicyTest do
|
||
|
use Pleroma.DataCase
|
||
|
import Pleroma.Factory
|
||
|
|
||
|
alias Pleroma.Web.ActivityPub.MRF.UserAllowListPolicy
|
||
|
|
||
|
setup do
|
||
|
policy = Pleroma.Config.get([:mrf_user_allowlist]) || []
|
||
|
on_exit(fn -> Pleroma.Config.put([:mrf_user_allowlist], policy) end)
|
||
|
|
||
|
:ok
|
||
|
end
|
||
|
|
||
|
test "pass filter if allow list is empty" do
|
||
|
actor = insert(:user)
|
||
|
message = %{"actor" => actor.ap_id}
|
||
|
assert UserAllowListPolicy.filter(message) == {:ok, message}
|
||
|
end
|
||
|
|
||
|
test "pass filter if allow list isn't empty and user in allow list" do
|
||
|
actor = insert(:user)
|
||
|
Pleroma.Config.put([:mrf_user_allowlist, :localhost], [actor.ap_id, "test-ap-id"])
|
||
|
message = %{"actor" => actor.ap_id}
|
||
|
assert UserAllowListPolicy.filter(message) == {:ok, message}
|
||
|
end
|
||
|
|
||
|
test "rejected if allow list isn't empty and user not in allow list" do
|
||
|
actor = insert(:user)
|
||
|
Pleroma.Config.put([:mrf_user_allowlist, :localhost], ["test-ap-id"])
|
||
|
message = %{"actor" => actor.ap_id}
|
||
|
assert UserAllowListPolicy.filter(message) == {:reject, nil}
|
||
|
end
|
||
|
end
|