84 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			Elixir
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			Elixir
		
	
	
	
	
	
| defmodule Pleroma.Web.ActivityPub.MRFTest do
 | |
|   use ExUnit.Case, async: true
 | |
|   use Pleroma.Tests.Helpers
 | |
|   alias Pleroma.Web.ActivityPub.MRF
 | |
| 
 | |
|   test "subdomains_regex/1" do
 | |
|     assert MRF.subdomains_regex(["unsafe.tld", "*.unsafe.tld"]) == [
 | |
|              ~r/^unsafe.tld$/i,
 | |
|              ~r/^(.*\.)*unsafe.tld$/i
 | |
|            ]
 | |
|   end
 | |
| 
 | |
|   describe "subdomain_match/2" do
 | |
|     test "common domains" do
 | |
|       regexes = MRF.subdomains_regex(["unsafe.tld", "unsafe2.tld"])
 | |
| 
 | |
|       assert regexes == [~r/^unsafe.tld$/i, ~r/^unsafe2.tld$/i]
 | |
| 
 | |
|       assert MRF.subdomain_match?(regexes, "unsafe.tld")
 | |
|       assert MRF.subdomain_match?(regexes, "unsafe2.tld")
 | |
| 
 | |
|       refute MRF.subdomain_match?(regexes, "example.com")
 | |
|     end
 | |
| 
 | |
|     test "wildcard domains with one subdomain" do
 | |
|       regexes = MRF.subdomains_regex(["*.unsafe.tld"])
 | |
| 
 | |
|       assert regexes == [~r/^(.*\.)*unsafe.tld$/i]
 | |
| 
 | |
|       assert MRF.subdomain_match?(regexes, "unsafe.tld")
 | |
|       assert MRF.subdomain_match?(regexes, "sub.unsafe.tld")
 | |
|       refute MRF.subdomain_match?(regexes, "anotherunsafe.tld")
 | |
|       refute MRF.subdomain_match?(regexes, "unsafe.tldanother")
 | |
|     end
 | |
| 
 | |
|     test "wildcard domains with two subdomains" do
 | |
|       regexes = MRF.subdomains_regex(["*.unsafe.tld"])
 | |
| 
 | |
|       assert regexes == [~r/^(.*\.)*unsafe.tld$/i]
 | |
| 
 | |
|       assert MRF.subdomain_match?(regexes, "unsafe.tld")
 | |
|       assert MRF.subdomain_match?(regexes, "sub.sub.unsafe.tld")
 | |
|       refute MRF.subdomain_match?(regexes, "sub.anotherunsafe.tld")
 | |
|       refute MRF.subdomain_match?(regexes, "sub.unsafe.tldanother")
 | |
|     end
 | |
| 
 | |
|     test "matches are case-insensitive" do
 | |
|       regexes = MRF.subdomains_regex(["UnSafe.TLD", "UnSAFE2.Tld"])
 | |
| 
 | |
|       assert regexes == [~r/^UnSafe.TLD$/i, ~r/^UnSAFE2.Tld$/i]
 | |
| 
 | |
|       assert MRF.subdomain_match?(regexes, "UNSAFE.TLD")
 | |
|       assert MRF.subdomain_match?(regexes, "UNSAFE2.TLD")
 | |
|       assert MRF.subdomain_match?(regexes, "unsafe.tld")
 | |
|       assert MRF.subdomain_match?(regexes, "unsafe2.tld")
 | |
| 
 | |
|       refute MRF.subdomain_match?(regexes, "EXAMPLE.COM")
 | |
|       refute MRF.subdomain_match?(regexes, "example.com")
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   describe "describe/0" do
 | |
|     test "it works as expected with noop policy" do
 | |
|       expected = %{
 | |
|         mrf_policies: ["NoOpPolicy"],
 | |
|         exclusions: false
 | |
|       }
 | |
| 
 | |
|       {:ok, ^expected} = MRF.describe()
 | |
|     end
 | |
| 
 | |
|     test "it works as expected with mock policy" do
 | |
|       clear_config([:mrf, :policies], [MRFModuleMock])
 | |
| 
 | |
|       expected = %{
 | |
|         mrf_policies: ["MRFModuleMock"],
 | |
|         mrf_module_mock: "some config data",
 | |
|         exclusions: false
 | |
|       }
 | |
| 
 | |
|       {:ok, ^expected} = MRF.describe()
 | |
|     end
 | |
|   end
 | |
| end
 | 
