2020-05-18 06:22:26 +00:00
|
|
|
defmodule Pleroma.Web.MediaProxy.Invalidation.HttpTest do
|
|
|
|
use ExUnit.Case
|
|
|
|
alias Pleroma.Web.MediaProxy.Invalidation
|
|
|
|
|
|
|
|
import ExUnit.CaptureLog
|
|
|
|
import Tesla.Mock
|
|
|
|
|
2020-06-14 18:02:57 +00:00
|
|
|
setup do
|
|
|
|
on_exit(fn -> Cachex.clear(:deleted_urls_cache) end)
|
|
|
|
end
|
|
|
|
|
2020-05-18 06:22:26 +00:00
|
|
|
test "logs hasn't error message when request is valid" do
|
|
|
|
mock(fn
|
|
|
|
%{method: :purge, url: "http://example.com/media/example.jpg"} ->
|
|
|
|
%Tesla.Env{status: 200}
|
|
|
|
end)
|
|
|
|
|
|
|
|
refute capture_log(fn ->
|
|
|
|
assert Invalidation.Http.purge(
|
|
|
|
["http://example.com/media/example.jpg"],
|
2020-06-14 18:02:57 +00:00
|
|
|
[]
|
|
|
|
) == {:ok, ["http://example.com/media/example.jpg"]}
|
2020-05-18 06:22:26 +00:00
|
|
|
end) =~ "Error while cache purge"
|
|
|
|
end
|
|
|
|
|
|
|
|
test "it write error message in logs when request invalid" do
|
|
|
|
mock(fn
|
|
|
|
%{method: :purge, url: "http://example.com/media/example1.jpg"} ->
|
|
|
|
%Tesla.Env{status: 404}
|
|
|
|
end)
|
|
|
|
|
|
|
|
assert capture_log(fn ->
|
|
|
|
assert Invalidation.Http.purge(
|
|
|
|
["http://example.com/media/example1.jpg"],
|
2020-06-14 18:02:57 +00:00
|
|
|
[]
|
|
|
|
) == {:ok, ["http://example.com/media/example1.jpg"]}
|
2020-05-18 06:22:26 +00:00
|
|
|
end) =~ "Error while cache purge: url - http://example.com/media/example1.jpg"
|
|
|
|
end
|
|
|
|
end
|