diff options
author | lain <lain@soykaf.club> | 2020-04-22 18:40:53 +0200 |
---|---|---|
committer | lain <lain@soykaf.club> | 2020-04-22 18:40:53 +0200 |
commit | e62173dfc8b739508345b7ab97477ae04fcdb457 (patch) | |
tree | ccdd932fd8e4bf0c74b2bbc2041f3218f6b5c0e7 /test | |
parent | 1cd38dfffa88384284a8ae0be39f52f25c544936 (diff) | |
download | pleroma-e62173dfc8b739508345b7ab97477ae04fcdb457.tar.gz pleroma-e62173dfc8b739508345b7ab97477ae04fcdb457.zip |
SideEffects: Run in transaction.
This fixes race conditions.
Diffstat (limited to 'test')
-rw-r--r-- | test/web/common_api/common_api_test.exs | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/test/web/common_api/common_api_test.exs b/test/web/common_api/common_api_test.exs index e130736ec..68a29108a 100644 --- a/test/web/common_api/common_api_test.exs +++ b/test/web/common_api/common_api_test.exs @@ -21,6 +21,33 @@ defmodule Pleroma.Web.CommonAPITest do setup do: clear_config([:instance, :limit]) setup do: clear_config([:instance, :max_pinned_statuses]) + test "favoriting race condition" do + user = insert(:user) + users_serial = insert_list(10, :user) + users = insert_list(10, :user) + + {:ok, activity} = CommonAPI.post(user, %{"status" => "."}) + + users_serial + |> Enum.map(fn user -> + CommonAPI.favorite(user, activity.id) + end) + + object = Object.get_by_ap_id(activity.data["object"]) + assert object.data["like_count"] == 10 + + users + |> Enum.map(fn user -> + Task.async(fn -> + CommonAPI.favorite(user, activity.id) + end) + end) + |> Enum.map(&Task.await/1) + + object = Object.get_by_ap_id(activity.data["object"]) + assert object.data["like_count"] == 20 + end + test "when replying to a conversation / participation, it will set the correct context id even if no explicit reply_to is given" do user = insert(:user) {:ok, activity} = CommonAPI.post(user, %{"status" => ".", "visibility" => "direct"}) |