52 lines
1.5 KiB
Elixir
52 lines
1.5 KiB
Elixir
# Pleroma: A lightweight social networking server
|
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
defmodule Pleroma.Workers.ScheduledActivityWorkerTest do
|
|
use Pleroma.DataCase
|
|
|
|
alias Pleroma.ScheduledActivity
|
|
alias Pleroma.Workers.ScheduledActivityWorker
|
|
|
|
import Pleroma.Factory
|
|
import ExUnit.CaptureLog
|
|
|
|
setup do: clear_config([ScheduledActivity, :enabled])
|
|
|
|
test "creates a status from the scheduled activity" do
|
|
Pleroma.Config.put([ScheduledActivity, :enabled], true)
|
|
user = insert(:user)
|
|
|
|
naive_datetime =
|
|
NaiveDateTime.add(
|
|
NaiveDateTime.utc_now(),
|
|
-:timer.minutes(2),
|
|
:millisecond
|
|
)
|
|
|
|
scheduled_activity =
|
|
insert(
|
|
:scheduled_activity,
|
|
scheduled_at: naive_datetime,
|
|
user: user,
|
|
params: %{status: "hi"}
|
|
)
|
|
|
|
ScheduledActivityWorker.perform(
|
|
%{"activity_id" => scheduled_activity.id},
|
|
:pid
|
|
)
|
|
|
|
refute Repo.get(ScheduledActivity, scheduled_activity.id)
|
|
activity = Repo.all(Pleroma.Activity) |> Enum.find(&(&1.actor == user.ap_id))
|
|
assert Pleroma.Object.normalize(activity).data["content"] == "hi"
|
|
end
|
|
|
|
test "adds log message if ScheduledActivity isn't find" do
|
|
Pleroma.Config.put([ScheduledActivity, :enabled], true)
|
|
|
|
assert capture_log([level: :error], fn ->
|
|
ScheduledActivityWorker.perform(%{"activity_id" => 42}, :pid)
|
|
end) =~ "Couldn't find scheduled activity"
|
|
end
|
|
end
|