diff options
| author | Roman Chvanikov <chvanikoff@gmail.com> | 2019-04-17 16:58:08 +0700 | 
|---|---|---|
| committer | Roman Chvanikov <chvanikoff@gmail.com> | 2019-04-17 16:58:08 +0700 | 
| commit | 87013f843853250e8b15696900e09afb92d22aac (patch) | |
| tree | 72491ebe110dbd191485a5f7aa1b80e6359e848b /test/web/mastodon_api/mastodon_api_controller_test.exs | |
| parent | dc21181f6504b55afa68de63f170fcb0f1084a6b (diff) | |
| parent | 8de17c480e4267a46ae8d862a3c8918aa6734c39 (diff) | |
| download | pleroma-87013f843853250e8b15696900e09afb92d22aac.tar.gz pleroma-87013f843853250e8b15696900e09afb92d22aac.zip | |
Merge branch 'develop' of git.pleroma.social:pleroma/pleroma into feature/digest-email
Diffstat (limited to 'test/web/mastodon_api/mastodon_api_controller_test.exs')
| -rw-r--r-- | test/web/mastodon_api/mastodon_api_controller_test.exs | 80 | 
1 files changed, 75 insertions, 5 deletions
| diff --git a/test/web/mastodon_api/mastodon_api_controller_test.exs b/test/web/mastodon_api/mastodon_api_controller_test.exs index 292cd46b8..f21cf677d 100644 --- a/test/web/mastodon_api/mastodon_api_controller_test.exs +++ b/test/web/mastodon_api/mastodon_api_controller_test.exs @@ -342,7 +342,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do      activity = Activity.get_by_id(id)      assert activity.data["context"] == replied_to.data["context"] -    assert activity.data["object"]["inReplyToStatusId"] == replied_to.id +    assert Activity.get_in_reply_to_activity(activity).id == replied_to.id    end    test "posting a status with an invalid in_reply_to_id", %{conn: conn} do @@ -1008,8 +1008,41 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do          |> assign(:user, user)          |> post("/api/v1/statuses/#{activity.id}/reblog") -      assert %{"reblog" => %{"id" => id, "reblogged" => true, "reblogs_count" => 1}} = -               json_response(conn, 200) +      assert %{ +               "reblog" => %{"id" => id, "reblogged" => true, "reblogs_count" => 1}, +               "reblogged" => true +             } = json_response(conn, 200) + +      assert to_string(activity.id) == id +    end + +    test "reblogged status for another user", %{conn: conn} do +      activity = insert(:note_activity) +      user1 = insert(:user) +      user2 = insert(:user) +      user3 = insert(:user) +      {:ok, reblog_activity1, _object} = CommonAPI.repeat(activity.id, user1) +      {:ok, _, _object} = CommonAPI.repeat(activity.id, user2) + +      conn_res = +        conn +        |> assign(:user, user3) +        |> get("/api/v1/statuses/#{reblog_activity1.id}") + +      assert %{ +               "reblog" => %{"id" => id, "reblogged" => false, "reblogs_count" => 2}, +               "reblogged" => false +             } = json_response(conn_res, 200) + +      conn_res = +        conn +        |> assign(:user, user2) +        |> get("/api/v1/statuses/#{reblog_activity1.id}") + +      assert %{ +               "reblog" => %{"id" => id, "reblogged" => true, "reblogs_count" => 2}, +               "reblogged" => true +             } = json_response(conn_res, 200)        assert to_string(activity.id) == id      end @@ -1587,6 +1620,40 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do      assert id == to_string(other_user.id)    end +  test "following / unfollowing errors" do +    user = insert(:user) + +    conn = +      build_conn() +      |> assign(:user, user) + +    # self follow +    conn_res = post(conn, "/api/v1/accounts/#{user.id}/follow") +    assert %{"error" => "Record not found"} = json_response(conn_res, 404) + +    # self unfollow +    user = User.get_cached_by_id(user.id) +    conn_res = post(conn, "/api/v1/accounts/#{user.id}/unfollow") +    assert %{"error" => "Record not found"} = json_response(conn_res, 404) + +    # self follow via uri +    user = User.get_cached_by_id(user.id) +    conn_res = post(conn, "/api/v1/follows", %{"uri" => user.nickname}) +    assert %{"error" => "Record not found"} = json_response(conn_res, 404) + +    # follow non existing user +    conn_res = post(conn, "/api/v1/accounts/doesntexist/follow") +    assert %{"error" => "Record not found"} = json_response(conn_res, 404) + +    # follow non existing user via uri +    conn_res = post(conn, "/api/v1/follows", %{"uri" => "doesntexist"}) +    assert %{"error" => "Record not found"} = json_response(conn_res, 404) + +    # unfollow non existing user +    conn_res = post(conn, "/api/v1/accounts/doesntexist/unfollow") +    assert %{"error" => "Record not found"} = json_response(conn_res, 404) +  end +    test "muting / unmuting a user", %{conn: conn} do      user = insert(:user)      other_user = insert(:user) @@ -1981,13 +2048,14 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do      conn = get(conn, "/api/v1/instance")      assert result = json_response(conn, 200) +    email = Pleroma.Config.get([:instance, :email])      # Note: not checking for "max_toot_chars" since it's optional      assert %{               "uri" => _,               "title" => _,               "description" => _,               "version" => _, -             "email" => _, +             "email" => from_config_email,               "urls" => %{                 "streaming_api" => _               }, @@ -1996,6 +2064,8 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do               "languages" => _,               "registrations" => _             } = result + +    assert email == from_config_email    end    test "get instance stats", %{conn: conn} do @@ -2724,7 +2794,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do      activity = Activity.get_by_id(id)      assert activity.data["object"]["inReplyTo"] == replied_to.data["object"]["id"] -    assert activity.data["object"]["inReplyToStatusId"] == replied_to.id +    assert Activity.get_in_reply_to_activity(activity).id == replied_to.id      # Reblog from the third user      conn2 = | 
