aboutsummaryrefslogtreecommitdiff
path: root/test/web/retry_queue_test.exs
diff options
context:
space:
mode:
authorMichael Loftis <mloftis@wgops.com>2018-12-30 15:16:26 +0000
committerMichael Loftis <mloftis@wgops.com>2018-12-30 15:16:26 +0000
commitcb286fdeba1782b75d1d7bca484d80e3cd499a98 (patch)
tree66fb0f4ddbe71664d757bcc581c1f5db81e647c2 /test/web/retry_queue_test.exs
parentf5d7b0003ea200d13abca2cbd4e4f59db9658231 (diff)
downloadpleroma-cb286fdeba1782b75d1d7bca484d80e3cd499a98.tar.gz
Improves RetryQueue behavior
reduces to one single timer firing once a second switches to a parallel worker model
Diffstat (limited to 'test/web/retry_queue_test.exs')
-rw-r--r--test/web/retry_queue_test.exs31
1 files changed, 22 insertions, 9 deletions
diff --git a/test/web/retry_queue_test.exs b/test/web/retry_queue_test.exs
index 9351b6c24..ecb3ce5d0 100644
--- a/test/web/retry_queue_test.exs
+++ b/test/web/retry_queue_test.exs
@@ -3,7 +3,8 @@
# SPDX-License-Identifier: AGPL-3.0-only
defmodule MockActivityPub do
- def publish_one(ret) do
+ def publish_one({ret, waiter}) do
+ send(waiter, :complete)
{ret, "success"}
end
end
@@ -15,21 +16,33 @@ defmodule Pleroma.Web.Federator.RetryQueueTest do
@small_retry_count 0
@hopeless_retry_count 10
+ setup do
+ RetryQueue.reset_stats()
+ end
+
+ test "RetryQueue responds to stats request" do
+ assert %{delivered: 0, dropped: 0} == RetryQueue.get_stats()
+ end
+
test "failed posts are retried" do
{:retry, _timeout} = RetryQueue.get_retry_params(@small_retry_count)
- assert {:noreply, %{delivered: 1}} ==
- RetryQueue.handle_info({:send, :ok, MockActivityPub, @small_retry_count}, %{
- delivered: 0
- })
+ wait_task =
+ Task.async(fn ->
+ receive do
+ :complete -> :ok
+ end
+ end)
+
+ RetryQueue.enqueue({:ok, wait_task.pid}, MockActivityPub, @small_retry_count)
+ Task.await(wait_task)
+ assert %{delivered: 1, dropped: 0} == RetryQueue.get_stats()
end
test "posts that have been tried too many times are dropped" do
{:drop, _timeout} = RetryQueue.get_retry_params(@hopeless_retry_count)
- assert {:noreply, %{dropped: 1}} ==
- RetryQueue.handle_cast({:maybe_enqueue, %{}, nil, @hopeless_retry_count}, %{
- dropped: 0
- })
+ RetryQueue.enqueue({:ok, nil}, MockActivityPub, @hopeless_retry_count)
+ assert %{delivered: 0, dropped: 1} == RetryQueue.get_stats()
end
end