Fix meilisearch tests and jobs for oban
authorEkaterina Vaartis <vaartis@kotobank.ch>
Sat, 22 Jan 2022 13:31:32 +0000 (16:31 +0300)
committerFloatingGhost <hannah@coffee-and-dreams.uk>
Wed, 29 Jun 2022 19:49:45 +0000 (20:49 +0100)
lib/pleroma/workers/search_indexing_worker.ex
test/pleroma/search/meilisearch_test.exs

index 43b7bad1e330413adc00c7ce65e6354e1e3cbfbf..70a8d42d06cb00dc3c4e349c591c1e1ceaf510d1 100644 (file)
@@ -9,6 +9,8 @@ defmodule Pleroma.Workers.SearchIndexingWorker do
     search_module = Pleroma.Config.get([Pleroma.Search, :module])
 
     search_module.add_to_index(activity)
+
+    :ok
   end
 
   def perform(%Job{args: %{"op" => "remove_from_index", "object" => object_id}}) do
@@ -17,5 +19,7 @@ defmodule Pleroma.Workers.SearchIndexingWorker do
     search_module = Pleroma.Config.get([Pleroma.Search, :module])
 
     search_module.remove_from_index(object)
+
+    :ok
   end
 end
index 251388ea2dc85b3db52ab54c0d25fe8fe6c522ef..da614577f46d3d9dda27a6a9dddf6e165c8e83bf 100644 (file)
@@ -6,6 +6,7 @@ defmodule Pleroma.Search.MeilisearchTest do
   require Pleroma.Constants
 
   use Pleroma.DataCase
+  use Oban.Testing, repo: Pleroma.Repo
 
   import Pleroma.Factory
   import Tesla.Mock
@@ -13,6 +14,7 @@ defmodule Pleroma.Search.MeilisearchTest do
 
   alias Pleroma.Search.Meilisearch
   alias Pleroma.Web.CommonAPI
+  alias Pleroma.Workers.SearchIndexingWorker
 
   setup_all do
     Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end)
@@ -27,7 +29,8 @@ defmodule Pleroma.Search.MeilisearchTest do
         {Meilisearch, [:passthrough],
          [
            add_to_index: fn a -> passthrough([a]) end,
-           remove_from_index: fn a -> passthrough([a]) end
+           remove_from_index: fn a -> passthrough([a]) end,
+           meili_put: fn u, a -> passthrough([u, a]) end
          ]}
       ],
       context,
@@ -38,7 +41,7 @@ defmodule Pleroma.Search.MeilisearchTest do
       user = insert(:user)
 
       mock_global(fn
-        %{method: :post, url: "http://127.0.0.1:7700/indexes/objects/documents", body: body} ->
+        %{method: :put, url: "http://127.0.0.1:7700/indexes/objects/documents", body: body} ->
           assert match?(
                    [%{"content" => "guys i just don&#39;t wanna leave the swamp"}],
                    Jason.decode!(body)
@@ -53,6 +56,15 @@ defmodule Pleroma.Search.MeilisearchTest do
           visibility: "public"
         })
 
+      args = %{"op" => "add_to_index", "activity" => activity.id}
+
+      assert_enqueued(
+        worker: SearchIndexingWorker,
+        args: args
+      )
+
+      assert :ok = perform_job(SearchIndexingWorker, args)
+
       assert_called(Meilisearch.add_to_index(activity))
     end
 
@@ -60,26 +72,25 @@ defmodule Pleroma.Search.MeilisearchTest do
       user = insert(:user)
 
       Enum.each(["unlisted", "private", "direct"], fn visiblity ->
-        {:ok, _} =
+        {:ok, activity} =
           CommonAPI.post(user, %{
             status: "guys i just don't wanna leave the swamp",
             visibility: visiblity
           })
+
+        Meilisearch.add_to_index(activity)
+        assert_not_called(Meilisearch.meili_put(:_))
       end)
 
       history = call_history(Meilisearch)
       assert Enum.count(history) == 3
-
-      Enum.each(history, fn {_, _, return} ->
-        assert is_nil(return)
-      end)
     end
 
     test "deletes posts from index when deleted locally" do
       user = insert(:user)
 
       mock_global(fn
-        %{method: :post, url: "http://127.0.0.1:7700/indexes/objects/documents", body: body} ->
+        %{method: :put, url: "http://127.0.0.1:7700/indexes/objects/documents", body: body} ->
           assert match?(
                    [%{"content" => "guys i just don&#39;t wanna leave the swamp"}],
                    Jason.decode!(body)
@@ -98,10 +109,16 @@ defmodule Pleroma.Search.MeilisearchTest do
           visibility: "public"
         })
 
-      assert_called(Meilisearch.add_to_index(activity))
+      args = %{"op" => "add_to_index", "activity" => activity.id}
+      assert_enqueued(worker: SearchIndexingWorker, args: args)
+      assert :ok = perform_job(SearchIndexingWorker, args)
 
       {:ok, _} = CommonAPI.delete(activity.id, user)
 
+      delete_args = %{"op" => "remove_from_index", "object" => activity.object.id}
+      assert_enqueued(worker: SearchIndexingWorker, args: delete_args)
+      assert :ok = perform_job(SearchIndexingWorker, delete_args)
+
       assert_called(Meilisearch.remove_from_index(:_))
     end
   end