diff options
Diffstat (limited to 'test/workers/cron')
4 files changed, 176 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..df82dc75d --- /dev/null +++ b/test/workers/cron/clear_oauth_token_worker_test.exs @@ -0,0 +1,22 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 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 + +  setup do: 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..f9bc50db5 --- /dev/null +++ b/test/workers/cron/digest_emails_worker_test.exs @@ -0,0 +1,54 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 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 + +  setup do: clear_config([:email_notifications, :digest]) + +  setup 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}!"}) + +    {:ok, user2: user2} +  end + +  test "it sends digest emails", %{user2: user2} do +    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 + +  test "it doesn't fail when a user has no email", %{user2: user2} do +    {:ok, _} = user2 |> Ecto.Changeset.change(%{email: nil}) |> Pleroma.Repo.update() + +    Pleroma.Workers.Cron.DigestEmailsWorker.perform(:opts, :pid) +    # Performing job(s) enqueued at previous step +    ObanHelpers.perform_all() +  end +end diff --git a/test/workers/cron/new_users_digest_worker_test.exs b/test/workers/cron/new_users_digest_worker_test.exs new file mode 100644 index 000000000..54cf0ca46 --- /dev/null +++ b/test/workers/cron/new_users_digest_worker_test.exs @@ -0,0 +1,44 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Workers.Cron.NewUsersDigestWorkerTest do +  use Pleroma.DataCase +  import Pleroma.Factory + +  alias Pleroma.Tests.ObanHelpers +  alias Pleroma.Web.CommonAPI +  alias Pleroma.Workers.Cron.NewUsersDigestWorker + +  test "it sends new users digest emails" do +    yesterday = NaiveDateTime.utc_now() |> Timex.shift(days: -1) +    admin = insert(:user, %{is_admin: true}) +    user = insert(:user, %{inserted_at: yesterday}) +    user2 = insert(:user, %{inserted_at: yesterday}) +    CommonAPI.post(user, %{status: "cofe"}) + +    NewUsersDigestWorker.perform(nil, nil) +    ObanHelpers.perform_all() + +    assert_received {:email, email} +    assert email.to == [{admin.name, admin.email}] +    assert email.subject == "#{Pleroma.Config.get([:instance, :name])} New Users" + +    refute email.html_body =~ admin.nickname +    assert email.html_body =~ user.nickname +    assert email.html_body =~ user2.nickname +    assert email.html_body =~ "cofe" +  end + +  test "it doesn't fail when admin has no email" do +    yesterday = NaiveDateTime.utc_now() |> Timex.shift(days: -1) +    insert(:user, %{is_admin: true, email: nil}) +    insert(:user, %{inserted_at: yesterday}) +    user = insert(:user, %{inserted_at: yesterday}) + +    CommonAPI.post(user, %{status: "cofe"}) + +    NewUsersDigestWorker.perform(nil, nil) +    ObanHelpers.perform_all() +  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..5864f9e5f --- /dev/null +++ b/test/workers/cron/purge_expired_activities_worker_test.exs @@ -0,0 +1,56 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 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 + +  setup do: 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 | 
