summaryrefslogtreecommitdiff
path: root/test/workers/cron/digest_emails_worker_test.exs
diff options
context:
space:
mode:
authorIvan Tashkinov <ivantashkinov@gmail.com>2020-03-06 11:48:30 +0300
committerIvan Tashkinov <ivantashkinov@gmail.com>2020-03-06 11:48:30 +0300
commit027714b519cca63ac943369d0bcc9534ba448a80 (patch)
treeab331c60efe243bd6eb79c95b67dc797bb165078 /test/workers/cron/digest_emails_worker_test.exs
parent40765875d41f181b4ac54a772b4c61d6afc0bc34 (diff)
parent47604907c9d2379d0883d63bc7add5782cc25d63 (diff)
downloadpleroma-027714b519cca63ac943369d0bcc9534ba448a80.tar.gz
pleroma-027714b519cca63ac943369d0bcc9534ba448a80.zip
Merge remote-tracking branch 'remotes/origin/develop' into 1560-non-federating-instances-routes-restrictions
Diffstat (limited to 'test/workers/cron/digest_emails_worker_test.exs')
-rw-r--r--test/workers/cron/digest_emails_worker_test.exs14
1 files changed, 13 insertions, 1 deletions
diff --git a/test/workers/cron/digest_emails_worker_test.exs b/test/workers/cron/digest_emails_worker_test.exs
index 66e16b810..5d65b9fef 100644
--- a/test/workers/cron/digest_emails_worker_test.exs
+++ b/test/workers/cron/digest_emails_worker_test.exs
@@ -13,7 +13,7 @@ defmodule Pleroma.Workers.Cron.DigestEmailsWorkerTest do
clear_config([:email_notifications, :digest])
- test "it sends digest emails" do
+ setup do
Pleroma.Config.put([:email_notifications, :digest], %{
active: true,
inactivity_threshold: 7,
@@ -31,6 +31,10 @@ defmodule Pleroma.Workers.Cron.DigestEmailsWorkerTest do
{: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()
@@ -39,4 +43,12 @@ defmodule Pleroma.Workers.Cron.DigestEmailsWorkerTest do
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