diff options
Diffstat (limited to 'test')
3 files changed, 118 insertions, 1 deletions
| diff --git a/test/pleroma/web/admin_api/controllers/admin_api_controller_test.exs b/test/pleroma/web/admin_api/controllers/admin_api_controller_test.exs index 1df28f147..23c26d7db 100644 --- a/test/pleroma/web/admin_api/controllers/admin_api_controller_test.exs +++ b/test/pleroma/web/admin_api/controllers/admin_api_controller_test.exs @@ -1060,6 +1060,34 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do        assert Repo.aggregate(Pleroma.User.Backup, :count) == 2      end    end + +  describe "POST /api/v1/pleroma/admin/reload_emoji" do +    setup do +      clear_config([:instance, :admin_privileges], [:emoji_management]) + +      admin = insert(:user, is_admin: true) +      token = insert(:oauth_admin_token, user: admin) + +      conn = +        build_conn() +        |> assign(:user, admin) +        |> assign(:token, token) + +      {:ok, %{conn: conn, admin: admin}} +    end + +    test "it requires privileged role :emoji_management", %{conn: conn} do +      assert conn +             |> post("/api/v1/pleroma/admin/reload_emoji") +             |> json_response(200) + +      clear_config([:instance, :admin_privileges], []) + +      assert conn +             |> post("/api/v1/pleroma/admin/reload_emoji") +             |> json_response(:forbidden) +    end +  end  end  # Needed for testing diff --git a/test/pleroma/web/pleroma_api/controllers/emoji_file_controller_test.exs b/test/pleroma/web/pleroma_api/controllers/emoji_file_controller_test.exs index 200ce3b68..e46a363a4 100644 --- a/test/pleroma/web/pleroma_api/controllers/emoji_file_controller_test.exs +++ b/test/pleroma/web/pleroma_api/controllers/emoji_file_controller_test.exs @@ -3,7 +3,7 @@  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Pleroma.Web.PleromaAPI.EmojiFileControllerTest do -  use Pleroma.Web.ConnCase +  use Pleroma.Web.ConnCase, async: false    import Mock    import Tesla.Mock @@ -30,6 +30,7 @@ defmodule Pleroma.Web.PleromaAPI.EmojiFileControllerTest do    describe "POST/PATCH/DELETE /api/pleroma/emoji/packs/files?name=:name" do      setup do +      clear_config([:instance, :admin_privileges], [:emoji_management])        pack_file = "#{@emoji_path}/test_pack/pack.json"        original_content = File.read!(pack_file) @@ -377,5 +378,32 @@ defmodule Pleroma.Web.PleromaAPI.EmojiFileControllerTest do                 })                 |> json_response_and_validate_schema(:bad_request)      end + +    test "it requires privileged role :emoji_management", %{admin_conn: admin_conn} do +      clear_config([:instance, :admin_privileges], []) + +      assert admin_conn +             |> put_req_header("content-type", "multipart/form-data") +             |> post("/api/pleroma/emoji/packs/files?name=test_pack", %{ +               file: %Plug.Upload{ +                 filename: "shortcode.png", +                 path: "#{Pleroma.Config.get([:instance, :static_dir])}/add/shortcode.png" +               } +             }) +             |> json_response(:forbidden) + +      assert admin_conn +             |> put_req_header("content-type", "multipart/form-data") +             |> patch("/api/pleroma/emoji/packs/files?name=test_pack", %{ +               shortcode: "blank", +               new_filename: "dir_2/blank_3.png" +             }) +             |> json_response(:forbidden) + +      assert admin_conn +             |> put_req_header("content-type", "multipart/form-data") +             |> delete("/api/pleroma/emoji/packs/files?name=test_pack&shortcode=blank3") +             |> json_response(:forbidden) +    end    end  end diff --git a/test/pleroma/web/pleroma_api/controllers/emoji_pack_controller_test.exs b/test/pleroma/web/pleroma_api/controllers/emoji_pack_controller_test.exs index d1fd1cbb0..6558767d2 100644 --- a/test/pleroma/web/pleroma_api/controllers/emoji_pack_controller_test.exs +++ b/test/pleroma/web/pleroma_api/controllers/emoji_pack_controller_test.exs @@ -99,6 +99,10 @@ defmodule Pleroma.Web.PleromaAPI.EmojiPackControllerTest do    end    describe "GET /api/pleroma/emoji/packs/remote" do +    setup do +      clear_config([:instance, :admin_privileges], [:emoji_management]) +    end +      test "shareable instance", %{admin_conn: admin_conn, conn: conn} do        resp =          conn @@ -136,6 +140,14 @@ defmodule Pleroma.Web.PleromaAPI.EmojiPackControllerTest do                 "error" => "The requested instance does not support sharing emoji packs"               }      end + +    test "it requires privileged role :emoji_management", %{admin_conn: admin_conn} do +      clear_config([:instance, :admin_privileges], []) + +      assert admin_conn +             |> get("/api/pleroma/emoji/packs/remote?url=https://example.com") +             |> json_response(:forbidden) +    end    end    describe "GET /api/pleroma/emoji/packs/archive?name=:name" do @@ -170,6 +182,10 @@ defmodule Pleroma.Web.PleromaAPI.EmojiPackControllerTest do    end    describe "POST /api/pleroma/emoji/packs/download" do +    setup do +      clear_config([:instance, :admin_privileges], [:emoji_management]) +    end +      test "shared pack from remote and non shared from fallback-src", %{        admin_conn: admin_conn,        conn: conn @@ -344,10 +360,24 @@ defmodule Pleroma.Web.PleromaAPI.EmojiPackControllerTest do                   "The pack was not set as shared and there is no fallback src to download from"               }      end + +    test "it requires privileged role :emoji_management", %{admin_conn: conn} do +      clear_config([:instance, :admin_privileges], []) + +      assert conn +             |> put_req_header("content-type", "multipart/form-data") +             |> post("/api/pleroma/emoji/packs/download", %{ +               url: "https://example.com", +               name: "test_pack", +               as: "test_pack2" +             }) +             |> json_response(:forbidden) +    end    end    describe "PATCH/update /api/pleroma/emoji/pack?name=:name" do      setup do +      clear_config([:instance, :admin_privileges], [:emoji_management])        pack_file = "#{@emoji_path}/test_pack/pack.json"        original_content = File.read!(pack_file) @@ -435,9 +465,22 @@ defmodule Pleroma.Web.PleromaAPI.EmojiPackControllerTest do                 "error" => "The fallback archive does not have all files specified in pack.json"               }      end + +    test "it requires privileged role :emoji_management", %{admin_conn: conn, new_data: new_data} do +      clear_config([:instance, :admin_privileges], []) + +      assert conn +             |> put_req_header("content-type", "multipart/form-data") +             |> patch("/api/pleroma/emoji/pack?name=test_pack", %{metadata: new_data}) +             |> json_response(:forbidden) +    end    end    describe "POST/DELETE /api/pleroma/emoji/pack?name=:name" do +    setup do +      clear_config([:instance, :admin_privileges], [:emoji_management]) +    end +      test "returns an error on creates pack when file system not writable", %{        admin_conn: admin_conn      } do @@ -520,6 +563,18 @@ defmodule Pleroma.Web.PleromaAPI.EmojiPackControllerTest do                 "error" => "pack name cannot be empty"               }      end + +    test "it requires privileged role :emoji_management", %{admin_conn: admin_conn} do +      clear_config([:instance, :admin_privileges], []) + +      assert admin_conn +             |> post("/api/pleroma/emoji/pack?name= ") +             |> json_response(:forbidden) + +      assert admin_conn +             |> delete("/api/pleroma/emoji/pack?name= ") +             |> json_response(:forbidden) +    end    end    test "deleting nonexisting pack", %{admin_conn: admin_conn} do @@ -578,6 +633,12 @@ defmodule Pleroma.Web.PleromaAPI.EmojiPackControllerTest do               "blank2" => "blank.png",               "foo" => "blank.png"             } + +    clear_config([:instance, :admin_privileges], []) + +    assert admin_conn +           |> get("/api/pleroma/emoji/packs/import") +           |> json_response(:forbidden)    end    describe "GET /api/pleroma/emoji/pack?name=:name" do | 
