diff options
Diffstat (limited to 'test/web')
| -rw-r--r-- | test/web/admin_api/admin_api_controller_test.exs | 4 | ||||
| -rw-r--r-- | test/web/mastodon_api/controllers/status_controller_test.exs | 47 | 
2 files changed, 37 insertions, 14 deletions
| diff --git a/test/web/admin_api/admin_api_controller_test.exs b/test/web/admin_api/admin_api_controller_test.exs index 45b22ea24..8009d4386 100644 --- a/test/web/admin_api/admin_api_controller_test.exs +++ b/test/web/admin_api/admin_api_controller_test.exs @@ -1880,10 +1880,10 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do                 "@#{admin.nickname} deleted status ##{id}"      end -    test "returns error when status is not exist", %{conn: conn} do +    test "returns 404 when the status does not exist", %{conn: conn} do        conn = delete(conn, "/api/pleroma/admin/statuses/test") -      assert json_response(conn, :bad_request) == "Could not delete" +      assert json_response(conn, :not_found) == "Not found"      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 9c2ceda5d..fbf63f608 100644 --- a/test/web/mastodon_api/controllers/status_controller_test.exs +++ b/test/web/mastodon_api/controllers/status_controller_test.exs @@ -476,6 +476,15 @@ defmodule Pleroma.Web.MastodonAPI.StatusControllerTest do      assert id == to_string(activity.id)    end +  test "getting a status that doesn't exist returns 404" do +    %{conn: conn} = oauth_access(["read:statuses"]) +    activity = insert(:note_activity) + +    conn = get(conn, "/api/v1/statuses/#{String.downcase(activity.id)}") + +    assert json_response(conn, 404) == %{"error" => "Record not found"} +  end +    test "get a direct status" do      %{user: user, conn: conn} = oauth_access(["read:statuses"])      other_user = insert(:user) @@ -520,6 +529,18 @@ defmodule Pleroma.Web.MastodonAPI.StatusControllerTest do        refute Activity.get_by_id(activity.id)      end +    test "when it doesn't exist" do +      %{user: author, conn: conn} = oauth_access(["write:statuses"]) +      activity = insert(:note_activity, user: author) + +      conn = +        conn +        |> assign(:user, author) +        |> delete("/api/v1/statuses/#{String.downcase(activity.id)}") + +      assert %{"error" => "Record not found"} == json_response(conn, 404) +    end +      test "when you didn't create it" do        %{conn: conn} = oauth_access(["write:statuses"])        activity = insert(:note_activity) @@ -574,6 +595,14 @@ defmodule Pleroma.Web.MastodonAPI.StatusControllerTest do        assert to_string(activity.id) == id      end +    test "returns 404 if the reblogged status doesn't exist", %{conn: conn} do +      activity = insert(:note_activity) + +      conn = post(conn, "/api/v1/statuses/#{String.downcase(activity.id)}/reblog") + +      assert %{"error" => "Record not found"} = json_response(conn, 404) +    end +      test "reblogs privately and returns the reblogged status", %{conn: conn} do        activity = insert(:note_activity) @@ -626,12 +655,6 @@ defmodule Pleroma.Web.MastodonAPI.StatusControllerTest do        assert to_string(activity.id) == id      end - -    test "returns 400 error when activity is not exist", %{conn: conn} do -      conn = post(conn, "/api/v1/statuses/foo/reblog") - -      assert json_response(conn, 400) == %{"error" => "Could not repeat"} -    end    end    describe "unreblogging" do @@ -649,10 +672,10 @@ defmodule Pleroma.Web.MastodonAPI.StatusControllerTest do        assert to_string(activity.id) == id      end -    test "returns 400 error when activity is not exist", %{conn: conn} do +    test "returns 404 error when activity does not exist", %{conn: conn} do        conn = post(conn, "/api/v1/statuses/foo/unreblog") -      assert json_response(conn, 400) == %{"error" => "Could not unrepeat"} +      assert json_response(conn, 404) == %{"error" => "Record not found"}      end    end @@ -677,10 +700,10 @@ defmodule Pleroma.Web.MastodonAPI.StatusControllerTest do        assert post(conn, "/api/v1/statuses/#{activity.id}/favourite") |> json_response(200)      end -    test "returns 400 error for a wrong id", %{conn: conn} do +    test "returns 404 error for a wrong id", %{conn: conn} do        conn = post(conn, "/api/v1/statuses/1/favourite") -      assert json_response(conn, 400) == %{"error" => "Could not favorite"} +      assert json_response(conn, 404) == %{"error" => "Record not found"}      end    end @@ -700,10 +723,10 @@ defmodule Pleroma.Web.MastodonAPI.StatusControllerTest do        assert to_string(activity.id) == id      end -    test "returns 400 error for a wrong id", %{conn: conn} do +    test "returns 404 error for a wrong id", %{conn: conn} do        conn = post(conn, "/api/v1/statuses/1/unfavourite") -      assert json_response(conn, 400) == %{"error" => "Could not unfavorite"} +      assert json_response(conn, 404) == %{"error" => "Record not found"}      end    end | 
