diff options
| author | Maksim Pechnikov <parallel588@gmail.com> | 2019-12-04 21:18:05 +0300 | 
|---|---|---|
| committer | Maksim Pechnikov <parallel588@gmail.com> | 2019-12-04 21:18:05 +0300 | 
| commit | 3c3bba0b7c65187b3270ef3402442cf870a55198 (patch) | |
| tree | 1727e2999f8e957fc96a8fbd6e4bd1dd7676884a | |
| parent | c0d572d0bf842fae08c609aa58c82554bee3a263 (diff) | |
| download | pleroma-3c3bba0b7c65187b3270ef3402442cf870a55198.tar.gz pleroma-3c3bba0b7c65187b3270ef3402442cf870a55198.zip | |
fix ScheduledActivity
| -rw-r--r-- | lib/pleroma/scheduled_activity.ex | 17 | ||||
| -rw-r--r-- | test/scheduled_activity_test.exs | 36 | ||||
| -rw-r--r-- | test/web/mastodon_api/controllers/scheduled_activity_controller_test.exs | 4 | 
3 files changed, 51 insertions, 6 deletions
| diff --git a/lib/pleroma/scheduled_activity.ex b/lib/pleroma/scheduled_activity.ex index ea78dce6a..d01100702 100644 --- a/lib/pleroma/scheduled_activity.ex +++ b/lib/pleroma/scheduled_activity.ex @@ -119,11 +119,7 @@ defmodule Pleroma.ScheduledActivity do    def create(%User{} = user, attrs) do      Multi.new()      |> Multi.insert(:scheduled_activity, new(user, attrs)) -    |> Multi.run(:scheduled_activity_job, fn _repo, %{scheduled_activity: activity} -> -      %{activity_id: activity.id} -      |> ScheduledActivityWorker.new(scheduled_at: activity.scheduled_at) -      |> Oban.insert() -    end) +    |> maybe_add_jobs(Config.get([ScheduledActivity, :enabled]))      |> Repo.transaction()      |> case do        {:ok, %{scheduled_activity: scheduled_activity}} -> @@ -134,6 +130,17 @@ defmodule Pleroma.ScheduledActivity do      end    end +  defp maybe_add_jobs(multi, true) do +    multi +    |> Multi.run(:scheduled_activity_job, fn _repo, %{scheduled_activity: activity} -> +      %{activity_id: activity.id} +      |> ScheduledActivityWorker.new(scheduled_at: activity.scheduled_at) +      |> Oban.insert() +    end) +  end + +  defp maybe_add_jobs(multi, _), do: multi +    def get(%User{} = user, scheduled_activity_id) do      ScheduledActivity      |> where(user_id: ^user.id) diff --git a/test/scheduled_activity_test.exs b/test/scheduled_activity_test.exs index b367ae5fb..d2c5f5aa2 100644 --- a/test/scheduled_activity_test.exs +++ b/test/scheduled_activity_test.exs @@ -15,7 +15,8 @@ defmodule Pleroma.ScheduledActivityTest do    end    describe "creation" do -    test "when daily user limit is exceeded" do +    test "scheduled activities with jobs when ScheduledActivity enabled" do +      Pleroma.Config.put([ScheduledActivity, :enabled], true)        user = insert(:user)        today = @@ -31,6 +32,39 @@ defmodule Pleroma.ScheduledActivityTest do          Repo.all(from(j in Oban.Job, where: j.queue == "scheduled_activities", select: j.args))        assert jobs == [%{"activity_id" => sa1.id}, %{"activity_id" => sa2.id}] +    end + +    test "scheduled activities without jobs when ScheduledActivity disabled" do +      Pleroma.Config.put([ScheduledActivity, :enabled], false) +      user = insert(:user) + +      today = +        NaiveDateTime.utc_now() +        |> NaiveDateTime.add(:timer.minutes(6), :millisecond) +        |> NaiveDateTime.to_iso8601() + +      attrs = %{params: %{}, scheduled_at: today} +      {:ok, _sa1} = ScheduledActivity.create(user, attrs) +      {:ok, _sa2} = ScheduledActivity.create(user, attrs) + +      jobs = +        Repo.all(from(j in Oban.Job, where: j.queue == "scheduled_activities", select: j.args)) + +      assert jobs == [] +    end + +    test "when daily user limit is exceeded" do +      user = insert(:user) + +      today = +        NaiveDateTime.utc_now() +        |> NaiveDateTime.add(:timer.minutes(6), :millisecond) +        |> NaiveDateTime.to_iso8601() + +      attrs = %{params: %{}, scheduled_at: today} +      {:ok, _} = ScheduledActivity.create(user, attrs) +      {:ok, _} = ScheduledActivity.create(user, attrs) +        {:error, changeset} = ScheduledActivity.create(user, attrs)        assert changeset.errors == [scheduled_at: {"daily limit exceeded", []}]      end diff --git a/test/web/mastodon_api/controllers/scheduled_activity_controller_test.exs b/test/web/mastodon_api/controllers/scheduled_activity_controller_test.exs index 5f3a376be..478631a12 100644 --- a/test/web/mastodon_api/controllers/scheduled_activity_controller_test.exs +++ b/test/web/mastodon_api/controllers/scheduled_activity_controller_test.exs @@ -11,6 +11,8 @@ defmodule Pleroma.Web.MastodonAPI.ScheduledActivityControllerTest do    import Pleroma.Factory    import Ecto.Query +  clear_config([ScheduledActivity, :enabled]) +    test "shows scheduled activities", %{conn: conn} do      user = insert(:user)      scheduled_activity_id1 = insert(:scheduled_activity, user: user).id |> to_string() @@ -68,6 +70,7 @@ defmodule Pleroma.Web.MastodonAPI.ScheduledActivityControllerTest do    end    test "updates a scheduled activity", %{conn: conn} do +    Pleroma.Config.put([ScheduledActivity, :enabled], true)      user = insert(:user)      scheduled_at = @@ -120,6 +123,7 @@ defmodule Pleroma.Web.MastodonAPI.ScheduledActivityControllerTest do    end    test "deletes a scheduled activity", %{conn: conn} do +    Pleroma.Config.put([ScheduledActivity, :enabled], true)      user = insert(:user)      {:ok, scheduled_activity} = | 
