forked from AkkomaGang/akkoma
56 lines
1.7 KiB
Elixir
56 lines
1.7 KiB
Elixir
# Pleroma: A lightweight social networking server
|
|
# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
defmodule Pleroma.Workers.Cron.PurgeExpiredActivitiesWorkerTest do
|
|
use Pleroma.DataCase
|
|
|
|
alias Pleroma.ActivityExpiration
|
|
alias Pleroma.Workers.Cron.PurgeExpiredActivitiesWorker
|
|
|
|
import Pleroma.Factory
|
|
import ExUnit.CaptureLog
|
|
|
|
clear_config([ActivityExpiration, :enabled])
|
|
|
|
test "deletes an expiration activity" do
|
|
Pleroma.Config.put([ActivityExpiration, :enabled], true)
|
|
activity = insert(:note_activity)
|
|
|
|
naive_datetime =
|
|
NaiveDateTime.add(
|
|
NaiveDateTime.utc_now(),
|
|
-:timer.minutes(2),
|
|
:millisecond
|
|
)
|
|
|
|
expiration =
|
|
insert(
|
|
:expiration_in_the_past,
|
|
%{activity_id: activity.id, scheduled_at: naive_datetime}
|
|
)
|
|
|
|
Pleroma.Workers.Cron.PurgeExpiredActivitiesWorker.perform(:ops, :pid)
|
|
|
|
refute Pleroma.Repo.get(Pleroma.Activity, activity.id)
|
|
refute Pleroma.Repo.get(Pleroma.ActivityExpiration, expiration.id)
|
|
end
|
|
|
|
describe "delete_activity/1" do
|
|
test "adds log message if activity isn't find" do
|
|
assert capture_log([level: :error], fn ->
|
|
PurgeExpiredActivitiesWorker.delete_activity(%ActivityExpiration{
|
|
activity_id: "test-activity"
|
|
})
|
|
end) =~ "Couldn't delete expired activity: not found activity"
|
|
end
|
|
|
|
test "adds log message if actor isn't find" do
|
|
assert capture_log([level: :error], fn ->
|
|
PurgeExpiredActivitiesWorker.delete_activity(%ActivityExpiration{
|
|
activity_id: "test-activity"
|
|
})
|
|
end) =~ "Couldn't delete expired activity: not found activity"
|
|
end
|
|
end
|
|
end
|