aboutsummaryrefslogtreecommitdiff
path: root/test/mix/tasks
diff options
context:
space:
mode:
authorlain <lain@soykaf.club>2019-08-08 14:38:33 +0000
committerlain <lain@soykaf.club>2019-08-08 14:38:33 +0000
commit29807ef6a5b43a528ffca08b4f721b251f331c8d (patch)
tree76930c3a3dc12b95bcb57a9b4832f861dd68d960 /test/mix/tasks
parentb18234e04c76daa564e0d8157dcd09566485da24 (diff)
parent9d4f34fbcb1a8e2eca424b3a3374c9f9af972574 (diff)
downloadpleroma-29807ef6a5b43a528ffca08b4f721b251f331c8d.tar.gz
Merge branch 'feature/digest-email' into 'develop'
Feature/digest email See merge request pleroma/pleroma!1078
Diffstat (limited to 'test/mix/tasks')
-rw-r--r--test/mix/tasks/pleroma.digest_test.exs51
1 files changed, 51 insertions, 0 deletions
diff --git a/test/mix/tasks/pleroma.digest_test.exs b/test/mix/tasks/pleroma.digest_test.exs
new file mode 100644
index 000000000..595f64ed7
--- /dev/null
+++ b/test/mix/tasks/pleroma.digest_test.exs
@@ -0,0 +1,51 @@
+defmodule Mix.Tasks.Pleroma.DigestTest do
+ use Pleroma.DataCase
+
+ import Pleroma.Factory
+ import Swoosh.TestAssertions
+
+ alias Pleroma.Web.CommonAPI
+
+ setup_all do
+ Mix.shell(Mix.Shell.Process)
+
+ on_exit(fn ->
+ Mix.shell(Mix.Shell.IO)
+ end)
+
+ :ok
+ end
+
+ describe "pleroma.digest test" do
+ test "Sends digest to the given user" do
+ user1 = insert(:user)
+ user2 = insert(:user)
+
+ Enum.each(0..10, fn i ->
+ {:ok, _activity} =
+ CommonAPI.post(user1, %{
+ "status" => "hey ##{i} @#{user2.nickname}!"
+ })
+ end)
+
+ yesterday =
+ NaiveDateTime.add(
+ NaiveDateTime.truncate(NaiveDateTime.utc_now(), :second),
+ -60 * 60 * 24,
+ :second
+ )
+
+ {:ok, yesterday_date} = Timex.format(yesterday, "%F", :strftime)
+
+ :ok = Mix.Tasks.Pleroma.Digest.run(["test", user2.nickname, yesterday_date])
+
+ assert_receive {:mix_shell, :info, [message]}
+ assert message =~ "Digest email have been sent"
+
+ assert_email_sent(
+ to: {user2.name, user2.email},
+ html_body: ~r/new mentions:/i
+ )
+ end
+ end
+end