diff options
Diffstat (limited to 'test/workers/cron')
| -rw-r--r-- | test/workers/cron/clear_oauth_token_worker_test.exs | 22 | ||||
| -rw-r--r-- | test/workers/cron/digest_emails_worker_test.exs | 42 | ||||
| -rw-r--r-- | test/workers/cron/purge_expired_activities_worker_test.exs | 34 | 
3 files changed, 98 insertions, 0 deletions
| diff --git a/test/workers/cron/clear_oauth_token_worker_test.exs b/test/workers/cron/clear_oauth_token_worker_test.exs new file mode 100644 index 000000000..adea47326 --- /dev/null +++ b/test/workers/cron/clear_oauth_token_worker_test.exs @@ -0,0 +1,22 @@ +# 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.ClearOauthTokenWorkerTest do +  use Pleroma.DataCase + +  import Pleroma.Factory +  alias Pleroma.Workers.Cron.ClearOauthTokenWorker + +  clear_config([:oauth2, :clean_expired_tokens]) + +  test "deletes expired tokens" do +    insert(:oauth_token, +      valid_until: NaiveDateTime.add(NaiveDateTime.utc_now(), -60 * 10) +    ) + +    Pleroma.Config.put([:oauth2, :clean_expired_tokens], true) +    ClearOauthTokenWorker.perform(:opts, :job) +    assert Pleroma.Repo.all(Pleroma.Web.OAuth.Token) == [] +  end +end diff --git a/test/workers/cron/digest_emails_worker_test.exs b/test/workers/cron/digest_emails_worker_test.exs new file mode 100644 index 000000000..073615d9e --- /dev/null +++ b/test/workers/cron/digest_emails_worker_test.exs @@ -0,0 +1,42 @@ +# 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.DigestEmailsWorkerTest do +  use Pleroma.DataCase + +  import Pleroma.Factory + +  alias Pleroma.Tests.ObanHelpers +  alias Pleroma.User +  alias Pleroma.Web.CommonAPI + +  clear_config([:email_notifications, :digest]) + +  test "it sends digest emails" do +    Pleroma.Config.put([:email_notifications, :digest], %{ +      active: true, +      inactivity_threshold: 7, +      interval: 7 +    }) + +    user = insert(:user) + +    date = +      Timex.now() +      |> Timex.shift(days: -10) +      |> Timex.to_naive_datetime() + +    user2 = insert(:user, last_digest_emailed_at: date) +    {:ok, _} = User.switch_email_notifications(user2, "digest", true) +    CommonAPI.post(user, %{"status" => "hey @#{user2.nickname}!"}) + +    Pleroma.Workers.Cron.DigestEmailsWorker.perform(:opts, :pid) +    # Performing job(s) enqueued at previous step +    ObanHelpers.perform_all() + +    assert_received {:email, email} +    assert email.to == [{user2.name, user2.email}] +    assert email.subject == "Your digest from #{Pleroma.Config.get(:instance)[:name]}" +  end +end diff --git a/test/workers/cron/purge_expired_activities_worker_test.exs b/test/workers/cron/purge_expired_activities_worker_test.exs new file mode 100644 index 000000000..07980bcd0 --- /dev/null +++ b/test/workers/cron/purge_expired_activities_worker_test.exs @@ -0,0 +1,34 @@ +# 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 +  import Pleroma.Factory + +  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 +end | 
