diff options
Diffstat (limited to 'test/web/mastodon_api/controllers')
| -rw-r--r-- | test/web/mastodon_api/controllers/auth_controller_test.exs | 22 | ||||
| -rw-r--r-- | test/web/mastodon_api/controllers/status_controller_test.exs | 38 | 
2 files changed, 53 insertions, 7 deletions
| diff --git a/test/web/mastodon_api/controllers/auth_controller_test.exs b/test/web/mastodon_api/controllers/auth_controller_test.exs index a485f8e41..4fa95fce1 100644 --- a/test/web/mastodon_api/controllers/auth_controller_test.exs +++ b/test/web/mastodon_api/controllers/auth_controller_test.exs @@ -122,17 +122,27 @@ defmodule Pleroma.Web.MastodonAPI.AuthControllerTest do        {:ok, user: user}      end -    test "it returns 404 when user is not found", %{conn: conn, user: user} 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.status == 404 -      assert conn.resp_body == "" + +      assert conn +             |> json_response(:no_content)      end -    test "it returns 400 when user is not local", %{conn: conn, user: user} do +    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.status == 400 -      assert conn.resp_body == "" + +      assert conn +             |> json_response(:no_content) +    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)      end    end diff --git a/test/web/mastodon_api/controllers/status_controller_test.exs b/test/web/mastodon_api/controllers/status_controller_test.exs index 5955d8334..f221884e7 100644 --- a/test/web/mastodon_api/controllers/status_controller_test.exs +++ b/test/web/mastodon_api/controllers/status_controller_test.exs @@ -296,9 +296,45 @@ defmodule Pleroma.Web.MastodonAPI.StatusControllerTest do        assert real_status == fake_status      end +    test "fake statuses' preview card is not cached", %{conn: conn} do +      clear_config([:rich_media, :enabled], true) + +      Tesla.Mock.mock(fn +        %{ +          method: :get, +          url: "https://example.com/twitter-card" +        } -> +          %Tesla.Env{status: 200, body: File.read!("test/fixtures/rich_media/twitter_card.html")} + +        env -> +          apply(HttpRequestMock, :request, [env]) +      end) + +      conn1 = +        conn +        |> put_req_header("content-type", "application/json") +        |> post("/api/v1/statuses", %{ +          "status" => "https://example.com/ogp", +          "preview" => true +        }) + +      conn2 = +        conn +        |> put_req_header("content-type", "application/json") +        |> post("/api/v1/statuses", %{ +          "status" => "https://example.com/twitter-card", +          "preview" => true +        }) + +      assert %{"card" => %{"title" => "The Rock"}} = json_response_and_validate_schema(conn1, 200) + +      assert %{"card" => %{"title" => "Small Island Developing States Photo Submission"}} = +               json_response_and_validate_schema(conn2, 200) +    end +      test "posting a status with OGP link preview", %{conn: conn} do        Tesla.Mock.mock(fn env -> apply(HttpRequestMock, :request, [env]) end) -      Config.put([:rich_media, :enabled], true) +      clear_config([:rich_media, :enabled], true)        conn =          conn | 
