mirror of
https://git.pleroma.social/pleroma/pleroma.git
synced 2025-01-20 14:08:10 +00:00
Test that a poll refresh is cancelled if updated_at on the object is newer than the poll closing time
This commit is contained in:
parent
b2340b5b77
commit
a1b384f63c
1 changed files with 40 additions and 21 deletions
|
@ -53,32 +53,51 @@ defmodule Pleroma.Workers.PollWorkerTest do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
test "poll refresh job" do
|
describe "poll refresh" do
|
||||||
user = insert(:user, local: false)
|
test "normal job" do
|
||||||
question = insert(:question, user: user)
|
user = insert(:user, local: false)
|
||||||
activity = insert(:question_activity, question: question)
|
question = insert(:question, user: user)
|
||||||
|
activity = insert(:question_activity, question: question)
|
||||||
|
|
||||||
PollWorker.new(%{"op" => "refresh", "activity_id" => activity.id})
|
PollWorker.new(%{"op" => "refresh", "activity_id" => activity.id})
|
||||||
|> Oban.insert()
|
|> Oban.insert()
|
||||||
|
|
||||||
expected_job_args = %{"activity_id" => activity.id, "op" => "refresh"}
|
expected_job_args = %{"activity_id" => activity.id, "op" => "refresh"}
|
||||||
|
|
||||||
assert_enqueued(args: expected_job_args)
|
assert_enqueued(args: expected_job_args)
|
||||||
|
|
||||||
|
with_mocks([
|
||||||
|
{
|
||||||
|
Pleroma.Web.Streamer,
|
||||||
|
[],
|
||||||
|
[
|
||||||
|
stream: fn _, _ -> nil end
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]) do
|
||||||
|
[job] = all_enqueued(worker: PollWorker)
|
||||||
|
PollWorker.perform(job)
|
||||||
|
|
||||||
|
# Ensure updates are streamed out
|
||||||
|
assert called(Pleroma.Web.Streamer.stream(["user", "list", "public", "public:local"], :_))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
test "when updated_at is after poll closing" do
|
||||||
|
poll_closed = DateTime.utc_now() |> DateTime.add(-86_400) |> DateTime.to_iso8601()
|
||||||
|
user = insert(:user, local: false)
|
||||||
|
question = insert(:question, user: user, closed: poll_closed)
|
||||||
|
activity = insert(:question_activity, question: question)
|
||||||
|
|
||||||
|
PollWorker.new(%{"op" => "refresh", "activity_id" => activity.id})
|
||||||
|
|> Oban.insert()
|
||||||
|
|
||||||
|
expected_job_args = %{"activity_id" => activity.id, "op" => "refresh"}
|
||||||
|
|
||||||
|
assert_enqueued(args: expected_job_args)
|
||||||
|
|
||||||
with_mocks([
|
|
||||||
{
|
|
||||||
Pleroma.Web.Streamer,
|
|
||||||
[],
|
|
||||||
[
|
|
||||||
stream: fn _, _ -> nil end
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]) do
|
|
||||||
[job] = all_enqueued(worker: PollWorker)
|
[job] = all_enqueued(worker: PollWorker)
|
||||||
PollWorker.perform(job)
|
assert {:cancel, :poll_finalized} = PollWorker.perform(job)
|
||||||
|
|
||||||
# Ensure updates are streamed out
|
|
||||||
assert called(Pleroma.Web.Streamer.stream(["user", "list", "public", "public:local"], :_))
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue