B MeiliSearch, SearchIndexingWorker: Use Config.Getting, make tests async.

This commit is contained in:
Lain Soykaf 2023-11-12 14:49:50 +04:00
parent c1402af293
commit d3f8950588
3 changed files with 72 additions and 48 deletions

View File

@ -3,6 +3,7 @@ defmodule Pleroma.Search.Meilisearch do
require Pleroma.Constants require Pleroma.Constants
alias Pleroma.Activity alias Pleroma.Activity
alias Pleroma.Config.Getting, as: Config
import Pleroma.Search.DatabaseSearch import Pleroma.Search.DatabaseSearch
import Ecto.Query import Ecto.Query
@ -10,14 +11,14 @@ defmodule Pleroma.Search.Meilisearch do
@behaviour Pleroma.Search.SearchBackend @behaviour Pleroma.Search.SearchBackend
defp meili_headers do defp meili_headers do
private_key = Pleroma.Config.get([Pleroma.Search.Meilisearch, :private_key]) private_key = Config.get([Pleroma.Search.Meilisearch, :private_key])
[{"Content-Type", "application/json"}] ++ [{"Content-Type", "application/json"}] ++
if is_nil(private_key), do: [], else: [{"Authorization", "Bearer #{private_key}"}] if is_nil(private_key), do: [], else: [{"Authorization", "Bearer #{private_key}"}]
end end
def meili_get(path) do def meili_get(path) do
endpoint = Pleroma.Config.get([Pleroma.Search.Meilisearch, :url]) endpoint = Config.get([Pleroma.Search.Meilisearch, :url])
result = result =
Pleroma.HTTP.get( Pleroma.HTTP.get(
@ -31,7 +32,7 @@ def meili_get(path) do
end end
def meili_post(path, params) do def meili_post(path, params) do
endpoint = Pleroma.Config.get([Pleroma.Search.Meilisearch, :url]) endpoint = Config.get([Pleroma.Search.Meilisearch, :url])
result = result =
Pleroma.HTTP.post( Pleroma.HTTP.post(
@ -46,7 +47,7 @@ def meili_post(path, params) do
end end
def meili_put(path, params) do def meili_put(path, params) do
endpoint = Pleroma.Config.get([Pleroma.Search.Meilisearch, :url]) endpoint = Config.get([Pleroma.Search.Meilisearch, :url])
result = result =
Pleroma.HTTP.request( Pleroma.HTTP.request(
@ -63,15 +64,20 @@ def meili_put(path, params) do
end end
def meili_delete(path) do def meili_delete(path) do
endpoint = Pleroma.Config.get([Pleroma.Search.Meilisearch, :url]) endpoint = Config.get([Pleroma.Search.Meilisearch, :url])
with {:ok, _} <-
Pleroma.HTTP.request( Pleroma.HTTP.request(
:delete, :delete,
Path.join(endpoint, path), Path.join(endpoint, path),
"", "",
meili_headers(), meili_headers(),
[] []
) ) do
:ok
else
_ -> :error
end
end end
@impl true @impl true

View File

@ -3,10 +3,12 @@ defmodule Pleroma.Workers.SearchIndexingWorker do
@impl Oban.Worker @impl Oban.Worker
alias Pleroma.Config.Getting, as: Config
def perform(%Job{args: %{"op" => "add_to_index", "activity" => activity_id}}) do def perform(%Job{args: %{"op" => "add_to_index", "activity" => activity_id}}) do
activity = Pleroma.Activity.get_by_id_with_object(activity_id) activity = Pleroma.Activity.get_by_id_with_object(activity_id)
search_module = Pleroma.Config.get([Pleroma.Search, :module]) search_module = Config.get([Pleroma.Search, :module])
search_module.add_to_index(activity) search_module.add_to_index(activity)
end end
@ -14,7 +16,7 @@ def perform(%Job{args: %{"op" => "add_to_index", "activity" => activity_id}}) do
def perform(%Job{args: %{"op" => "remove_from_index", "object" => object_id}}) do def perform(%Job{args: %{"op" => "remove_from_index", "object" => object_id}}) do
object = Pleroma.Object.get_by_id(object_id) object = Pleroma.Object.get_by_id(object_id)
search_module = Pleroma.Config.get([Pleroma.Search, :module]) search_module = Config.get([Pleroma.Search, :module])
search_module.remove_from_index(object) search_module.remove_from_index(object)
end end

View File

@ -5,51 +5,50 @@
defmodule Pleroma.Search.MeilisearchTest do defmodule Pleroma.Search.MeilisearchTest do
require Pleroma.Constants require Pleroma.Constants
use Pleroma.DataCase use Pleroma.DataCase, async: true
use Oban.Testing, repo: Pleroma.Repo use Oban.Testing, repo: Pleroma.Repo
import Pleroma.Factory import Pleroma.Factory
import Tesla.Mock import Tesla.Mock
import Mock import Mox
alias Pleroma.Search.Meilisearch alias Pleroma.Search.Meilisearch
alias Pleroma.Web.CommonAPI alias Pleroma.Web.CommonAPI
alias Pleroma.Workers.SearchIndexingWorker alias Pleroma.Workers.SearchIndexingWorker
alias Pleroma.UnstubbedConfigMock, as: Config
setup_all do
Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end)
:ok
end
describe "meilisearch" do describe "meilisearch" do
setup do: clear_config([Pleroma.Search, :module], Meilisearch)
setup_with_mocks(
[
{Meilisearch, [:passthrough],
[
add_to_index: fn a -> passthrough([a]) end,
remove_from_index: fn a -> passthrough([a]) end,
meili_put: fn u, a -> passthrough([u, a]) end
]}
],
context,
do: {:ok, context}
)
test "indexes a local post on creation" do test "indexes a local post on creation" do
user = insert(:user) user = insert(:user)
mock_global(fn Tesla.Mock.mock(fn
%{method: :put, 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?( assert match?(
[%{"content" => "guys i just don&#39;t wanna leave the swamp"}], [%{"content" => "guys i just don&#39;t wanna leave the swamp"}],
Jason.decode!(body) Jason.decode!(body)
) )
# To make sure that the worker is called
send(self(), "posted_to_meilisearch")
json(%{updateId: 1}) json(%{updateId: 1})
end) end)
Config
|> expect(:get, 3, fn
[Pleroma.Search, :module], nil ->
Meilisearch
[Pleroma.Search.Meilisearch, :url], nil ->
"http://127.0.0.1:7700"
[Pleroma.Search.Meilisearch, :private_key], nil ->
"secret"
end)
{:ok, activity} = {:ok, activity} =
CommonAPI.post(user, %{ CommonAPI.post(user, %{
status: "guys i just don't wanna leave the swamp", status: "guys i just don't wanna leave the swamp",
@ -64,8 +63,7 @@ test "indexes a local post on creation" do
) )
assert :ok = perform_job(SearchIndexingWorker, args) assert :ok = perform_job(SearchIndexingWorker, args)
assert_received("posted_to_meilisearch")
assert_called(Meilisearch.add_to_index(activity))
end end
test "doesn't index posts that are not public" do test "doesn't index posts that are not public" do
@ -80,21 +78,26 @@ test "doesn't index posts that are not public" do
args = %{"op" => "add_to_index", "activity" => activity.id} args = %{"op" => "add_to_index", "activity" => activity.id}
assert_enqueued(worker: SearchIndexingWorker, args: args) Config
assert :ok = perform_job(SearchIndexingWorker, args) |> expect(:get, fn
[Pleroma.Search, :module], nil ->
assert_not_called(Meilisearch.meili_put(:_)) Meilisearch
end) end)
history = call_history(Meilisearch) assert_enqueued(worker: SearchIndexingWorker, args: args)
assert Enum.count(history) == 2 assert :ok = perform_job(SearchIndexingWorker, args)
end)
end end
test "deletes posts from index when deleted locally" do test "deletes posts from index when deleted locally" do
user = insert(:user) user = insert(:user)
mock_global(fn Tesla.Mock.mock(fn
%{method: :put, 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?( assert match?(
[%{"content" => "guys i just don&#39;t wanna leave the swamp"}], [%{"content" => "guys i just don&#39;t wanna leave the swamp"}],
Jason.decode!(body) Jason.decode!(body)
@ -103,10 +106,23 @@ test "deletes posts from index when deleted locally" do
json(%{updateId: 1}) json(%{updateId: 1})
%{method: :delete, url: "http://127.0.0.1:7700/indexes/objects/documents/" <> id} -> %{method: :delete, url: "http://127.0.0.1:7700/indexes/objects/documents/" <> id} ->
send(self(), "called_delete")
assert String.length(id) > 1 assert String.length(id) > 1
json(%{updateId: 2}) json(%{updateId: 2})
end) end)
Config
|> expect(:get, 6, fn
[Pleroma.Search, :module], nil ->
Meilisearch
[Pleroma.Search.Meilisearch, :url], nil ->
"http://127.0.0.1:7700"
[Pleroma.Search.Meilisearch, :private_key], nil ->
"secret"
end)
{:ok, activity} = {:ok, activity} =
CommonAPI.post(user, %{ CommonAPI.post(user, %{
status: "guys i just don't wanna leave the swamp", status: "guys i just don't wanna leave the swamp",
@ -123,7 +139,7 @@ test "deletes posts from index when deleted locally" do
assert_enqueued(worker: SearchIndexingWorker, args: delete_args) assert_enqueued(worker: SearchIndexingWorker, args: delete_args)
assert :ok = perform_job(SearchIndexingWorker, delete_args) assert :ok = perform_job(SearchIndexingWorker, delete_args)
assert_called(Meilisearch.remove_from_index(:_)) assert_received("called_delete")
end end
end end
end end