diff options
Diffstat (limited to 'test')
| -rw-r--r-- | test/user_test.exs | 28 | ||||
| -rw-r--r-- | test/web/activity_pub/side_effects_test.exs | 25 | ||||
| -rw-r--r-- | test/web/auth/pleroma_authenticator_test.exs | 2 | ||||
| -rw-r--r-- | test/web/auth/totp_authenticator_test.exs | 2 | ||||
| -rw-r--r-- | test/web/common_api/common_api_test.exs | 18 | ||||
| -rw-r--r-- | test/web/mastodon_api/controllers/account_controller/update_credentials_test.exs | 7 | ||||
| -rw-r--r-- | test/web/mastodon_api/controllers/instance_controller_test.exs | 3 | ||||
| -rw-r--r-- | test/web/mastodon_api/controllers/status_controller_test.exs | 6 | ||||
| -rw-r--r-- | test/web/mastodon_api/views/status_view_test.exs | 10 | ||||
| -rw-r--r-- | test/web/media_proxy/invalidations/http_test.exs | 35 | ||||
| -rw-r--r-- | test/web/media_proxy/invalidations/script_test.exs | 20 | ||||
| -rw-r--r-- | test/web/pleroma_api/controllers/mascot_controller_test.exs | 25 | ||||
| -rw-r--r-- | test/web/pleroma_api/controllers/scrobble_controller_test.exs | 26 | ||||
| -rw-r--r-- | test/web/pleroma_api/views/scrobble_view_test.exs | 20 | 
14 files changed, 182 insertions, 45 deletions
| diff --git a/test/user_test.exs b/test/user_test.exs index 6b9df60a4..863e0106c 100644 --- a/test/user_test.exs +++ b/test/user_test.exs @@ -555,6 +555,7 @@ defmodule Pleroma.UserTest do        assert user == fetched_user      end +    @tag capture_log: true      test "returns nil if no user could be fetched" do        {:error, fetched_user} = User.get_or_fetch_by_nickname("nonexistant@social.heldscal.la")        assert fetched_user == "not found nonexistant@social.heldscal.la" @@ -1171,6 +1172,33 @@ defmodule Pleroma.UserTest do      end    end +  describe "delete/1 when confirmation is pending" do +    setup do +      user = insert(:user, confirmation_pending: true) +      {:ok, user: user} +    end + +    test "deletes user from database when activation required", %{user: user} do +      clear_config([:instance, :account_activation_required], true) + +      {:ok, job} = User.delete(user) +      {:ok, _} = ObanHelpers.perform(job) + +      refute User.get_cached_by_id(user.id) +      refute User.get_by_id(user.id) +    end + +    test "deactivates user when activation is not required", %{user: user} do +      clear_config([:instance, :account_activation_required], false) + +      {:ok, job} = User.delete(user) +      {:ok, _} = ObanHelpers.perform(job) + +      assert %{deactivated: true} = User.get_cached_by_id(user.id) +      assert %{deactivated: true} = User.get_by_id(user.id) +    end +  end +    test "get_public_key_for_ap_id fetches a user that's not in the db" do      assert {:ok, _key} = User.get_public_key_for_ap_id("http://mastodon.example.org/users/admin")    end diff --git a/test/web/activity_pub/side_effects_test.exs b/test/web/activity_pub/side_effects_test.exs index 797f00d08..a46254a05 100644 --- a/test/web/activity_pub/side_effects_test.exs +++ b/test/web/activity_pub/side_effects_test.exs @@ -140,6 +140,31 @@ defmodule Pleroma.Web.ActivityPub.SideEffectsTest do      end    end +  describe "delete users with confirmation pending" do +    setup do +      user = insert(:user, confirmation_pending: true) +      {:ok, delete_user_data, _meta} = Builder.delete(user, user.ap_id) +      {:ok, delete_user, _meta} = ActivityPub.persist(delete_user_data, local: true) +      {:ok, delete: delete_user, user: user} +    end + +    test "when activation is not required", %{delete: delete, user: user} do +      clear_config([:instance, :account_activation_required], false) +      {:ok, _, _} = SideEffects.handle(delete) +      ObanHelpers.perform_all() + +      assert User.get_cached_by_id(user.id).deactivated +    end + +    test "when activation is required", %{delete: delete, user: user} do +      clear_config([:instance, :account_activation_required], true) +      {:ok, _, _} = SideEffects.handle(delete) +      ObanHelpers.perform_all() + +      refute User.get_cached_by_id(user.id) +    end +  end +    describe "Undo objects" do      setup do        poster = insert(:user) diff --git a/test/web/auth/pleroma_authenticator_test.exs b/test/web/auth/pleroma_authenticator_test.exs index 731bd5932..1ba0dfecc 100644 --- a/test/web/auth/pleroma_authenticator_test.exs +++ b/test/web/auth/pleroma_authenticator_test.exs @@ -1,5 +1,5 @@  # Pleroma: A lightweight social networking server -# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Pleroma.Web.Auth.PleromaAuthenticatorTest do diff --git a/test/web/auth/totp_authenticator_test.exs b/test/web/auth/totp_authenticator_test.exs index e502e0ae8..84d4cd840 100644 --- a/test/web/auth/totp_authenticator_test.exs +++ b/test/web/auth/totp_authenticator_test.exs @@ -1,5 +1,5 @@  # Pleroma: A lightweight social networking server -# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Pleroma.Web.Auth.TOTPAuthenticatorTest do diff --git a/test/web/common_api/common_api_test.exs b/test/web/common_api/common_api_test.exs index fd8299013..52e95397c 100644 --- a/test/web/common_api/common_api_test.exs +++ b/test/web/common_api/common_api_test.exs @@ -841,10 +841,10 @@ defmodule Pleroma.Web.CommonAPITest do        {:ok, activity} =          CommonAPI.listen(user, %{ -          "title" => "lain radio episode 1", -          "album" => "lain radio", -          "artist" => "lain", -          "length" => 180_000 +          title: "lain radio episode 1", +          album: "lain radio", +          artist: "lain", +          length: 180_000          })        object = Object.normalize(activity) @@ -859,11 +859,11 @@ defmodule Pleroma.Web.CommonAPITest do        {:ok, activity} =          CommonAPI.listen(user, %{ -          "title" => "lain radio episode 1", -          "album" => "lain radio", -          "artist" => "lain", -          "length" => 180_000, -          "visibility" => "private" +          title: "lain radio episode 1", +          album: "lain radio", +          artist: "lain", +          length: 180_000, +          visibility: "private"          })        object = Object.normalize(activity) diff --git a/test/web/mastodon_api/controllers/account_controller/update_credentials_test.exs b/test/web/mastodon_api/controllers/account_controller/update_credentials_test.exs index fdb6d4c5d..696228203 100644 --- a/test/web/mastodon_api/controllers/account_controller/update_credentials_test.exs +++ b/test/web/mastodon_api/controllers/account_controller/update_credentials_test.exs @@ -112,6 +112,13 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIController.UpdateCredentialsTest do        assert user_data["source"]["privacy"] == "unlisted"      end +    test "updates the user's privacy", %{conn: conn} do +      conn = patch(conn, "/api/v1/accounts/update_credentials", %{source: %{privacy: "unlisted"}}) + +      assert user_data = json_response_and_validate_schema(conn, 200) +      assert user_data["source"]["privacy"] == "unlisted" +    end +      test "updates the user's hide_followers status", %{conn: conn} do        conn = patch(conn, "/api/v1/accounts/update_credentials", %{hide_followers: "true"}) diff --git a/test/web/mastodon_api/controllers/instance_controller_test.exs b/test/web/mastodon_api/controllers/instance_controller_test.exs index 2c61dc5ba..8bdfdddd1 100644 --- a/test/web/mastodon_api/controllers/instance_controller_test.exs +++ b/test/web/mastodon_api/controllers/instance_controller_test.exs @@ -31,7 +31,8 @@ defmodule Pleroma.Web.MastodonAPI.InstanceControllerTest do               "upload_limit" => _,               "avatar_upload_limit" => _,               "background_upload_limit" => _, -             "banner_upload_limit" => _ +             "banner_upload_limit" => _, +             "background_image" => _             } = result      assert result["pleroma"]["metadata"]["features"] diff --git a/test/web/mastodon_api/controllers/status_controller_test.exs b/test/web/mastodon_api/controllers/status_controller_test.exs index bdee88fd3..962e64b03 100644 --- a/test/web/mastodon_api/controllers/status_controller_test.exs +++ b/test/web/mastodon_api/controllers/status_controller_test.exs @@ -62,7 +62,7 @@ defmodule Pleroma.Web.MastodonAPI.StatusControllerTest do          |> post("/api/v1/statuses", %{            "status" => "cofe",            "spoiler_text" => "2hu", -          "sensitive" => "false" +          "sensitive" => "0"          })        {:ok, ttl} = Cachex.ttl(:idempotency_cache, idempotency_key) @@ -81,7 +81,7 @@ defmodule Pleroma.Web.MastodonAPI.StatusControllerTest do          |> post("/api/v1/statuses", %{            "status" => "cofe",            "spoiler_text" => "2hu", -          "sensitive" => "false" +          "sensitive" => 0          })        assert %{"id" => second_id} = json_response(conn_two, 200) @@ -93,7 +93,7 @@ defmodule Pleroma.Web.MastodonAPI.StatusControllerTest do          |> post("/api/v1/statuses", %{            "status" => "cofe",            "spoiler_text" => "2hu", -          "sensitive" => "false" +          "sensitive" => "False"          })        assert %{"id" => third_id} = json_response_and_validate_schema(conn_three, 200) diff --git a/test/web/mastodon_api/views/status_view_test.exs b/test/web/mastodon_api/views/status_view_test.exs index 5d7adbe29..43e3bdca1 100644 --- a/test/web/mastodon_api/views/status_view_test.exs +++ b/test/web/mastodon_api/views/status_view_test.exs @@ -620,14 +620,4 @@ defmodule Pleroma.Web.MastodonAPI.StatusViewTest do      assert status.visibility == "list"    end - -  test "successfully renders a Listen activity (pleroma extension)" do -    listen_activity = insert(:listen) - -    status = StatusView.render("listen.json", activity: listen_activity) - -    assert status.length == listen_activity.data["object"]["length"] -    assert status.title == listen_activity.data["object"]["title"] -    assert_schema(status, "Status", Pleroma.Web.ApiSpec.spec()) -  end  end diff --git a/test/web/media_proxy/invalidations/http_test.exs b/test/web/media_proxy/invalidations/http_test.exs new file mode 100644 index 000000000..8a3b4141c --- /dev/null +++ b/test/web/media_proxy/invalidations/http_test.exs @@ -0,0 +1,35 @@ +defmodule Pleroma.Web.MediaProxy.Invalidation.HttpTest do +  use ExUnit.Case +  alias Pleroma.Web.MediaProxy.Invalidation + +  import ExUnit.CaptureLog +  import Tesla.Mock + +  test "logs hasn't error message when request is valid" do +    mock(fn +      %{method: :purge, url: "http://example.com/media/example.jpg"} -> +        %Tesla.Env{status: 200} +    end) + +    refute capture_log(fn -> +             assert Invalidation.Http.purge( +                      ["http://example.com/media/example.jpg"], +                      %{} +                    ) == {:ok, "success"} +           end) =~ "Error while cache purge" +  end + +  test "it write error message in logs when request invalid" do +    mock(fn +      %{method: :purge, url: "http://example.com/media/example1.jpg"} -> +        %Tesla.Env{status: 404} +    end) + +    assert capture_log(fn -> +             assert Invalidation.Http.purge( +                      ["http://example.com/media/example1.jpg"], +                      %{} +                    ) == {:ok, "success"} +           end) =~ "Error while cache purge: url - http://example.com/media/example1.jpg" +  end +end diff --git a/test/web/media_proxy/invalidations/script_test.exs b/test/web/media_proxy/invalidations/script_test.exs new file mode 100644 index 000000000..1358963ab --- /dev/null +++ b/test/web/media_proxy/invalidations/script_test.exs @@ -0,0 +1,20 @@ +defmodule Pleroma.Web.MediaProxy.Invalidation.ScriptTest do +  use ExUnit.Case +  alias Pleroma.Web.MediaProxy.Invalidation + +  import ExUnit.CaptureLog + +  test "it logger error when script not found" do +    assert capture_log(fn -> +             assert Invalidation.Script.purge( +                      ["http://example.com/media/example.jpg"], +                      %{script_path: "./example"} +                    ) == {:error, "\"%ErlangError{original: :enoent}\""} +           end) =~ "Error while cache purge: \"%ErlangError{original: :enoent}\"" + +    assert Invalidation.Script.purge( +             ["http://example.com/media/example.jpg"], +             %{} +           ) == {:error, "not found script path"} +  end +end diff --git a/test/web/pleroma_api/controllers/mascot_controller_test.exs b/test/web/pleroma_api/controllers/mascot_controller_test.exs index 617831b02..e2ead6e15 100644 --- a/test/web/pleroma_api/controllers/mascot_controller_test.exs +++ b/test/web/pleroma_api/controllers/mascot_controller_test.exs @@ -16,9 +16,12 @@ defmodule Pleroma.Web.PleromaAPI.MascotControllerTest do        filename: "sound.mp3"      } -    ret_conn = put(conn, "/api/v1/pleroma/mascot", %{"file" => non_image_file}) +    ret_conn = +      conn +      |> put_req_header("content-type", "multipart/form-data") +      |> put("/api/v1/pleroma/mascot", %{"file" => non_image_file}) -    assert json_response(ret_conn, 415) +    assert json_response_and_validate_schema(ret_conn, 415)      file = %Plug.Upload{        content_type: "image/jpg", @@ -26,9 +29,12 @@ defmodule Pleroma.Web.PleromaAPI.MascotControllerTest do        filename: "an_image.jpg"      } -    conn = put(conn, "/api/v1/pleroma/mascot", %{"file" => file}) +    conn = +      conn +      |> put_req_header("content-type", "multipart/form-data") +      |> put("/api/v1/pleroma/mascot", %{"file" => file}) -    assert %{"id" => _, "type" => image} = json_response(conn, 200) +    assert %{"id" => _, "type" => image} = json_response_and_validate_schema(conn, 200)    end    test "mascot retrieving" do @@ -37,7 +43,7 @@ defmodule Pleroma.Web.PleromaAPI.MascotControllerTest do      # When user hasn't set a mascot, we should just get pleroma tan back      ret_conn = get(conn, "/api/v1/pleroma/mascot") -    assert %{"url" => url} = json_response(ret_conn, 200) +    assert %{"url" => url} = json_response_and_validate_schema(ret_conn, 200)      assert url =~ "pleroma-fox-tan-smol"      # When a user sets their mascot, we should get that back @@ -47,9 +53,12 @@ defmodule Pleroma.Web.PleromaAPI.MascotControllerTest do        filename: "an_image.jpg"      } -    ret_conn = put(conn, "/api/v1/pleroma/mascot", %{"file" => file}) +    ret_conn = +      conn +      |> put_req_header("content-type", "multipart/form-data") +      |> put("/api/v1/pleroma/mascot", %{"file" => file}) -    assert json_response(ret_conn, 200) +    assert json_response_and_validate_schema(ret_conn, 200)      user = User.get_cached_by_id(user.id) @@ -58,7 +67,7 @@ defmodule Pleroma.Web.PleromaAPI.MascotControllerTest do        |> assign(:user, user)        |> get("/api/v1/pleroma/mascot") -    assert %{"url" => url, "type" => "image"} = json_response(conn, 200) +    assert %{"url" => url, "type" => "image"} = json_response_and_validate_schema(conn, 200)      assert url =~ "an_image"    end  end diff --git a/test/web/pleroma_api/controllers/scrobble_controller_test.exs b/test/web/pleroma_api/controllers/scrobble_controller_test.exs index 1b945040c..f39c07ac6 100644 --- a/test/web/pleroma_api/controllers/scrobble_controller_test.exs +++ b/test/web/pleroma_api/controllers/scrobble_controller_test.exs @@ -12,14 +12,16 @@ defmodule Pleroma.Web.PleromaAPI.ScrobbleControllerTest do        %{conn: conn} = oauth_access(["write"])        conn = -        post(conn, "/api/v1/pleroma/scrobble", %{ +        conn +        |> put_req_header("content-type", "application/json") +        |> post("/api/v1/pleroma/scrobble", %{            "title" => "lain radio episode 1",            "artist" => "lain",            "album" => "lain radio",            "length" => "180000"          }) -      assert %{"title" => "lain radio episode 1"} = json_response(conn, 200) +      assert %{"title" => "lain radio episode 1"} = json_response_and_validate_schema(conn, 200)      end    end @@ -29,28 +31,28 @@ defmodule Pleroma.Web.PleromaAPI.ScrobbleControllerTest do        {:ok, _activity} =          CommonAPI.listen(user, %{ -          "title" => "lain radio episode 1", -          "artist" => "lain", -          "album" => "lain radio" +          title: "lain radio episode 1", +          artist: "lain", +          album: "lain radio"          })        {:ok, _activity} =          CommonAPI.listen(user, %{ -          "title" => "lain radio episode 2", -          "artist" => "lain", -          "album" => "lain radio" +          title: "lain radio episode 2", +          artist: "lain", +          album: "lain radio"          })        {:ok, _activity} =          CommonAPI.listen(user, %{ -          "title" => "lain radio episode 3", -          "artist" => "lain", -          "album" => "lain radio" +          title: "lain radio episode 3", +          artist: "lain", +          album: "lain radio"          })        conn = get(conn, "/api/v1/pleroma/accounts/#{user.id}/scrobbles") -      result = json_response(conn, 200) +      result = json_response_and_validate_schema(conn, 200)        assert length(result) == 3      end diff --git a/test/web/pleroma_api/views/scrobble_view_test.exs b/test/web/pleroma_api/views/scrobble_view_test.exs new file mode 100644 index 000000000..6bdb56509 --- /dev/null +++ b/test/web/pleroma_api/views/scrobble_view_test.exs @@ -0,0 +1,20 @@ +# 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.StatusViewTest do +  use Pleroma.DataCase + +  alias Pleroma.Web.PleromaAPI.ScrobbleView + +  import Pleroma.Factory + +  test "successfully renders a Listen activity (pleroma extension)" do +    listen_activity = insert(:listen) + +    status = ScrobbleView.render("show.json", activity: listen_activity) + +    assert status.length == listen_activity.data["object"]["length"] +    assert status.title == listen_activity.data["object"]["title"] +  end +end | 
