B StripLocation: Add test, work for all svgs.
This commit is contained in:
parent
5b4962165e
commit
fe00fbfd54
|
@ -14,7 +14,7 @@ defmodule Pleroma.Upload.Filter.Exiftool.StripLocation do
|
||||||
# Formats not compatible with exiftool at this time
|
# Formats not compatible with exiftool at this time
|
||||||
def filter(%Pleroma.Upload{content_type: "image/heic"}), do: {:ok, :noop}
|
def filter(%Pleroma.Upload{content_type: "image/heic"}), do: {:ok, :noop}
|
||||||
def filter(%Pleroma.Upload{content_type: "image/webp"}), do: {:ok, :noop}
|
def filter(%Pleroma.Upload{content_type: "image/webp"}), do: {:ok, :noop}
|
||||||
def filter(%Pleroma.Upload{content_type: "image/svg+xml"}), do: {:ok, :noop}
|
def filter(%Pleroma.Upload{content_type: "image/svg" <> _}), do: {:ok, :noop}
|
||||||
|
|
||||||
def filter(%Pleroma.Upload{tempfile: file, content_type: "image" <> _}) do
|
def filter(%Pleroma.Upload{tempfile: file, content_type: "image" <> _}) do
|
||||||
try do
|
try do
|
||||||
|
|
|
@ -31,12 +31,19 @@ test "apply exiftool filter" do
|
||||||
refute String.match?(exif_filtered, ~r/GPS/)
|
refute String.match?(exif_filtered, ~r/GPS/)
|
||||||
end
|
end
|
||||||
|
|
||||||
test "verify webp files are skipped" do
|
test "verify webp, heic, svg files are skipped" do
|
||||||
upload = %Pleroma.Upload{
|
uploads =
|
||||||
name: "sample.webp",
|
~w{webp heic svg svg+xml}
|
||||||
content_type: "image/webp"
|
|> Enum.map(fn type ->
|
||||||
}
|
%Pleroma.Upload{
|
||||||
|
name: "sample.#{type}",
|
||||||
|
content_type: "image/#{type}"
|
||||||
|
}
|
||||||
|
end)
|
||||||
|
|
||||||
assert Filter.Exiftool.StripLocation.filter(upload) == {:ok, :noop}
|
uploads
|
||||||
|
|> Enum.each(fn upload ->
|
||||||
|
assert Filter.Exiftool.StripLocation.filter(upload) == {:ok, :noop}
|
||||||
|
end)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue