diff options
Diffstat (limited to 'test')
| -rw-r--r-- | test/web/activity_pub/activity_pub_test.exs | 4 | ||||
| -rw-r--r-- | test/web/twitter_api/twitter_api_controller_test.exs | 34 | ||||
| -rw-r--r-- | test/web/twitter_api/twitter_api_test.exs | 11 | 
3 files changed, 46 insertions, 3 deletions
diff --git a/test/web/activity_pub/activity_pub_test.exs b/test/web/activity_pub/activity_pub_test.exs index 081c202b1..bc33b4dfc 100644 --- a/test/web/activity_pub/activity_pub_test.exs +++ b/test/web/activity_pub/activity_pub_test.exs @@ -318,11 +318,9 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do        {:ok, announce_activity, object} = ActivityPub.announce(user, object)        assert object.data["announcement_count"] == 1 -      {:ok, unannounce_activity, activity, object} = ActivityPub.unannounce(user, object) +      {:ok, unannounce_activity, object} = ActivityPub.unannounce(user, object)        assert object.data["announcement_count"] == 0 -      assert activity == announce_activity -        assert unannounce_activity.data["to"] == [                 User.ap_followers(user),                 announce_activity.data["actor"] diff --git a/test/web/twitter_api/twitter_api_controller_test.exs b/test/web/twitter_api/twitter_api_controller_test.exs index bd11551df..806227110 100644 --- a/test/web/twitter_api/twitter_api_controller_test.exs +++ b/test/web/twitter_api/twitter_api_controller_test.exs @@ -580,6 +580,40 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do      end    end +  describe "POST /api/statuses/unretweet/:id" do +    setup [:valid_user] + +    test "without valid credentials", %{conn: conn} do +      note_activity = insert(:note_activity) +      conn = post(conn, "/api/statuses/unretweet/#{note_activity.id}.json") +      assert json_response(conn, 403) == %{"error" => "Invalid credentials."} +    end + +    test "with credentials", %{conn: conn, user: current_user} do +      note_activity = insert(:note_activity) + +      request_path = "/api/statuses/retweet/#{note_activity.id}.json" + +      _response = +        conn +        |> with_credentials(current_user.nickname, "test") +        |> post(request_path) + +      request_path = String.replace(request_path, "retweet", "unretweet") + +      response = +        conn +        |> with_credentials(current_user.nickname, "test") +        |> post(request_path) + +      activity = Repo.get(Activity, note_activity.id) +      activity_user = Repo.get_by(User, ap_id: note_activity.data["actor"]) + +      assert json_response(response, 200) == +               ActivityRepresenter.to_map(activity, %{user: activity_user, for: current_user}) +    end +  end +    describe "POST /api/account/register" do      test "it creates a new user", %{conn: conn} do        data = %{ diff --git a/test/web/twitter_api/twitter_api_test.exs b/test/web/twitter_api/twitter_api_test.exs index edacb312d..06c1ba6ec 100644 --- a/test/web/twitter_api/twitter_api_test.exs +++ b/test/web/twitter_api/twitter_api_test.exs @@ -228,6 +228,17 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPITest do      assert status == updated_activity    end +  test "it unretweets an already retweeted status" do +    user = insert(:user) +    note_activity = insert(:note_activity) + +    {:ok, _status} = TwitterAPI.repeat(user, note_activity.id) +    {:ok, status} = TwitterAPI.unrepeat(user, note_activity.id) +    updated_activity = Activity.get_by_ap_id(note_activity.data["id"]) + +    assert status == updated_activity +  end +    test "it registers a new user and returns the user." do      data = %{        "nickname" => "lain",  | 
