diff options
Diffstat (limited to 'test')
| -rw-r--r-- | test/activity_test.exs | 7 | ||||
| -rw-r--r-- | test/config/config_db_test.exs | 16 | ||||
| -rw-r--r-- | test/http/connection_test.exs | 2 | ||||
| -rw-r--r-- | test/http/request_builder_test.exs | 14 | ||||
| -rw-r--r-- | test/plugs/authentication_plug_test.exs | 7 | ||||
| -rw-r--r-- | test/uploaders/s3_test.exs | 2 | ||||
| -rw-r--r-- | test/web/activity_pub/activity_pub_test.exs | 2 | ||||
| -rw-r--r-- | test/web/admin_api/admin_api_controller_test.exs | 136 | ||||
| -rw-r--r-- | test/web/feed/tag_controller_test.exs | 4 | ||||
| -rw-r--r-- | test/web/mastodon_api/controllers/search_controller_test.exs | 2 | ||||
| -rw-r--r-- | test/web/pleroma_api/controllers/account_controller_test.exs | 107 | ||||
| -rw-r--r-- | test/web/push/impl_test.exs | 4 | ||||
| -rw-r--r-- | test/web/rel_me_test.exs | 2 | 
13 files changed, 210 insertions, 95 deletions
| diff --git a/test/activity_test.exs b/test/activity_test.exs index 507027e5a..2a92327d1 100644 --- a/test/activity_test.exs +++ b/test/activity_test.exs @@ -11,6 +11,11 @@ defmodule Pleroma.ActivityTest do    alias Pleroma.ThreadMute    import Pleroma.Factory +  setup_all do +    Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end) +    :ok +  end +    test "returns an activity by it's AP id" do      activity = insert(:note_activity)      found_activity = Activity.get_by_ap_id(activity.data["id"]) @@ -107,8 +112,6 @@ defmodule Pleroma.ActivityTest do    describe "search" do      setup do -      Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end) -        user = insert(:user)        params = %{ diff --git a/test/config/config_db_test.exs b/test/config/config_db_test.exs index 6b0e7b4b6..336de7359 100644 --- a/test/config/config_db_test.exs +++ b/test/config/config_db_test.exs @@ -43,11 +43,9 @@ defmodule Pleroma.ConfigDBTest do               {ConfigDB.from_string(saved.key), ConfigDB.from_binary(saved.value)}             ] -    assert config[:quack] == [ -             level: :info, -             meta: [:none], -             webhook_url: "https://hooks.slack.com/services/KEY/some_val" -           ] +    assert config[:quack][:level] == :info +    assert config[:quack][:meta] == [:none] +    assert config[:quack][:webhook_url] == "https://hooks.slack.com/services/KEY/some_val"    end    describe "update_or_create/1" do @@ -478,6 +476,14 @@ defmodule Pleroma.ConfigDBTest do        assert ConfigDB.from_binary(binary) == [key: "value"]      end +    test "keyword with partial_chain key" do +      binary = +        ConfigDB.transform([%{"tuple" => [":partial_chain", "&:hackney_connect.partial_chain/1"]}]) + +      assert binary == :erlang.term_to_binary(partial_chain: &:hackney_connect.partial_chain/1) +      assert ConfigDB.from_binary(binary) == [partial_chain: &:hackney_connect.partial_chain/1] +    end +      test "keyword" do        binary =          ConfigDB.transform([ diff --git a/test/http/connection_test.exs b/test/http/connection_test.exs index 5cc78ad5b..7c94a50b2 100644 --- a/test/http/connection_test.exs +++ b/test/http/connection_test.exs @@ -3,7 +3,7 @@  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Pleroma.HTTP.ConnectionTest do -  use ExUnit.Case, async: true +  use ExUnit.Case    use Pleroma.Tests.Helpers    import ExUnit.CaptureLog diff --git a/test/http/request_builder_test.exs b/test/http/request_builder_test.exs index f11528c3f..fab909905 100644 --- a/test/http/request_builder_test.exs +++ b/test/http/request_builder_test.exs @@ -3,23 +3,19 @@  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Pleroma.HTTP.RequestBuilderTest do -  use ExUnit.Case, async: true +  use ExUnit.Case    use Pleroma.Tests.Helpers -  alias Pleroma.Config    alias Pleroma.HTTP.Request    alias Pleroma.HTTP.RequestBuilder    describe "headers/2" do -    setup do: clear_config([:http, :send_user_agent]) -    setup do: clear_config([:http, :user_agent]) -      test "don't send pleroma user agent" do        assert RequestBuilder.headers(%Request{}, []) == %Request{headers: []}      end      test "send pleroma user agent" do -      Config.put([:http, :send_user_agent], true) -      Config.put([:http, :user_agent], :default) +      clear_config([:http, :send_user_agent], true) +      clear_config([:http, :user_agent], :default)        assert RequestBuilder.headers(%Request{}, []) == %Request{                 headers: [{"user-agent", Pleroma.Application.user_agent()}] @@ -27,8 +23,8 @@ defmodule Pleroma.HTTP.RequestBuilderTest do      end      test "send custom user agent" do -      Config.put([:http, :send_user_agent], true) -      Config.put([:http, :user_agent], "totally-not-pleroma") +      clear_config([:http, :send_user_agent], true) +      clear_config([:http, :user_agent], "totally-not-pleroma")        assert RequestBuilder.headers(%Request{}, []) == %Request{                 headers: [{"user-agent", "totally-not-pleroma"}] diff --git a/test/plugs/authentication_plug_test.exs b/test/plugs/authentication_plug_test.exs index 31e20d726..c8ede71c0 100644 --- a/test/plugs/authentication_plug_test.exs +++ b/test/plugs/authentication_plug_test.exs @@ -79,6 +79,13 @@ defmodule Pleroma.Plugs.AuthenticationPlugTest do        assert AuthenticationPlug.checkpw("password", hash)      end +    test "check bcrypt hash" do +      hash = "$2a$10$uyhC/R/zoE1ndwwCtMusK.TLVzkQ/Ugsbqp3uXI.CTTz0gBw.24jS" + +      assert AuthenticationPlug.checkpw("password", hash) +      refute AuthenticationPlug.checkpw("password1", hash) +    end +      test "it returns false when hash invalid" do        hash =          "psBWV8gxkGOZWBz$PmfCycChoxeJ3GgGzwvhlgacb9mUoZ.KUXNCssekER4SJ7bOK53uXrHNb2e4i8yPFgSKyzaW9CcmrDXWIEMtD1" diff --git a/test/uploaders/s3_test.exs b/test/uploaders/s3_test.exs index 6950ccb25..d949c90a5 100644 --- a/test/uploaders/s3_test.exs +++ b/test/uploaders/s3_test.exs @@ -58,7 +58,7 @@ defmodule Pleroma.Uploaders.S3Test do          name: "image-tet.jpg",          content_type: "image/jpg",          path: "test_folder/image-tet.jpg", -        tempfile: Path.absname("test/fixtures/image_tmp.jpg") +        tempfile: Path.absname("test/instance_static/add/shortcode.png")        }        [file_upload: file_upload] diff --git a/test/web/activity_pub/activity_pub_test.exs b/test/web/activity_pub/activity_pub_test.exs index 56fde97e7..77bd07edf 100644 --- a/test/web/activity_pub/activity_pub_test.exs +++ b/test/web/activity_pub/activity_pub_test.exs @@ -951,7 +951,7 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do      test "works with base64 encoded images" do        file = %{ -        "img" => data_uri() +        img: data_uri()        }        {:ok, %Object{}} = ActivityPub.upload(file) diff --git a/test/web/admin_api/admin_api_controller_test.exs b/test/web/admin_api/admin_api_controller_test.exs index ecf5465be..370d876d0 100644 --- a/test/web/admin_api/admin_api_controller_test.exs +++ b/test/web/admin_api/admin_api_controller_test.exs @@ -2509,6 +2509,7 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do                  %{"tuple" => [":seconds_valid", 60]},                  %{"tuple" => [":path", ""]},                  %{"tuple" => [":key1", nil]}, +                %{"tuple" => [":partial_chain", "&:hackney_connect.partial_chain/1"]},                  %{"tuple" => [":regex1", "~r/https:\/\/example.com/"]},                  %{"tuple" => [":regex2", "~r/https:\/\/example.com/u"]},                  %{"tuple" => [":regex3", "~r/https:\/\/example.com/i"]}, @@ -2532,6 +2533,7 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do                       %{"tuple" => [":seconds_valid", 60]},                       %{"tuple" => [":path", ""]},                       %{"tuple" => [":key1", nil]}, +                     %{"tuple" => [":partial_chain", "&:hackney_connect.partial_chain/1"]},                       %{"tuple" => [":regex1", "~r/https:\\/\\/example.com/"]},                       %{"tuple" => [":regex2", "~r/https:\\/\\/example.com/u"]},                       %{"tuple" => [":regex3", "~r/https:\\/\\/example.com/i"]}, @@ -2544,6 +2546,7 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do                       ":seconds_valid",                       ":path",                       ":key1", +                     ":partial_chain",                       ":regex1",                       ":regex2",                       ":regex3", @@ -2862,26 +2865,25 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do                group: ":pleroma",                key: ":http",                value: [ -                %{"tuple" => [":proxy_url", %{"tuple" => [":socks5", "localhost", 1234]}]}, -                %{"tuple" => [":send_user_agent", false]} +                %{"tuple" => [":proxy_url", %{"tuple" => [":socks5", "localhost", 1234]}]}                ]              }            ]          }) -      assert json_response(conn, 200) == %{ +      assert %{                 "configs" => [                   %{                     "group" => ":pleroma",                     "key" => ":http", -                   "value" => [ -                     %{"tuple" => [":proxy_url", %{"tuple" => [":socks5", "localhost", 1234]}]}, -                     %{"tuple" => [":send_user_agent", false]} -                   ], -                   "db" => [":proxy_url", ":send_user_agent"] +                   "value" => value, +                   "db" => db                   }                 ] -             } +             } = json_response(conn, 200) + +      assert %{"tuple" => [":proxy_url", %{"tuple" => [":socks5", "localhost", 1234]}]} in value +      assert ":proxy_url" in db      end      test "proxy tuple domain", %{conn: conn} do @@ -2892,26 +2894,25 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do                group: ":pleroma",                key: ":http",                value: [ -                %{"tuple" => [":proxy_url", %{"tuple" => [":socks5", "domain.com", 1234]}]}, -                %{"tuple" => [":send_user_agent", false]} +                %{"tuple" => [":proxy_url", %{"tuple" => [":socks5", "domain.com", 1234]}]}                ]              }            ]          }) -      assert json_response(conn, 200) == %{ +      assert %{                 "configs" => [                   %{                     "group" => ":pleroma",                     "key" => ":http", -                   "value" => [ -                     %{"tuple" => [":proxy_url", %{"tuple" => [":socks5", "domain.com", 1234]}]}, -                     %{"tuple" => [":send_user_agent", false]} -                   ], -                   "db" => [":proxy_url", ":send_user_agent"] +                   "value" => value, +                   "db" => db                   }                 ] -             } +             } = json_response(conn, 200) + +      assert %{"tuple" => [":proxy_url", %{"tuple" => [":socks5", "domain.com", 1234]}]} in value +      assert ":proxy_url" in db      end      test "proxy tuple ip", %{conn: conn} do @@ -2922,26 +2923,52 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do                group: ":pleroma",                key: ":http",                value: [ -                %{"tuple" => [":proxy_url", %{"tuple" => [":socks5", "127.0.0.1", 1234]}]}, -                %{"tuple" => [":send_user_agent", false]} +                %{"tuple" => [":proxy_url", %{"tuple" => [":socks5", "127.0.0.1", 1234]}]}                ]              }            ]          }) -      assert json_response(conn, 200) == %{ +      assert %{                 "configs" => [                   %{                     "group" => ":pleroma",                     "key" => ":http", -                   "value" => [ -                     %{"tuple" => [":proxy_url", %{"tuple" => [":socks5", "127.0.0.1", 1234]}]}, -                     %{"tuple" => [":send_user_agent", false]} -                   ], -                   "db" => [":proxy_url", ":send_user_agent"] +                   "value" => value, +                   "db" => db                   }                 ] -             } +             } = json_response(conn, 200) + +      assert %{"tuple" => [":proxy_url", %{"tuple" => [":socks5", "127.0.0.1", 1234]}]} in value +      assert ":proxy_url" in db +    end + +    test "doesn't set keys not in the whitelist", %{conn: conn} do +      clear_config(:database_config_whitelist, [ +        {:pleroma, :key1}, +        {:pleroma, :key2}, +        {:pleroma, Pleroma.Captcha.NotReal}, +        {:not_real} +      ]) + +      post(conn, "/api/pleroma/admin/config", %{ +        configs: [ +          %{group: ":pleroma", key: ":key1", value: "value1"}, +          %{group: ":pleroma", key: ":key2", value: "value2"}, +          %{group: ":pleroma", key: ":key3", value: "value3"}, +          %{group: ":pleroma", key: "Pleroma.Web.Endpoint.NotReal", value: "value4"}, +          %{group: ":pleroma", key: "Pleroma.Captcha.NotReal", value: "value5"}, +          %{group: ":not_real", key: ":anything", value: "value6"} +        ] +      }) + +      assert Application.get_env(:pleroma, :key1) == "value1" +      assert Application.get_env(:pleroma, :key2) == "value2" +      assert Application.get_env(:pleroma, :key3) == nil +      assert Application.get_env(:pleroma, Pleroma.Web.Endpoint.NotReal) == nil +      assert Application.get_env(:pleroma, Pleroma.Captcha.NotReal) == "value5" +      assert Application.get_env(:not_real, :anything) == "value6"      end    end @@ -3574,19 +3601,54 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do      end    end -  test "GET /api/pleroma/admin/config/descriptions", %{conn: conn} do -    admin = insert(:user, is_admin: true) +  describe "GET /api/pleroma/admin/config/descriptions" do +    test "structure", %{conn: conn} do +      admin = insert(:user, is_admin: true) -    conn = -      assign(conn, :user, admin) -      |> get("/api/pleroma/admin/config/descriptions") +      conn = +        assign(conn, :user, admin) +        |> get("/api/pleroma/admin/config/descriptions") -    assert [child | _others] = json_response(conn, 200) +      assert [child | _others] = json_response(conn, 200) + +      assert child["children"] +      assert child["key"] +      assert String.starts_with?(child["group"], ":") +      assert child["description"] +    end + +    test "filters by database configuration whitelist", %{conn: conn} do +      clear_config(:database_config_whitelist, [ +        {:pleroma, :instance}, +        {:pleroma, :activitypub}, +        {:pleroma, Pleroma.Upload}, +        {:esshd} +      ]) + +      admin = insert(:user, is_admin: true) -    assert child["children"] -    assert child["key"] -    assert String.starts_with?(child["group"], ":") -    assert child["description"] +      conn = +        assign(conn, :user, admin) +        |> get("/api/pleroma/admin/config/descriptions") + +      children = json_response(conn, 200) + +      assert length(children) == 4 + +      assert Enum.count(children, fn c -> c["group"] == ":pleroma" end) == 3 + +      instance = Enum.find(children, fn c -> c["key"] == ":instance" end) +      assert instance["children"] + +      activitypub = Enum.find(children, fn c -> c["key"] == ":activitypub" end) +      assert activitypub["children"] + +      web_endpoint = Enum.find(children, fn c -> c["key"] == "Pleroma.Upload" end) +      assert web_endpoint["children"] + +      esshd = Enum.find(children, fn c -> c["group"] == ":esshd" end) +      assert esshd["children"] +    end    end    describe "/api/pleroma/admin/stats" do diff --git a/test/web/feed/tag_controller_test.exs b/test/web/feed/tag_controller_test.exs index a54161bd4..3c29cd94f 100644 --- a/test/web/feed/tag_controller_test.exs +++ b/test/web/feed/tag_controller_test.exs @@ -138,8 +138,8 @@ defmodule Pleroma.Web.Feed.TagControllerTest do             ]      assert xpath(xml, ~x"//channel/item/pubDate/text()"sl) == [ -             FeedView.pub_date(activity1.data["published"]), -             FeedView.pub_date(activity2.data["published"]) +             FeedView.pub_date(activity2.data["published"]), +             FeedView.pub_date(activity1.data["published"])             ]      assert xpath(xml, ~x"//channel/item/enclosure/@url"sl) == [ diff --git a/test/web/mastodon_api/controllers/search_controller_test.exs b/test/web/mastodon_api/controllers/search_controller_test.exs index 6ad9a59fe..7d0cafccc 100644 --- a/test/web/mastodon_api/controllers/search_controller_test.exs +++ b/test/web/mastodon_api/controllers/search_controller_test.exs @@ -13,7 +13,7 @@ defmodule Pleroma.Web.MastodonAPI.SearchControllerTest do    import Tesla.Mock    import Mock -  setup do +  setup_all do      mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end)      :ok    end diff --git a/test/web/pleroma_api/controllers/account_controller_test.exs b/test/web/pleroma_api/controllers/account_controller_test.exs index 34fc4aa23..103997c31 100644 --- a/test/web/pleroma_api/controllers/account_controller_test.exs +++ b/test/web/pleroma_api/controllers/account_controller_test.exs @@ -31,8 +31,28 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do      test "resend account confirmation email", %{conn: conn, user: user} do        conn +      |> put_req_header("content-type", "application/json")        |> post("/api/v1/pleroma/accounts/confirmation_resend?email=#{user.email}") -      |> json_response(:no_content) +      |> json_response_and_validate_schema(:no_content) + +      ObanHelpers.perform_all() + +      email = Pleroma.Emails.UserEmail.account_confirmation_email(user) +      notify_email = Config.get([:instance, :notify_email]) +      instance_name = Config.get([:instance, :name]) + +      assert_email_sent( +        from: {instance_name, notify_email}, +        to: {user.name, user.email}, +        html_body: email.html_body +      ) +    end + +    test "resend account confirmation email (with nickname)", %{conn: conn, user: user} do +      conn +      |> put_req_header("content-type", "application/json") +      |> post("/api/v1/pleroma/accounts/confirmation_resend?nickname=#{user.nickname}") +      |> json_response_and_validate_schema(:no_content)        ObanHelpers.perform_all() @@ -54,7 +74,10 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do      test "user avatar can be set", %{user: user, conn: conn} do        avatar_image = File.read!("test/fixtures/avatar_data_uri") -      conn = patch(conn, "/api/v1/pleroma/accounts/update_avatar", %{img: avatar_image}) +      conn = +        conn +        |> put_req_header("content-type", "multipart/form-data") +        |> patch("/api/v1/pleroma/accounts/update_avatar", %{img: avatar_image})        user = refresh_record(user) @@ -70,17 +93,20 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do                 ]               } = user.avatar -      assert %{"url" => _} = json_response(conn, 200) +      assert %{"url" => _} = json_response_and_validate_schema(conn, 200)      end      test "user avatar can be reset", %{user: user, conn: conn} do -      conn = patch(conn, "/api/v1/pleroma/accounts/update_avatar", %{img: ""}) +      conn = +        conn +        |> put_req_header("content-type", "multipart/form-data") +        |> patch("/api/v1/pleroma/accounts/update_avatar", %{img: ""})        user = User.get_cached_by_id(user.id)        assert user.avatar == nil -      assert %{"url" => nil} = json_response(conn, 200) +      assert %{"url" => nil} = json_response_and_validate_schema(conn, 200)      end    end @@ -88,21 +114,27 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do      setup do: oauth_access(["write:accounts"])      test "can set profile banner", %{user: user, conn: conn} do -      conn = patch(conn, "/api/v1/pleroma/accounts/update_banner", %{"banner" => @image}) +      conn = +        conn +        |> put_req_header("content-type", "multipart/form-data") +        |> patch("/api/v1/pleroma/accounts/update_banner", %{"banner" => @image})        user = refresh_record(user)        assert user.banner["type"] == "Image" -      assert %{"url" => _} = json_response(conn, 200) +      assert %{"url" => _} = json_response_and_validate_schema(conn, 200)      end      test "can reset profile banner", %{user: user, conn: conn} do -      conn = patch(conn, "/api/v1/pleroma/accounts/update_banner", %{"banner" => ""}) +      conn = +        conn +        |> put_req_header("content-type", "multipart/form-data") +        |> patch("/api/v1/pleroma/accounts/update_banner", %{"banner" => ""})        user = refresh_record(user)        assert user.banner == %{} -      assert %{"url" => nil} = json_response(conn, 200) +      assert %{"url" => nil} = json_response_and_validate_schema(conn, 200)      end    end @@ -110,19 +142,26 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do      setup do: oauth_access(["write:accounts"])      test "background image can be set", %{user: user, conn: conn} do -      conn = patch(conn, "/api/v1/pleroma/accounts/update_background", %{"img" => @image}) +      conn = +        conn +        |> put_req_header("content-type", "multipart/form-data") +        |> patch("/api/v1/pleroma/accounts/update_background", %{"img" => @image})        user = refresh_record(user)        assert user.background["type"] == "Image" -      assert %{"url" => _} = json_response(conn, 200) +      # assert %{"url" => _} = json_response(conn, 200) +      assert %{"url" => _} = json_response_and_validate_schema(conn, 200)      end      test "background image can be reset", %{user: user, conn: conn} do -      conn = patch(conn, "/api/v1/pleroma/accounts/update_background", %{"img" => ""}) +      conn = +        conn +        |> put_req_header("content-type", "multipart/form-data") +        |> patch("/api/v1/pleroma/accounts/update_background", %{"img" => ""})        user = refresh_record(user)        assert user.background == %{} -      assert %{"url" => nil} = json_response(conn, 200) +      assert %{"url" => nil} = json_response_and_validate_schema(conn, 200)      end    end @@ -143,7 +182,7 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do        response =          conn          |> get("/api/v1/pleroma/accounts/#{user.id}/favourites") -        |> json_response(:ok) +        |> json_response_and_validate_schema(:ok)        [like] = response @@ -160,7 +199,7 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do        response =          build_conn()          |> get("/api/v1/pleroma/accounts/#{user.id}/favourites") -        |> json_response(200) +        |> json_response_and_validate_schema(200)        assert length(response) == 1      end @@ -183,7 +222,7 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do            |> assign(:user, u)            |> assign(:token, insert(:oauth_token, user: u, scopes: ["read:favourites"]))            |> get("/api/v1/pleroma/accounts/#{user.id}/favourites") -          |> json_response(:ok) +          |> json_response_and_validate_schema(:ok)          assert length(response) == 1        end @@ -191,7 +230,7 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do        response =          build_conn()          |> get("/api/v1/pleroma/accounts/#{user.id}/favourites") -        |> json_response(200) +        |> json_response_and_validate_schema(200)        assert length(response) == 0      end @@ -213,7 +252,7 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do        response =          conn          |> get("/api/v1/pleroma/accounts/#{user.id}/favourites") -        |> json_response(:ok) +        |> json_response_and_validate_schema(:ok)        assert Enum.empty?(response)      end @@ -233,11 +272,12 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do        response =          conn -        |> get("/api/v1/pleroma/accounts/#{user.id}/favourites", %{ -          since_id: third_activity.id, -          max_id: seventh_activity.id -        }) -        |> json_response(:ok) +        |> get( +          "/api/v1/pleroma/accounts/#{user.id}/favourites?since_id=#{third_activity.id}&max_id=#{ +            seventh_activity.id +          }" +        ) +        |> json_response_and_validate_schema(:ok)        assert length(response) == 3        refute third_activity in response @@ -256,8 +296,8 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do        response =          conn -        |> get("/api/v1/pleroma/accounts/#{user.id}/favourites", %{limit: "3"}) -        |> json_response(:ok) +        |> get("/api/v1/pleroma/accounts/#{user.id}/favourites?limit=3") +        |> json_response_and_validate_schema(:ok)        assert length(response) == 3      end @@ -269,7 +309,7 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do        response =          conn          |> get("/api/v1/pleroma/accounts/#{user.id}/favourites") -        |> json_response(:ok) +        |> json_response_and_validate_schema(:ok)        assert Enum.empty?(response)      end @@ -277,7 +317,7 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do      test "returns 404 error when specified user is not exist", %{conn: conn} do        conn = get(conn, "/api/v1/pleroma/accounts/test/favourites") -      assert json_response(conn, 404) == %{"error" => "Record not found"} +      assert json_response_and_validate_schema(conn, 404) == %{"error" => "Record not found"}      end      test "returns 403 error when user has hidden own favorites", %{conn: conn} do @@ -287,7 +327,7 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do        conn = get(conn, "/api/v1/pleroma/accounts/#{user.id}/favourites") -      assert json_response(conn, 403) == %{"error" => "Can't get favorites"} +      assert json_response_and_validate_schema(conn, 403) == %{"error" => "Can't get favorites"}      end      test "hides favorites for new users by default", %{conn: conn} do @@ -298,7 +338,7 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do        assert user.hide_favorites        conn = get(conn, "/api/v1/pleroma/accounts/#{user.id}/favourites") -      assert json_response(conn, 403) == %{"error" => "Can't get favorites"} +      assert json_response_and_validate_schema(conn, 403) == %{"error" => "Can't get favorites"}      end    end @@ -312,11 +352,12 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do          |> assign(:user, user)          |> post("/api/v1/pleroma/accounts/#{subscription_target.id}/subscribe") -      assert %{"id" => _id, "subscribing" => true} = json_response(ret_conn, 200) +      assert %{"id" => _id, "subscribing" => true} = +               json_response_and_validate_schema(ret_conn, 200)        conn = post(conn, "/api/v1/pleroma/accounts/#{subscription_target.id}/unsubscribe") -      assert %{"id" => _id, "subscribing" => false} = json_response(conn, 200) +      assert %{"id" => _id, "subscribing" => false} = json_response_and_validate_schema(conn, 200)      end    end @@ -326,7 +367,7 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do        conn = post(conn, "/api/v1/pleroma/accounts/target_id/subscribe") -      assert %{"error" => "Record not found"} = json_response(conn, 404) +      assert %{"error" => "Record not found"} = json_response_and_validate_schema(conn, 404)      end    end @@ -336,7 +377,7 @@ defmodule Pleroma.Web.PleromaAPI.AccountControllerTest do        conn = post(conn, "/api/v1/pleroma/accounts/target_id/unsubscribe") -      assert %{"error" => "Record not found"} = json_response(conn, 404) +      assert %{"error" => "Record not found"} = json_response_and_validate_schema(conn, 404)      end    end  end diff --git a/test/web/push/impl_test.exs b/test/web/push/impl_test.exs index 2fc3e73b5..2acd0939f 100644 --- a/test/web/push/impl_test.exs +++ b/test/web/push/impl_test.exs @@ -13,8 +13,8 @@ defmodule Pleroma.Web.Push.ImplTest do    import Pleroma.Factory -  setup_all do -    Tesla.Mock.mock_global(fn +  setup do +    Tesla.Mock.mock(fn        %{method: :post, url: "https://example.com/example/1234"} ->          %Tesla.Env{status: 200} diff --git a/test/web/rel_me_test.exs b/test/web/rel_me_test.exs index e05a8863d..65255916d 100644 --- a/test/web/rel_me_test.exs +++ b/test/web/rel_me_test.exs @@ -3,7 +3,7 @@  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Pleroma.Web.RelMeTest do -  use ExUnit.Case, async: true +  use ExUnit.Case    setup_all do      Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end) | 
