# Pleroma: A lightweight social networking server # Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> # SPDX-License-Identifier: AGPL-3.0-only defmodule Pleroma.Web.MediaProxy.Invalidation.HttpTest do use ExUnit.Case alias Pleroma.Web.MediaProxy.Invalidation import ExUnit.CaptureLog import Tesla.Mock setup do on_exit(fn -> Cachex.clear(:banned_urls_cache) end) end 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"], [] ) == {:ok, ["http://example.com/media/example.jpg"]} 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"], [] ) == {:ok, ["http://example.com/media/example1.jpg"]} end) =~ "Error while cache purge: url - http://example.com/media/example1.jpg" end end