Browse Source

Migration to fix malformed Pleroma.Formatter config

chores/our-libs-hex-releases
Alex Gleason 3 years ago
parent
commit
c7a0016f9f
No known key found for this signature in database GPG Key ID: 7211D1F99744FBB7
2 changed files with 88 additions and 0 deletions
  1. +26
    -0
      priv/repo/migrations/20200722185515_fix_malformed_formatter_config.exs
  2. +62
    -0
      test/migrations/20200722185515_fix_malformed_formatter_config_test.exs

+ 26
- 0
priv/repo/migrations/20200722185515_fix_malformed_formatter_config.exs View File

@@ -0,0 +1,26 @@
defmodule Pleroma.Repo.Migrations.FixMalformedFormatterConfig do
use Ecto.Migration
alias Pleroma.ConfigDB

@config_path %{group: :pleroma, key: Pleroma.Formatter}

def change do
with %ConfigDB{value: %{} = opts} <- ConfigDB.get_by_params(@config_path),
fixed_opts <- Map.to_list(opts) do
fix_config(fixed_opts)
else
_ -> :skipped
end
end

defp fix_config(fixed_opts) when is_list(fixed_opts) do
{:ok, _} =
ConfigDB.update_or_create(%{
group: :pleroma,
key: Pleroma.Formatter,
value: fixed_opts
})

:ok
end
end

+ 62
- 0
test/migrations/20200722185515_fix_malformed_formatter_config_test.exs View File

@@ -0,0 +1,62 @@
defmodule Pleroma.Repo.Migrations.FixMalformedFormatterConfigTest do
use Pleroma.DataCase
import Pleroma.Factory
import Pleroma.Tests.Helpers, only: [require_migration: 1]
alias Pleroma.ConfigDB

setup_all do: require_migration("20200722185515_fix_malformed_formatter_config")

test "change/0 converts a map into a list", %{migration: migration} do
incorrect_opts = %{
class: false,
extra: true,
new_window: false,
rel: "ugc",
strip_prefix: false
}

insert(:config, group: :pleroma, key: Pleroma.Formatter, value: incorrect_opts)

assert :ok == migration.change()

%{value: new_opts} = ConfigDB.get_by_params(%{group: :pleroma, key: Pleroma.Formatter})

assert new_opts == [
class: false,
extra: true,
new_window: false,
rel: "ugc",
strip_prefix: false
]

{text, _mentions, []} =
Pleroma.Formatter.linkify(
"https://www.businessinsider.com/walmart-will-close-stores-on-thanksgiving-ending-black-friday-tradition-2020-7\n\nOmg will COVID finally end Black Friday???"
)

assert text ==
"<a href=\"https://www.businessinsider.com/walmart-will-close-stores-on-thanksgiving-ending-black-friday-tradition-2020-7\" rel=\"ugc\">https://www.businessinsider.com/walmart-will-close-stores-on-thanksgiving-ending-black-friday-tradition-2020-7</a>\n\nOmg will COVID finally end Black Friday???"
end

test "change/0 skips if Pleroma.Formatter config is already a list", %{migration: migration} do
opts = [
class: false,
extra: true,
new_window: false,
rel: "ugc",
strip_prefix: false
]

insert(:config, group: :pleroma, key: Pleroma.Formatter, value: opts)

assert :skipped == migration.change()

%{value: new_opts} = ConfigDB.get_by_params(%{group: :pleroma, key: Pleroma.Formatter})

assert new_opts == opts
end

test "change/0 skips if Pleroma.Formatter is empty", %{migration: migration} do
assert :skipped == migration.change()
end
end

Loading…
Cancel
Save