diff options
Diffstat (limited to 'test')
| -rw-r--r-- | test/emoji/pack_test.exs | 93 | ||||
| -rw-r--r-- | test/fixtures/emojis.zip | bin | 0 -> 1446 bytes | |||
| -rw-r--r-- | test/fixtures/empty.zip | bin | 0 -> 22 bytes | |||
| -rw-r--r-- | test/user_test.exs | 7 | ||||
| -rw-r--r-- | test/utils_test.exs | 15 | ||||
| -rw-r--r-- | test/web/admin_api/controllers/admin_api_controller_test.exs | 7 | ||||
| -rw-r--r-- | test/web/mastodon_api/controllers/auth_controller_test.exs | 15 | ||||
| -rw-r--r-- | test/web/pleroma_api/controllers/emoji_file_controller_test.exs | 357 | ||||
| -rw-r--r-- | test/web/pleroma_api/controllers/emoji_pack_controller_test.exs | 287 | 
9 files changed, 483 insertions, 298 deletions
| diff --git a/test/emoji/pack_test.exs b/test/emoji/pack_test.exs new file mode 100644 index 000000000..70d1eaa1b --- /dev/null +++ b/test/emoji/pack_test.exs @@ -0,0 +1,93 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Emoji.PackTest do +  use ExUnit.Case, async: true +  alias Pleroma.Emoji.Pack + +  @emoji_path Path.join( +                Pleroma.Config.get!([:instance, :static_dir]), +                "emoji" +              ) + +  setup do +    pack_path = Path.join(@emoji_path, "dump_pack") +    File.mkdir(pack_path) + +    File.write!(Path.join(pack_path, "pack.json"), """ +    { +    "files": { }, +    "pack": { +    "description": "Dump pack", "homepage": "https://pleroma.social", +    "license": "Test license", "share-files": true +    }} +    """) + +    {:ok, pack} = Pleroma.Emoji.Pack.load_pack("dump_pack") + +    on_exit(fn -> +      File.rm_rf!(pack_path) +    end) + +    {:ok, pack: pack} +  end + +  describe "add_file/4" do +    test "add emojies from zip file", %{pack: pack} do +      file = %Plug.Upload{ +        content_type: "application/zip", +        filename: "emojis.zip", +        path: Path.absname("test/fixtures/emojis.zip") +      } + +      {:ok, updated_pack} = Pack.add_file(pack, nil, nil, file) + +      assert updated_pack.files == %{ +               "a_trusted_friend-128" => "128px/a_trusted_friend-128.png", +               "auroraborealis" => "auroraborealis.png", +               "baby_in_a_box" => "1000px/baby_in_a_box.png", +               "bear" => "1000px/bear.png", +               "bear-128" => "128px/bear-128.png" +             } + +      assert updated_pack.files_count == 5 +    end +  end + +  test "returns error when zip file is bad", %{pack: pack} do +    file = %Plug.Upload{ +      content_type: "application/zip", +      filename: "emojis.zip", +      path: Path.absname("test/instance_static/emoji/test_pack/blank.png") +    } + +    assert Pack.add_file(pack, nil, nil, file) == {:error, :einval} +  end + +  test "returns pack when zip file is empty", %{pack: pack} do +    file = %Plug.Upload{ +      content_type: "application/zip", +      filename: "emojis.zip", +      path: Path.absname("test/fixtures/empty.zip") +    } + +    {:ok, updated_pack} = Pack.add_file(pack, nil, nil, file) +    assert updated_pack == pack +  end + +  test "add emoji file", %{pack: pack} do +    file = %Plug.Upload{ +      filename: "blank.png", +      path: "#{@emoji_path}/test_pack/blank.png" +    } + +    {:ok, updated_pack} = Pack.add_file(pack, "test_blank", "test_blank.png", file) + +    assert updated_pack.files == %{ +             "test_blank" => "test_blank.png" +           } + +    assert updated_pack.files_count == 1 +  end +end diff --git a/test/fixtures/emojis.zip b/test/fixtures/emojis.zipBinary files differ new file mode 100644 index 000000000..d7fc4732b --- /dev/null +++ b/test/fixtures/emojis.zip diff --git a/test/fixtures/empty.zip b/test/fixtures/empty.zipBinary files differ new file mode 100644 index 000000000..15cb0ecb3 --- /dev/null +++ b/test/fixtures/empty.zip diff --git a/test/user_test.exs b/test/user_test.exs index cceb14eb9..d506f7047 100644 --- a/test/user_test.exs +++ b/test/user_test.exs @@ -509,7 +509,12 @@ defmodule Pleroma.UserTest do        cng = User.register_changeset(%User{}, @full_user_data)        {:ok, registered_user} = User.register(cng)        ObanHelpers.perform_all() -      assert_email_sent(Pleroma.Emails.UserEmail.account_confirmation_email(registered_user)) + +      Pleroma.Emails.UserEmail.account_confirmation_email(registered_user) +      # temporary hackney fix until hackney max_connections bug is fixed +      # https://git.pleroma.social/pleroma/pleroma/-/issues/2101 +      |> Swoosh.Email.put_private(:hackney_options, ssl_options: [versions: [:"tlsv1.2"]]) +      |> assert_email_sent()      end      test "it requires an email, name, nickname and password, bio is optional when account_activation_required is enabled" do diff --git a/test/utils_test.exs b/test/utils_test.exs new file mode 100644 index 000000000..3a730d545 --- /dev/null +++ b/test/utils_test.exs @@ -0,0 +1,15 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.UtilsTest do +  use ExUnit.Case, async: true + +  describe "tmp_dir/1" do +    test "returns unique temporary directory" do +      {:ok, path} = Pleroma.Utils.tmp_dir("emoji") +      assert path =~ ~r/\/tmp\/emoji-(.*)-#{:os.getpid()}-(.*)/ +      File.rm_rf(path) +    end +  end +end diff --git a/test/web/admin_api/controllers/admin_api_controller_test.exs b/test/web/admin_api/controllers/admin_api_controller_test.exs index e4d3512de..cba6b43d3 100644 --- a/test/web/admin_api/controllers/admin_api_controller_test.exs +++ b/test/web/admin_api/controllers/admin_api_controller_test.exs @@ -1977,7 +1977,12 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do                 }"        ObanHelpers.perform_all() -      assert_email_sent(Pleroma.Emails.UserEmail.account_confirmation_email(first_user)) + +      Pleroma.Emails.UserEmail.account_confirmation_email(first_user) +      # temporary hackney fix until hackney max_connections bug is fixed +      # https://git.pleroma.social/pleroma/pleroma/-/issues/2101 +      |> Swoosh.Email.put_private(:hackney_options, ssl_options: [versions: [:"tlsv1.2"]]) +      |> assert_email_sent()      end    end diff --git a/test/web/mastodon_api/controllers/auth_controller_test.exs b/test/web/mastodon_api/controllers/auth_controller_test.exs index 4fa95fce1..bf2438fe2 100644 --- a/test/web/mastodon_api/controllers/auth_controller_test.exs +++ b/test/web/mastodon_api/controllers/auth_controller_test.exs @@ -61,7 +61,7 @@ defmodule Pleroma.Web.MastodonAPI.AuthControllerTest do      end      test "it returns 204", %{conn: conn} do -      assert json_response(conn, :no_content) +      assert empty_json_response(conn)      end      test "it creates a PasswordResetToken record for user", %{user: user} do @@ -91,7 +91,7 @@ defmodule Pleroma.Web.MastodonAPI.AuthControllerTest do        assert conn               |> post("/auth/password?nickname=#{user.nickname}") -             |> json_response(:no_content) +             |> empty_json_response()        ObanHelpers.perform_all()        token_record = Repo.get_by(Pleroma.PasswordResetToken, user_id: user.id) @@ -112,7 +112,7 @@ defmodule Pleroma.Web.MastodonAPI.AuthControllerTest do        assert conn               |> post("/auth/password?nickname=#{user.nickname}") -             |> json_response(:no_content) +             |> empty_json_response()      end    end @@ -125,24 +125,21 @@ defmodule Pleroma.Web.MastodonAPI.AuthControllerTest do      test "it returns 204 when user is not found", %{conn: conn, user: user} do        conn = post(conn, "/auth/password?email=nonexisting_#{user.email}") -      assert conn -             |> json_response(:no_content) +      assert empty_json_response(conn)      end      test "it returns 204 when user is not local", %{conn: conn, user: user} do        {:ok, user} = Repo.update(Ecto.Changeset.change(user, local: false))        conn = post(conn, "/auth/password?email=#{user.email}") -      assert conn -             |> json_response(:no_content) +      assert empty_json_response(conn)      end      test "it returns 204 when user is deactivated", %{conn: conn, user: user} do        {:ok, user} = Repo.update(Ecto.Changeset.change(user, deactivated: true, local: true))        conn = post(conn, "/auth/password?email=#{user.email}") -      assert conn -             |> json_response(:no_content) +      assert empty_json_response(conn)      end    end diff --git a/test/web/pleroma_api/controllers/emoji_file_controller_test.exs b/test/web/pleroma_api/controllers/emoji_file_controller_test.exs new file mode 100644 index 000000000..39b4e1dac --- /dev/null +++ b/test/web/pleroma_api/controllers/emoji_file_controller_test.exs @@ -0,0 +1,357 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.PleromaAPI.EmojiFileControllerTest do +  use Pleroma.Web.ConnCase + +  import Tesla.Mock +  import Pleroma.Factory + +  @emoji_path Path.join( +                Pleroma.Config.get!([:instance, :static_dir]), +                "emoji" +              ) +  setup do: clear_config([:auth, :enforce_oauth_admin_scope_usage], false) + +  setup do: clear_config([:instance, :public], true) + +  setup do +    admin = insert(:user, is_admin: true) +    token = insert(:oauth_admin_token, user: admin) + +    admin_conn = +      build_conn() +      |> assign(:user, admin) +      |> assign(:token, token) + +    Pleroma.Emoji.reload() +    {:ok, %{admin_conn: admin_conn}} +  end + +  describe "POST/PATCH/DELETE /api/pleroma/emoji/packs/:name/files" do +    setup do +      pack_file = "#{@emoji_path}/test_pack/pack.json" +      original_content = File.read!(pack_file) + +      on_exit(fn -> +        File.write!(pack_file, original_content) +      end) + +      :ok +    end + +    test "upload zip file with emojies", %{admin_conn: admin_conn} do +      on_exit(fn -> +        [ +          "128px/a_trusted_friend-128.png", +          "auroraborealis.png", +          "1000px/baby_in_a_box.png", +          "1000px/bear.png", +          "128px/bear-128.png" +        ] +        |> Enum.each(fn path -> File.rm_rf!("#{@emoji_path}/test_pack/#{path}") end) +      end) + +      resp = +        admin_conn +        |> put_req_header("content-type", "multipart/form-data") +        |> post("/api/pleroma/emoji/packs/test_pack/files", %{ +          file: %Plug.Upload{ +            content_type: "application/zip", +            filename: "emojis.zip", +            path: Path.absname("test/fixtures/emojis.zip") +          } +        }) +        |> json_response_and_validate_schema(200) + +      assert resp == %{ +               "a_trusted_friend-128" => "128px/a_trusted_friend-128.png", +               "auroraborealis" => "auroraborealis.png", +               "baby_in_a_box" => "1000px/baby_in_a_box.png", +               "bear" => "1000px/bear.png", +               "bear-128" => "128px/bear-128.png", +               "blank" => "blank.png", +               "blank2" => "blank2.png" +             } + +      Enum.each(Map.values(resp), fn path -> +        assert File.exists?("#{@emoji_path}/test_pack/#{path}") +      end) +    end + +    test "create shortcode exists", %{admin_conn: admin_conn} do +      assert admin_conn +             |> put_req_header("content-type", "multipart/form-data") +             |> post("/api/pleroma/emoji/packs/test_pack/files", %{ +               shortcode: "blank", +               filename: "dir/blank.png", +               file: %Plug.Upload{ +                 filename: "blank.png", +                 path: "#{@emoji_path}/test_pack/blank.png" +               } +             }) +             |> json_response_and_validate_schema(:conflict) == %{ +               "error" => "An emoji with the \"blank\" shortcode already exists" +             } +    end + +    test "don't rewrite old emoji", %{admin_conn: admin_conn} do +      on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/dir/") end) + +      assert admin_conn +             |> put_req_header("content-type", "multipart/form-data") +             |> post("/api/pleroma/emoji/packs/test_pack/files", %{ +               shortcode: "blank3", +               filename: "dir/blank.png", +               file: %Plug.Upload{ +                 filename: "blank.png", +                 path: "#{@emoji_path}/test_pack/blank.png" +               } +             }) +             |> json_response_and_validate_schema(200) == %{ +               "blank" => "blank.png", +               "blank2" => "blank2.png", +               "blank3" => "dir/blank.png" +             } + +      assert File.exists?("#{@emoji_path}/test_pack/dir/blank.png") + +      assert admin_conn +             |> put_req_header("content-type", "multipart/form-data") +             |> patch("/api/pleroma/emoji/packs/test_pack/files", %{ +               shortcode: "blank", +               new_shortcode: "blank2", +               new_filename: "dir_2/blank_3.png" +             }) +             |> json_response_and_validate_schema(:conflict) == %{ +               "error" => +                 "New shortcode \"blank2\" is already used. If you want to override emoji use 'force' option" +             } +    end + +    test "rewrite old emoji with force option", %{admin_conn: admin_conn} do +      on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/dir_2/") end) + +      assert admin_conn +             |> put_req_header("content-type", "multipart/form-data") +             |> post("/api/pleroma/emoji/packs/test_pack/files", %{ +               shortcode: "blank3", +               filename: "dir/blank.png", +               file: %Plug.Upload{ +                 filename: "blank.png", +                 path: "#{@emoji_path}/test_pack/blank.png" +               } +             }) +             |> json_response_and_validate_schema(200) == %{ +               "blank" => "blank.png", +               "blank2" => "blank2.png", +               "blank3" => "dir/blank.png" +             } + +      assert File.exists?("#{@emoji_path}/test_pack/dir/blank.png") + +      assert admin_conn +             |> put_req_header("content-type", "multipart/form-data") +             |> patch("/api/pleroma/emoji/packs/test_pack/files", %{ +               shortcode: "blank3", +               new_shortcode: "blank4", +               new_filename: "dir_2/blank_3.png", +               force: true +             }) +             |> json_response_and_validate_schema(200) == %{ +               "blank" => "blank.png", +               "blank2" => "blank2.png", +               "blank4" => "dir_2/blank_3.png" +             } + +      assert File.exists?("#{@emoji_path}/test_pack/dir_2/blank_3.png") +    end + +    test "with empty filename", %{admin_conn: admin_conn} do +      assert admin_conn +             |> put_req_header("content-type", "multipart/form-data") +             |> post("/api/pleroma/emoji/packs/test_pack/files", %{ +               shortcode: "blank2", +               filename: "", +               file: %Plug.Upload{ +                 filename: "blank.png", +                 path: "#{@emoji_path}/test_pack/blank.png" +               } +             }) +             |> json_response_and_validate_schema(422) == %{ +               "error" => "pack name, shortcode or filename cannot be empty" +             } +    end + +    test "add file with not loaded pack", %{admin_conn: admin_conn} do +      assert admin_conn +             |> put_req_header("content-type", "multipart/form-data") +             |> post("/api/pleroma/emoji/packs/not_loaded/files", %{ +               shortcode: "blank3", +               filename: "dir/blank.png", +               file: %Plug.Upload{ +                 filename: "blank.png", +                 path: "#{@emoji_path}/test_pack/blank.png" +               } +             }) +             |> json_response_and_validate_schema(:not_found) == %{ +               "error" => "pack \"not_loaded\" is not found" +             } +    end + +    test "remove file with not loaded pack", %{admin_conn: admin_conn} do +      assert admin_conn +             |> delete("/api/pleroma/emoji/packs/not_loaded/files?shortcode=blank3") +             |> json_response_and_validate_schema(:not_found) == %{ +               "error" => "pack \"not_loaded\" is not found" +             } +    end + +    test "remove file with empty shortcode", %{admin_conn: admin_conn} do +      assert admin_conn +             |> delete("/api/pleroma/emoji/packs/not_loaded/files?shortcode=") +             |> json_response_and_validate_schema(:not_found) == %{ +               "error" => "pack \"not_loaded\" is not found" +             } +    end + +    test "update file with not loaded pack", %{admin_conn: admin_conn} do +      assert admin_conn +             |> put_req_header("content-type", "multipart/form-data") +             |> patch("/api/pleroma/emoji/packs/not_loaded/files", %{ +               shortcode: "blank4", +               new_shortcode: "blank3", +               new_filename: "dir_2/blank_3.png" +             }) +             |> json_response_and_validate_schema(:not_found) == %{ +               "error" => "pack \"not_loaded\" is not found" +             } +    end + +    test "new with shortcode as file with update", %{admin_conn: admin_conn} do +      assert admin_conn +             |> put_req_header("content-type", "multipart/form-data") +             |> post("/api/pleroma/emoji/packs/test_pack/files", %{ +               shortcode: "blank4", +               filename: "dir/blank.png", +               file: %Plug.Upload{ +                 filename: "blank.png", +                 path: "#{@emoji_path}/test_pack/blank.png" +               } +             }) +             |> json_response_and_validate_schema(200) == %{ +               "blank" => "blank.png", +               "blank4" => "dir/blank.png", +               "blank2" => "blank2.png" +             } + +      assert File.exists?("#{@emoji_path}/test_pack/dir/blank.png") + +      assert admin_conn +             |> put_req_header("content-type", "multipart/form-data") +             |> patch("/api/pleroma/emoji/packs/test_pack/files", %{ +               shortcode: "blank4", +               new_shortcode: "blank3", +               new_filename: "dir_2/blank_3.png" +             }) +             |> json_response_and_validate_schema(200) == %{ +               "blank3" => "dir_2/blank_3.png", +               "blank" => "blank.png", +               "blank2" => "blank2.png" +             } + +      refute File.exists?("#{@emoji_path}/test_pack/dir/") +      assert File.exists?("#{@emoji_path}/test_pack/dir_2/blank_3.png") + +      assert admin_conn +             |> delete("/api/pleroma/emoji/packs/test_pack/files?shortcode=blank3") +             |> json_response_and_validate_schema(200) == %{ +               "blank" => "blank.png", +               "blank2" => "blank2.png" +             } + +      refute File.exists?("#{@emoji_path}/test_pack/dir_2/") + +      on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/dir") end) +    end + +    test "new with shortcode from url", %{admin_conn: admin_conn} do +      mock(fn +        %{ +          method: :get, +          url: "https://test-blank/blank_url.png" +        } -> +          text(File.read!("#{@emoji_path}/test_pack/blank.png")) +      end) + +      assert admin_conn +             |> put_req_header("content-type", "multipart/form-data") +             |> post("/api/pleroma/emoji/packs/test_pack/files", %{ +               shortcode: "blank_url", +               file: "https://test-blank/blank_url.png" +             }) +             |> json_response_and_validate_schema(200) == %{ +               "blank_url" => "blank_url.png", +               "blank" => "blank.png", +               "blank2" => "blank2.png" +             } + +      assert File.exists?("#{@emoji_path}/test_pack/blank_url.png") + +      on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/blank_url.png") end) +    end + +    test "new without shortcode", %{admin_conn: admin_conn} do +      on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/shortcode.png") end) + +      assert admin_conn +             |> put_req_header("content-type", "multipart/form-data") +             |> post("/api/pleroma/emoji/packs/test_pack/files", %{ +               file: %Plug.Upload{ +                 filename: "shortcode.png", +                 path: "#{Pleroma.Config.get([:instance, :static_dir])}/add/shortcode.png" +               } +             }) +             |> json_response_and_validate_schema(200) == %{ +               "shortcode" => "shortcode.png", +               "blank" => "blank.png", +               "blank2" => "blank2.png" +             } +    end + +    test "remove non existing shortcode in pack.json", %{admin_conn: admin_conn} do +      assert admin_conn +             |> delete("/api/pleroma/emoji/packs/test_pack/files?shortcode=blank3") +             |> json_response_and_validate_schema(:bad_request) == %{ +               "error" => "Emoji \"blank3\" does not exist" +             } +    end + +    test "update non existing emoji", %{admin_conn: admin_conn} do +      assert admin_conn +             |> put_req_header("content-type", "multipart/form-data") +             |> patch("/api/pleroma/emoji/packs/test_pack/files", %{ +               shortcode: "blank3", +               new_shortcode: "blank4", +               new_filename: "dir_2/blank_3.png" +             }) +             |> json_response_and_validate_schema(:bad_request) == %{ +               "error" => "Emoji \"blank3\" does not exist" +             } +    end + +    test "update with empty shortcode", %{admin_conn: admin_conn} do +      assert %{ +               "error" => "Missing field: new_shortcode." +             } = +               admin_conn +               |> put_req_header("content-type", "multipart/form-data") +               |> patch("/api/pleroma/emoji/packs/test_pack/files", %{ +                 shortcode: "blank", +                 new_filename: "dir_2/blank_3.png" +               }) +               |> json_response_and_validate_schema(:bad_request) +    end +  end +end diff --git a/test/web/pleroma_api/controllers/emoji_pack_controller_test.exs b/test/web/pleroma_api/controllers/emoji_pack_controller_test.exs index e113bb15f..a34df2c18 100644 --- a/test/web/pleroma_api/controllers/emoji_pack_controller_test.exs +++ b/test/web/pleroma_api/controllers/emoji_pack_controller_test.exs @@ -411,293 +411,6 @@ defmodule Pleroma.Web.PleromaAPI.EmojiPackControllerTest do      end    end -  describe "POST/PATCH/DELETE /api/pleroma/emoji/packs/:name/files" do -    setup do -      pack_file = "#{@emoji_path}/test_pack/pack.json" -      original_content = File.read!(pack_file) - -      on_exit(fn -> -        File.write!(pack_file, original_content) -      end) - -      :ok -    end - -    test "create shortcode exists", %{admin_conn: admin_conn} do -      assert admin_conn -             |> put_req_header("content-type", "multipart/form-data") -             |> post("/api/pleroma/emoji/packs/test_pack/files", %{ -               shortcode: "blank", -               filename: "dir/blank.png", -               file: %Plug.Upload{ -                 filename: "blank.png", -                 path: "#{@emoji_path}/test_pack/blank.png" -               } -             }) -             |> json_response_and_validate_schema(:conflict) == %{ -               "error" => "An emoji with the \"blank\" shortcode already exists" -             } -    end - -    test "don't rewrite old emoji", %{admin_conn: admin_conn} do -      on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/dir/") end) - -      assert admin_conn -             |> put_req_header("content-type", "multipart/form-data") -             |> post("/api/pleroma/emoji/packs/test_pack/files", %{ -               shortcode: "blank3", -               filename: "dir/blank.png", -               file: %Plug.Upload{ -                 filename: "blank.png", -                 path: "#{@emoji_path}/test_pack/blank.png" -               } -             }) -             |> json_response_and_validate_schema(200) == %{ -               "blank" => "blank.png", -               "blank2" => "blank2.png", -               "blank3" => "dir/blank.png" -             } - -      assert File.exists?("#{@emoji_path}/test_pack/dir/blank.png") - -      assert admin_conn -             |> put_req_header("content-type", "multipart/form-data") -             |> patch("/api/pleroma/emoji/packs/test_pack/files", %{ -               shortcode: "blank", -               new_shortcode: "blank2", -               new_filename: "dir_2/blank_3.png" -             }) -             |> json_response_and_validate_schema(:conflict) == %{ -               "error" => -                 "New shortcode \"blank2\" is already used. If you want to override emoji use 'force' option" -             } -    end - -    test "rewrite old emoji with force option", %{admin_conn: admin_conn} do -      on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/dir_2/") end) - -      assert admin_conn -             |> put_req_header("content-type", "multipart/form-data") -             |> post("/api/pleroma/emoji/packs/test_pack/files", %{ -               shortcode: "blank3", -               filename: "dir/blank.png", -               file: %Plug.Upload{ -                 filename: "blank.png", -                 path: "#{@emoji_path}/test_pack/blank.png" -               } -             }) -             |> json_response_and_validate_schema(200) == %{ -               "blank" => "blank.png", -               "blank2" => "blank2.png", -               "blank3" => "dir/blank.png" -             } - -      assert File.exists?("#{@emoji_path}/test_pack/dir/blank.png") - -      assert admin_conn -             |> put_req_header("content-type", "multipart/form-data") -             |> patch("/api/pleroma/emoji/packs/test_pack/files", %{ -               shortcode: "blank3", -               new_shortcode: "blank4", -               new_filename: "dir_2/blank_3.png", -               force: true -             }) -             |> json_response_and_validate_schema(200) == %{ -               "blank" => "blank.png", -               "blank2" => "blank2.png", -               "blank4" => "dir_2/blank_3.png" -             } - -      assert File.exists?("#{@emoji_path}/test_pack/dir_2/blank_3.png") -    end - -    test "with empty filename", %{admin_conn: admin_conn} do -      assert admin_conn -             |> put_req_header("content-type", "multipart/form-data") -             |> post("/api/pleroma/emoji/packs/test_pack/files", %{ -               shortcode: "blank2", -               filename: "", -               file: %Plug.Upload{ -                 filename: "blank.png", -                 path: "#{@emoji_path}/test_pack/blank.png" -               } -             }) -             |> json_response_and_validate_schema(:bad_request) == %{ -               "error" => "pack name, shortcode or filename cannot be empty" -             } -    end - -    test "add file with not loaded pack", %{admin_conn: admin_conn} do -      assert admin_conn -             |> put_req_header("content-type", "multipart/form-data") -             |> post("/api/pleroma/emoji/packs/not_loaded/files", %{ -               shortcode: "blank3", -               filename: "dir/blank.png", -               file: %Plug.Upload{ -                 filename: "blank.png", -                 path: "#{@emoji_path}/test_pack/blank.png" -               } -             }) -             |> json_response_and_validate_schema(:bad_request) == %{ -               "error" => "pack \"not_loaded\" is not found" -             } -    end - -    test "remove file with not loaded pack", %{admin_conn: admin_conn} do -      assert admin_conn -             |> delete("/api/pleroma/emoji/packs/not_loaded/files?shortcode=blank3") -             |> json_response_and_validate_schema(:bad_request) == %{ -               "error" => "pack \"not_loaded\" is not found" -             } -    end - -    test "remove file with empty shortcode", %{admin_conn: admin_conn} do -      assert admin_conn -             |> delete("/api/pleroma/emoji/packs/not_loaded/files?shortcode=") -             |> json_response_and_validate_schema(:bad_request) == %{ -               "error" => "pack name or shortcode cannot be empty" -             } -    end - -    test "update file with not loaded pack", %{admin_conn: admin_conn} do -      assert admin_conn -             |> put_req_header("content-type", "multipart/form-data") -             |> patch("/api/pleroma/emoji/packs/not_loaded/files", %{ -               shortcode: "blank4", -               new_shortcode: "blank3", -               new_filename: "dir_2/blank_3.png" -             }) -             |> json_response_and_validate_schema(:bad_request) == %{ -               "error" => "pack \"not_loaded\" is not found" -             } -    end - -    test "new with shortcode as file with update", %{admin_conn: admin_conn} do -      assert admin_conn -             |> put_req_header("content-type", "multipart/form-data") -             |> post("/api/pleroma/emoji/packs/test_pack/files", %{ -               shortcode: "blank4", -               filename: "dir/blank.png", -               file: %Plug.Upload{ -                 filename: "blank.png", -                 path: "#{@emoji_path}/test_pack/blank.png" -               } -             }) -             |> json_response_and_validate_schema(200) == %{ -               "blank" => "blank.png", -               "blank4" => "dir/blank.png", -               "blank2" => "blank2.png" -             } - -      assert File.exists?("#{@emoji_path}/test_pack/dir/blank.png") - -      assert admin_conn -             |> put_req_header("content-type", "multipart/form-data") -             |> patch("/api/pleroma/emoji/packs/test_pack/files", %{ -               shortcode: "blank4", -               new_shortcode: "blank3", -               new_filename: "dir_2/blank_3.png" -             }) -             |> json_response_and_validate_schema(200) == %{ -               "blank3" => "dir_2/blank_3.png", -               "blank" => "blank.png", -               "blank2" => "blank2.png" -             } - -      refute File.exists?("#{@emoji_path}/test_pack/dir/") -      assert File.exists?("#{@emoji_path}/test_pack/dir_2/blank_3.png") - -      assert admin_conn -             |> delete("/api/pleroma/emoji/packs/test_pack/files?shortcode=blank3") -             |> json_response_and_validate_schema(200) == %{ -               "blank" => "blank.png", -               "blank2" => "blank2.png" -             } - -      refute File.exists?("#{@emoji_path}/test_pack/dir_2/") - -      on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/dir") end) -    end - -    test "new with shortcode from url", %{admin_conn: admin_conn} do -      mock(fn -        %{ -          method: :get, -          url: "https://test-blank/blank_url.png" -        } -> -          text(File.read!("#{@emoji_path}/test_pack/blank.png")) -      end) - -      assert admin_conn -             |> put_req_header("content-type", "multipart/form-data") -             |> post("/api/pleroma/emoji/packs/test_pack/files", %{ -               shortcode: "blank_url", -               file: "https://test-blank/blank_url.png" -             }) -             |> json_response_and_validate_schema(200) == %{ -               "blank_url" => "blank_url.png", -               "blank" => "blank.png", -               "blank2" => "blank2.png" -             } - -      assert File.exists?("#{@emoji_path}/test_pack/blank_url.png") - -      on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/blank_url.png") end) -    end - -    test "new without shortcode", %{admin_conn: admin_conn} do -      on_exit(fn -> File.rm_rf!("#{@emoji_path}/test_pack/shortcode.png") end) - -      assert admin_conn -             |> put_req_header("content-type", "multipart/form-data") -             |> post("/api/pleroma/emoji/packs/test_pack/files", %{ -               file: %Plug.Upload{ -                 filename: "shortcode.png", -                 path: "#{Pleroma.Config.get([:instance, :static_dir])}/add/shortcode.png" -               } -             }) -             |> json_response_and_validate_schema(200) == %{ -               "shortcode" => "shortcode.png", -               "blank" => "blank.png", -               "blank2" => "blank2.png" -             } -    end - -    test "remove non existing shortcode in pack.json", %{admin_conn: admin_conn} do -      assert admin_conn -             |> delete("/api/pleroma/emoji/packs/test_pack/files?shortcode=blank3") -             |> json_response_and_validate_schema(:bad_request) == %{ -               "error" => "Emoji \"blank3\" does not exist" -             } -    end - -    test "update non existing emoji", %{admin_conn: admin_conn} do -      assert admin_conn -             |> put_req_header("content-type", "multipart/form-data") -             |> patch("/api/pleroma/emoji/packs/test_pack/files", %{ -               shortcode: "blank3", -               new_shortcode: "blank4", -               new_filename: "dir_2/blank_3.png" -             }) -             |> json_response_and_validate_schema(:bad_request) == %{ -               "error" => "Emoji \"blank3\" does not exist" -             } -    end - -    test "update with empty shortcode", %{admin_conn: admin_conn} do -      assert %{ -               "error" => "Missing field: new_shortcode." -             } = -               admin_conn -               |> put_req_header("content-type", "multipart/form-data") -               |> patch("/api/pleroma/emoji/packs/test_pack/files", %{ -                 shortcode: "blank", -                 new_filename: "dir_2/blank_3.png" -               }) -               |> json_response_and_validate_schema(:bad_request) -    end -  end -    describe "POST/DELETE /api/pleroma/emoji/packs/:name" do      test "creating and deleting a pack", %{admin_conn: admin_conn} do        assert admin_conn | 
