diff options
| author | lain <lain@soykaf.club> | 2018-05-13 10:56:11 +0200 | 
|---|---|---|
| committer | lain <lain@soykaf.club> | 2018-05-13 10:56:11 +0200 | 
| commit | 76722ea9c8dfbb8fefe247883946aa5c872d9a49 (patch) | |
| tree | 34020541df1d6684e935cfd09f36cb6eed7b13f6 /test | |
| parent | a3d1d4894fdd8dd0133e1d2c6fde9d95f49dfcc7 (diff) | |
| parent | bb864e96ad4e0be470da78baa000019f571e30db (diff) | |
| download | pleroma-76722ea9c8dfbb8fefe247883946aa5c872d9a49.tar.gz pleroma-76722ea9c8dfbb8fefe247883946aa5c872d9a49.zip | |
Merge branch 'develop' into kaniini/pleroma-bugfix/unlisted-statuses
Diffstat (limited to 'test')
| -rw-r--r-- | test/notification_test.exs | 7 | ||||
| -rw-r--r-- | test/support/builders/activity_builder.ex | 2 | ||||
| -rw-r--r-- | test/support/httpoison_mock.ex | 6 | ||||
| -rw-r--r-- | test/web/mastodon_api/mastodon_api_controller_test.exs | 38 | ||||
| -rw-r--r-- | test/web/streamer_test.exs | 63 | ||||
| -rw-r--r-- | test/web/twitter_api/twitter_api_controller_test.exs | 18 | 
6 files changed, 127 insertions, 7 deletions
| diff --git a/test/notification_test.exs b/test/notification_test.exs index 568ad642c..2ca1ac13d 100644 --- a/test/notification_test.exs +++ b/test/notification_test.exs @@ -33,6 +33,13 @@ defmodule Pleroma.NotificationTest do        assert nil == Notification.create_notification(activity, user)      end + +    test "it doesn't create a notification for user if he is the activity author" do +      activity = insert(:note_activity) +      author = User.get_by_ap_id(activity.data["actor"]) + +      assert nil == Notification.create_notification(activity, author) +    end    end    describe "get notification" do diff --git a/test/support/builders/activity_builder.ex b/test/support/builders/activity_builder.ex index d9c188955..eb72d5ba9 100644 --- a/test/support/builders/activity_builder.ex +++ b/test/support/builders/activity_builder.ex @@ -26,7 +26,7 @@ defmodule Pleroma.Builders.ActivityBuilder do    end    def insert_list(times, data \\ %{}, opts \\ %{}) do -    Enum.map(1..times, fn n -> +    Enum.map(1..times, fn _n ->        {:ok, activity} = insert(data, opts)        activity      end) diff --git a/test/support/httpoison_mock.ex b/test/support/httpoison_mock.ex index ba35c4460..4a5a9ea85 100644 --- a/test/support/httpoison_mock.ex +++ b/test/support/httpoison_mock.ex @@ -367,7 +367,7 @@ defmodule HTTPoisonMock do    def post(          "https://social.heldscal.la/main/push/hub", -        {:form, data}, +        {:form, _data},          "Content-type": "application/x-www-form-urlencoded"        ) do      {:ok, @@ -711,11 +711,11 @@ defmodule HTTPoisonMock do       }"}    end -  def post(url, body, headers) do +  def post(url, _body, _headers) do      {:error, "Not implemented the mock response for post #{inspect(url)}"}    end -  def post(url, body, headers, options) do +  def post(url, _body, _headers, _options) do      {:error, "Not implemented the mock response for post #{inspect(url)}"}    end  end diff --git a/test/web/mastodon_api/mastodon_api_controller_test.exs b/test/web/mastodon_api/mastodon_api_controller_test.exs index 5293b9364..883ebc61e 100644 --- a/test/web/mastodon_api/mastodon_api_controller_test.exs +++ b/test/web/mastodon_api/mastodon_api_controller_test.exs @@ -63,19 +63,53 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do    test "posting a status", %{conn: conn} do      user = insert(:user) -    conn = +    idempotency_key = "Pikachu rocks!" + +    conn_one =        conn        |> assign(:user, user) +      |> put_req_header("idempotency-key", idempotency_key)        |> post("/api/v1/statuses", %{          "status" => "cofe",          "spoiler_text" => "2hu",          "sensitive" => "false"        }) +    {:ok, ttl} = Cachex.ttl(:idempotency_cache, idempotency_key) +    # Six hours +    assert ttl > :timer.seconds(6 * 60 * 60 - 1) +      assert %{"content" => "cofe", "id" => id, "spoiler_text" => "2hu", "sensitive" => false} = -             json_response(conn, 200) +             json_response(conn_one, 200)      assert Repo.get(Activity, id) + +    conn_two = +      conn +      |> assign(:user, user) +      |> put_req_header("idempotency-key", idempotency_key) +      |> post("/api/v1/statuses", %{ +        "status" => "cofe", +        "spoiler_text" => "2hu", +        "sensitive" => "false" +      }) + +    assert %{"id" => second_id} = json_response(conn_two, 200) + +    assert id == second_id + +    conn_three = +      conn +      |> assign(:user, user) +      |> post("/api/v1/statuses", %{ +        "status" => "cofe", +        "spoiler_text" => "2hu", +        "sensitive" => "false" +      }) + +    assert %{"id" => third_id} = json_response(conn_three, 200) + +    refute id == third_id    end    test "posting a sensitive status", %{conn: conn} do diff --git a/test/web/streamer_test.exs b/test/web/streamer_test.exs new file mode 100644 index 000000000..47d491d1b --- /dev/null +++ b/test/web/streamer_test.exs @@ -0,0 +1,63 @@ +defmodule Pleroma.Web.StreamerTest do +  use Pleroma.DataCase + +  alias Pleroma.Web.Streamer +  alias Pleroma.User +  alias Pleroma.Web.CommonAPI +  import Pleroma.Factory + +  test "it sends to public" do +    user = insert(:user) +    other_user = insert(:user) + +    task = +      Task.async(fn -> +        assert_receive {:text, _}, 4_000 +      end) + +    fake_socket = %{ +      transport_pid: task.pid, +      assigns: %{ +        user: user +      } +    } + +    {:ok, activity} = CommonAPI.post(other_user, %{"status" => "Test"}) + +    topics = %{ +      "public" => [fake_socket] +    } + +    Streamer.push_to_socket(topics, "public", activity) + +    Task.await(task) +  end + +  test "it doesn't send to blocked users" do +    user = insert(:user) +    blocked_user = insert(:user) +    {:ok, user} = User.block(user, blocked_user) + +    task = +      Task.async(fn -> +        refute_receive {:text, _}, 1_000 +      end) + +    fake_socket = %{ +      transport_pid: task.pid, +      assigns: %{ +        user: user +      } +    } + +    {:ok, activity} = CommonAPI.post(blocked_user, %{"status" => "Test"}) + +    topics = %{ +      "public" => [fake_socket] +    } + +    Streamer.push_to_socket(topics, "public", activity) + +    Task.await(task) +  end +end diff --git a/test/web/twitter_api/twitter_api_controller_test.exs b/test/web/twitter_api/twitter_api_controller_test.exs index 406dace1c..896fe246d 100644 --- a/test/web/twitter_api/twitter_api_controller_test.exs +++ b/test/web/twitter_api/twitter_api_controller_test.exs @@ -257,8 +257,10 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do      end      test "with credentials", %{conn: conn, user: current_user} do +      other_user = insert(:user) +        {:ok, activity} = -        ActivityBuilder.insert(%{"to" => [current_user.ap_id]}, %{user: current_user}) +        ActivityBuilder.insert(%{"to" => [current_user.ap_id]}, %{user: other_user})        conn =          conn @@ -784,4 +786,18 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do        assert status["id"] == activity.id      end    end + +  test "Convert newlines to <br> in bio", %{conn: conn} do +    user = insert(:user) + +    conn = +      conn +      |> assign(:user, user) +      |> post("/api/account/update_profile.json", %{ +        "description" => "Hello,\r\nWorld! I\n am a test." +      }) + +    user = Repo.get!(User, user.id) +    assert user.bio == "Hello,<br>World! I<br> am a test." +  end  end | 
