1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
5 defmodule Pleroma.Web.PleromaAPI.MascotControllerTest do
6 use Pleroma.Web.ConnCase, async: true
8 alias Pleroma.UnstubbedConfigMock, as: ConfigMock
13 test "mascot upload" do
14 %{conn: conn} = oauth_access(["write:accounts"])
16 non_image_file = %Plug.Upload{
17 content_type: "audio/mpeg",
18 path: Path.absname("test/fixtures/sound.mp3"),
24 |> put_req_header("content-type", "multipart/form-data")
25 |> put("/api/v1/pleroma/mascot", %{"file" => non_image_file})
27 assert json_response_and_validate_schema(ret_conn, 415)
30 content_type: "image/jpeg",
31 path: Path.absname("test/fixtures/image.jpg"),
32 filename: "an_image.jpg"
36 |> stub_with(Pleroma.Test.StaticConfig)
40 |> put_req_header("content-type", "multipart/form-data")
41 |> put("/api/v1/pleroma/mascot", %{"file" => file})
43 assert %{"id" => _, "type" => _image} = json_response_and_validate_schema(conn, 200)
46 test "mascot retrieving" do
47 %{user: user, conn: conn} = oauth_access(["read:accounts", "write:accounts"])
49 # When user hasn't set a mascot, we should just get pleroma tan back
50 ret_conn = get(conn, "/api/v1/pleroma/mascot")
52 assert %{"url" => url} = json_response_and_validate_schema(ret_conn, 200)
53 assert url =~ "pleroma-fox-tan-smol"
55 # When a user sets their mascot, we should get that back
57 content_type: "image/jpeg",
58 path: Path.absname("test/fixtures/image.jpg"),
59 filename: "an_image.jpg"
63 |> stub_with(Pleroma.Test.StaticConfig)
67 |> put_req_header("content-type", "multipart/form-data")
68 |> put("/api/v1/pleroma/mascot", %{"file" => file})
70 assert json_response_and_validate_schema(ret_conn, 200)
72 user = User.get_cached_by_id(user.id)
76 |> assign(:user, user)
77 |> get("/api/v1/pleroma/mascot")
79 assert %{"url" => url, "type" => "image"} = json_response_and_validate_schema(conn, 200)
80 assert url =~ "an_image"