2018-12-23 15:11:29 -05:00
|
|
|
# Pleroma: A lightweight social networking server
|
|
|
|
# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/>
|
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2018-11-19 11:08:41 -05:00
|
|
|
defmodule MockActivityPub do
|
2018-12-30 10:16:26 -05:00
|
|
|
def publish_one({ret, waiter}) do
|
|
|
|
send(waiter, :complete)
|
2018-11-19 11:08:41 -05:00
|
|
|
{ret, "success"}
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-12-11 07:31:52 -05:00
|
|
|
defmodule Pleroma.Web.Federator.RetryQueueTest do
|
2018-11-19 11:08:41 -05:00
|
|
|
use Pleroma.DataCase
|
|
|
|
alias Pleroma.Web.Federator.RetryQueue
|
|
|
|
|
|
|
|
@small_retry_count 0
|
|
|
|
@hopeless_retry_count 10
|
|
|
|
|
2018-12-30 10:16:26 -05:00
|
|
|
setup do
|
|
|
|
RetryQueue.reset_stats()
|
|
|
|
end
|
|
|
|
|
|
|
|
test "RetryQueue responds to stats request" do
|
|
|
|
assert %{delivered: 0, dropped: 0} == RetryQueue.get_stats()
|
|
|
|
end
|
|
|
|
|
2018-11-19 11:08:41 -05:00
|
|
|
test "failed posts are retried" do
|
|
|
|
{:retry, _timeout} = RetryQueue.get_retry_params(@small_retry_count)
|
|
|
|
|
2018-12-30 10:16:26 -05:00
|
|
|
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()
|
2018-11-19 11:08:41 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
test "posts that have been tried too many times are dropped" do
|
|
|
|
{:drop, _timeout} = RetryQueue.get_retry_params(@hopeless_retry_count)
|
|
|
|
|
2018-12-30 10:16:26 -05:00
|
|
|
RetryQueue.enqueue({:ok, nil}, MockActivityPub, @hopeless_retry_count)
|
|
|
|
assert %{delivered: 0, dropped: 1} == RetryQueue.get_stats()
|
2018-11-19 11:08:41 -05:00
|
|
|
end
|
|
|
|
end
|