Merge branch 'fix-module-search-in-pleroma-ctl' into 'develop'

B ReleaseTasks: Fix task module finding.

See merge request pleroma/pleroma!4297
This commit is contained in:
lain 2024-11-21 13:15:33 +00:00
commit 2482d56153
3 changed files with 35 additions and 8 deletions

View File

@ -0,0 +1 @@
Fix pleroma_ctl mix task calls sometimes not being found

View File

@ -16,17 +16,24 @@ defmodule Pleroma.ReleaseTasks do
end end
end end
def find_module(task) do
module_name =
task
|> String.split(".")
|> Enum.map(&String.capitalize/1)
|> then(fn x -> [Mix, Tasks, Pleroma] ++ x end)
|> Module.concat()
case Code.ensure_loaded(module_name) do
{:module, _} -> module_name
_ -> nil
end
end
defp mix_task(task, args) do defp mix_task(task, args) do
Application.load(:pleroma) Application.load(:pleroma)
{:ok, modules} = :application.get_key(:pleroma, :modules)
module = module = find_module(task)
Enum.find(modules, fn module ->
module = Module.split(module)
match?(["Mix", "Tasks", "Pleroma" | _], module) and
String.downcase(List.last(module)) == task
end)
if module do if module do
module.run(args) module.run(args)

View File

@ -0,0 +1,19 @@
# Pleroma: A lightweight social networking server
# Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only
defmodule Pleroma.ReleaseTaskTest do
use Pleroma.DataCase, async: true
alias Pleroma.ReleaseTasks
test "finding the module" do
task = "search.meilisearch"
assert Mix.Tasks.Pleroma.Search.Meilisearch == ReleaseTasks.find_module(task)
task = "user"
assert Mix.Tasks.Pleroma.User == ReleaseTasks.find_module(task)
refute ReleaseTasks.find_module("doesnt.exist")
end
end