akkoma/test/pleroma/web/media_proxy/invalidation/http_test.exs

40 lines
1.3 KiB
Elixir
Raw Permalink Normal View History

2020-10-12 17:00:50 +00:00
# Pleroma: A lightweight social networking server
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
2020-10-12 17:00:50 +00:00
# SPDX-License-Identifier: AGPL-3.0-only
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
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