diff options
| author | kaniini <nenolod@gmail.com> | 2019-01-17 03:19:55 +0000 | 
|---|---|---|
| committer | kaniini <nenolod@gmail.com> | 2019-01-17 03:19:55 +0000 | 
| commit | ce2efd1ee25d6e06c4bc5c0d97aad7b84c7c6874 (patch) | |
| tree | 7e2b60fb3be7407f756cd5e0a24660c6f2b18e65 /test/web | |
| parent | 608cc65d43277016a22500771360598775a3df1e (diff) | |
| parent | 943324b66158d1bd2449894ec41bc544c56058a7 (diff) | |
| download | pleroma-ce2efd1ee25d6e06c4bc5c0d97aad7b84c7c6874.tar.gz pleroma-ce2efd1ee25d6e06c4bc5c0d97aad7b84c7c6874.zip  | |
Merge branch 'resilient-user-view-2' into 'develop'
MastoAPI: Don't break on missing users.
See merge request pleroma/pleroma!675
Diffstat (limited to 'test/web')
| -rw-r--r-- | test/web/mastodon_api/status_view_test.exs | 30 | 
1 files changed, 30 insertions, 0 deletions
diff --git a/test/web/mastodon_api/status_view_test.exs b/test/web/mastodon_api/status_view_test.exs index 1076b5002..d30ae6149 100644 --- a/test/web/mastodon_api/status_view_test.exs +++ b/test/web/mastodon_api/status_view_test.exs @@ -19,6 +19,36 @@ defmodule Pleroma.Web.MastodonAPI.StatusViewTest do      :ok    end +  test "returns a temporary ap_id based user for activities missing db users" do +    user = insert(:user) + +    {:ok, activity} = CommonAPI.post(user, %{"status" => "Hey @shp!", "visibility" => "direct"}) + +    Repo.delete(user) +    Cachex.clear(:user_cache) + +    %{account: ms_user} = StatusView.render("status.json", activity: activity) + +    assert ms_user.acct == "erroruser@example.com" +  end + +  test "tries to get a user by nickname if fetching by ap_id doesn't work" do +    user = insert(:user) + +    {:ok, activity} = CommonAPI.post(user, %{"status" => "Hey @shp!", "visibility" => "direct"}) + +    {:ok, user} = +      user +      |> Ecto.Changeset.change(%{ap_id: "#{user.ap_id}/extension/#{user.nickname}"}) +      |> Repo.update() + +    Cachex.clear(:user_cache) + +    result = StatusView.render("status.json", activity: activity) + +    assert result[:account][:id] == to_string(user.id) +  end +    test "a note with null content" do      note = insert(:note_activity)  | 
