diff options
Diffstat (limited to 'test/tasks')
| -rw-r--r-- | test/tasks/config_test.exs | 198 | ||||
| -rw-r--r-- | test/tasks/count_statuses_test.exs | 2 | ||||
| -rw-r--r-- | test/tasks/database_test.exs | 2 | ||||
| -rw-r--r-- | test/tasks/ecto/ecto_test.exs | 2 | ||||
| -rw-r--r-- | test/tasks/ecto/migrate_test.exs | 2 | ||||
| -rw-r--r-- | test/tasks/ecto/rollback_test.exs | 2 | ||||
| -rw-r--r-- | test/tasks/email_test.exs | 52 | ||||
| -rw-r--r-- | test/tasks/instance_test.exs | 8 | ||||
| -rw-r--r-- | test/tasks/pleroma_test.exs | 2 | ||||
| -rw-r--r-- | test/tasks/refresh_counter_cache_test.exs | 43 | ||||
| -rw-r--r-- | test/tasks/relay_test.exs | 5 | ||||
| -rw-r--r-- | test/tasks/robots_txt_test.exs | 2 | ||||
| -rw-r--r-- | test/tasks/uploads_test.exs | 2 | ||||
| -rw-r--r-- | test/tasks/user_test.exs | 2 | 
14 files changed, 277 insertions, 47 deletions
| diff --git a/test/tasks/config_test.exs b/test/tasks/config_test.exs index 9cd47380c..a6c0de351 100644 --- a/test/tasks/config_test.exs +++ b/test/tasks/config_test.exs @@ -1,66 +1,196 @@  # Pleroma: A lightweight social networking server -# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Mix.Tasks.Pleroma.ConfigTest do    use Pleroma.DataCase + +  alias Pleroma.ConfigDB    alias Pleroma.Repo -  alias Pleroma.Web.AdminAPI.Config    setup_all do      Mix.shell(Mix.Shell.Process) -    temp_file = "config/temp.exported_from_db.secret.exs"      on_exit(fn ->        Mix.shell(Mix.Shell.IO)        Application.delete_env(:pleroma, :first_setting)        Application.delete_env(:pleroma, :second_setting) -      :ok = File.rm(temp_file)      end) -    {:ok, temp_file: temp_file} +    :ok    end -  clear_config_all([:instance, :dynamic_configuration]) do -    Pleroma.Config.put([:instance, :dynamic_configuration], true) +  clear_config_all(:configurable_from_database) do +    Pleroma.Config.put(:configurable_from_database, true)    end -  test "settings are migrated to db" do -    assert Repo.all(Config) == [] +  test "error if file with custom settings doesn't exist" do +    Mix.Tasks.Pleroma.Config.migrate_to_db("config/not_existance_config_file.exs") + +    assert_receive {:mix_shell, :info, +                    [ +                      "To migrate settings, you must define custom settings in config/not_existance_config_file.exs." +                    ]}, +                   15 +  end + +  describe "migrate_to_db/1" do +    setup do +      initial = Application.get_env(:quack, :level) +      on_exit(fn -> Application.put_env(:quack, :level, initial) end) +    end + +    test "settings are migrated to db" do +      assert Repo.all(ConfigDB) == [] -    Application.put_env(:pleroma, :first_setting, key: "value", key2: [Pleroma.Repo]) -    Application.put_env(:pleroma, :second_setting, key: "value2", key2: [Pleroma.Activity]) +      Mix.Tasks.Pleroma.Config.migrate_to_db("test/fixtures/config/temp.secret.exs") -    Mix.Tasks.Pleroma.Config.run(["migrate_to_db"]) +      config1 = ConfigDB.get_by_params(%{group: ":pleroma", key: ":first_setting"}) +      config2 = ConfigDB.get_by_params(%{group: ":pleroma", key: ":second_setting"}) +      config3 = ConfigDB.get_by_params(%{group: ":quack", key: ":level"}) +      refute ConfigDB.get_by_params(%{group: ":pleroma", key: "Pleroma.Repo"}) -    first_db = Config.get_by_params(%{group: "pleroma", key: ":first_setting"}) -    second_db = Config.get_by_params(%{group: "pleroma", key: ":second_setting"}) -    refute Config.get_by_params(%{group: "pleroma", key: "Pleroma.Repo"}) +      assert ConfigDB.from_binary(config1.value) == [key: "value", key2: [Repo]] +      assert ConfigDB.from_binary(config2.value) == [key: "value2", key2: ["Activity"]] +      assert ConfigDB.from_binary(config3.value) == :info +    end -    assert Config.from_binary(first_db.value) == [key: "value", key2: [Pleroma.Repo]] -    assert Config.from_binary(second_db.value) == [key: "value2", key2: [Pleroma.Activity]] +    test "config table is truncated before migration" do +      ConfigDB.create(%{ +        group: ":pleroma", +        key: ":first_setting", +        value: [key: "value", key2: ["Activity"]] +      }) + +      assert Repo.aggregate(ConfigDB, :count, :id) == 1 + +      Mix.Tasks.Pleroma.Config.migrate_to_db("test/fixtures/config/temp.secret.exs") + +      config = ConfigDB.get_by_params(%{group: ":pleroma", key: ":first_setting"}) +      assert ConfigDB.from_binary(config.value) == [key: "value", key2: [Repo]] +    end    end -  test "settings are migrated to file and deleted from db", %{temp_file: temp_file} do -    Config.create(%{ -      group: "pleroma", -      key: ":setting_first", -      value: [key: "value", key2: [Pleroma.Activity]] -    }) +  describe "with deletion temp file" do +    setup do +      temp_file = "config/temp.exported_from_db.secret.exs" + +      on_exit(fn -> +        :ok = File.rm(temp_file) +      end) + +      {:ok, temp_file: temp_file} +    end + +    test "settings are migrated to file and deleted from db", %{temp_file: temp_file} do +      ConfigDB.create(%{ +        group: ":pleroma", +        key: ":setting_first", +        value: [key: "value", key2: ["Activity"]] +      }) + +      ConfigDB.create(%{ +        group: ":pleroma", +        key: ":setting_second", +        value: [key: "value2", key2: [Repo]] +      }) + +      ConfigDB.create(%{group: ":quack", key: ":level", value: :info}) + +      Mix.Tasks.Pleroma.Config.run(["migrate_from_db", "--env", "temp", "-d"]) + +      assert Repo.all(ConfigDB) == [] + +      file = File.read!(temp_file) +      assert file =~ "config :pleroma, :setting_first," +      assert file =~ "config :pleroma, :setting_second," +      assert file =~ "config :quack, :level, :info" +    end + +    test "load a settings with large values and pass to file", %{temp_file: temp_file} do +      ConfigDB.create(%{ +        group: ":pleroma", +        key: ":instance", +        value: [ +          name: "Pleroma", +          email: "example@example.com", +          notify_email: "noreply@example.com", +          description: "A Pleroma instance, an alternative fediverse server", +          limit: 5_000, +          chat_limit: 5_000, +          remote_limit: 100_000, +          upload_limit: 16_000_000, +          avatar_upload_limit: 2_000_000, +          background_upload_limit: 4_000_000, +          banner_upload_limit: 4_000_000, +          poll_limits: %{ +            max_options: 20, +            max_option_chars: 200, +            min_expiration: 0, +            max_expiration: 365 * 24 * 60 * 60 +          }, +          registrations_open: true, +          federating: true, +          federation_incoming_replies_max_depth: 100, +          federation_reachability_timeout_days: 7, +          federation_publisher_modules: [Pleroma.Web.ActivityPub.Publisher], +          allow_relay: true, +          rewrite_policy: Pleroma.Web.ActivityPub.MRF.NoOpPolicy, +          public: true, +          quarantined_instances: [], +          managed_config: true, +          static_dir: "instance/static/", +          allowed_post_formats: ["text/plain", "text/html", "text/markdown", "text/bbcode"], +          mrf_transparency: true, +          mrf_transparency_exclusions: [], +          autofollowed_nicknames: [], +          max_pinned_statuses: 1, +          attachment_links: false, +          welcome_user_nickname: nil, +          welcome_message: nil, +          max_report_comment_size: 1000, +          safe_dm_mentions: false, +          healthcheck: false, +          remote_post_retention_days: 90, +          skip_thread_containment: true, +          limit_to_local_content: :unauthenticated, +          user_bio_length: 5000, +          user_name_length: 100, +          max_account_fields: 10, +          max_remote_account_fields: 20, +          account_field_name_length: 512, +          account_field_value_length: 2048, +          external_user_synchronization: true, +          extended_nickname_format: true, +          multi_factor_authentication: [ +            totp: [ +              # digits 6 or 8 +              digits: 6, +              period: 30 +            ], +            backup_codes: [ +              number: 2, +              length: 6 +            ] +          ] +        ] +      }) -    Config.create(%{ -      group: "pleroma", -      key: ":setting_second", -      value: [key: "valu2", key2: [Pleroma.Repo]] -    }) +      Mix.Tasks.Pleroma.Config.run(["migrate_from_db", "--env", "temp", "-d"]) -    Mix.Tasks.Pleroma.Config.run(["migrate_from_db", "temp", "true"]) +      assert Repo.all(ConfigDB) == [] +      assert File.exists?(temp_file) +      {:ok, file} = File.read(temp_file) -    assert Repo.all(Config) == [] -    assert File.exists?(temp_file) -    {:ok, file} = File.read(temp_file) +      header = +        if Code.ensure_loaded?(Config.Reader) do +          "import Config" +        else +          "use Mix.Config" +        end -    assert file =~ "config :pleroma, :setting_first," -    assert file =~ "config :pleroma, :setting_second," +      assert file == +               "#{header}\n\nconfig :pleroma, :instance,\n  name: \"Pleroma\",\n  email: \"example@example.com\",\n  notify_email: \"noreply@example.com\",\n  description: \"A Pleroma instance, an alternative fediverse server\",\n  limit: 5000,\n  chat_limit: 5000,\n  remote_limit: 100_000,\n  upload_limit: 16_000_000,\n  avatar_upload_limit: 2_000_000,\n  background_upload_limit: 4_000_000,\n  banner_upload_limit: 4_000_000,\n  poll_limits: %{\n    max_expiration: 31_536_000,\n    max_option_chars: 200,\n    max_options: 20,\n    min_expiration: 0\n  },\n  registrations_open: true,\n  federating: true,\n  federation_incoming_replies_max_depth: 100,\n  federation_reachability_timeout_days: 7,\n  federation_publisher_modules: [Pleroma.Web.ActivityPub.Publisher],\n  allow_relay: true,\n  rewrite_policy: Pleroma.Web.ActivityPub.MRF.NoOpPolicy,\n  public: true,\n  quarantined_instances: [],\n  managed_config: true,\n  static_dir: \"instance/static/\",\n  allowed_post_formats: [\"text/plain\", \"text/html\", \"text/markdown\", \"text/bbcode\"],\n  mrf_transparency: true,\n  mrf_transparency_exclusions: [],\n  autofollowed_nicknames: [],\n  max_pinned_statuses: 1,\n  attachment_links: false,\n  welcome_user_nickname: nil,\n  welcome_message: nil,\n  max_report_comment_size: 1000,\n  safe_dm_mentions: false,\n  healthcheck: false,\n  remote_post_retention_days: 90,\n  skip_thread_containment: true,\n  limit_to_local_content: :unauthenticated,\n  user_bio_length: 5000,\n  user_name_length: 100,\n  max_account_fields: 10,\n  max_remote_account_fields: 20,\n  account_field_name_length: 512,\n  account_field_value_length: 2048,\n  external_user_synchronization: true,\n  extended_nickname_format: true,\n  multi_factor_authentication: [\n    totp: [digits: 6, period: 30],\n    backup_codes: [number: 2, length: 6]\n  ]\n" +    end    end  end diff --git a/test/tasks/count_statuses_test.exs b/test/tasks/count_statuses_test.exs index bb5dc88f8..73c2ea690 100644 --- a/test/tasks/count_statuses_test.exs +++ b/test/tasks/count_statuses_test.exs @@ -1,5 +1,5 @@  # Pleroma: A lightweight social networking server -# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Mix.Tasks.Pleroma.CountStatusesTest do diff --git a/test/tasks/database_test.exs b/test/tasks/database_test.exs index 77c102cce..7b05993d3 100644 --- a/test/tasks/database_test.exs +++ b/test/tasks/database_test.exs @@ -1,5 +1,5 @@  # Pleroma: A lightweight social networking server -# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Mix.Tasks.Pleroma.DatabaseTest do diff --git a/test/tasks/ecto/ecto_test.exs b/test/tasks/ecto/ecto_test.exs index a1b9ca174..3a028df83 100644 --- a/test/tasks/ecto/ecto_test.exs +++ b/test/tasks/ecto/ecto_test.exs @@ -1,5 +1,5 @@  # Pleroma: A lightweight social networking server -# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Mix.Tasks.Pleroma.EctoTest do diff --git a/test/tasks/ecto/migrate_test.exs b/test/tasks/ecto/migrate_test.exs index 42f6cbf47..43df176a1 100644 --- a/test/tasks/ecto/migrate_test.exs +++ b/test/tasks/ecto/migrate_test.exs @@ -1,5 +1,5 @@  # Pleroma: A lightweight social networking server -# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>  # SPDX-License-Identifier: AGPL-3.0-onl  defmodule Mix.Tasks.Pleroma.Ecto.MigrateTest do diff --git a/test/tasks/ecto/rollback_test.exs b/test/tasks/ecto/rollback_test.exs index c33c4e940..0236e35d5 100644 --- a/test/tasks/ecto/rollback_test.exs +++ b/test/tasks/ecto/rollback_test.exs @@ -1,5 +1,5 @@  # Pleroma: A lightweight social networking server -# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Mix.Tasks.Pleroma.Ecto.RollbackTest do diff --git a/test/tasks/email_test.exs b/test/tasks/email_test.exs new file mode 100644 index 000000000..944c07064 --- /dev/null +++ b/test/tasks/email_test.exs @@ -0,0 +1,52 @@ +defmodule Mix.Tasks.Pleroma.EmailTest do +  use Pleroma.DataCase + +  import Swoosh.TestAssertions + +  alias Pleroma.Config +  alias Pleroma.Tests.ObanHelpers + +  setup_all do +    Mix.shell(Mix.Shell.Process) + +    on_exit(fn -> +      Mix.shell(Mix.Shell.IO) +    end) + +    :ok +  end + +  describe "pleroma.email test" do +    test "Sends test email with no given address" do +      mail_to = Config.get([:instance, :email]) + +      :ok = Mix.Tasks.Pleroma.Email.run(["test"]) + +      ObanHelpers.perform_all() + +      assert_receive {:mix_shell, :info, [message]} +      assert message =~ "Test email has been sent" + +      assert_email_sent( +        to: mail_to, +        html_body: ~r/a test email was requested./i +      ) +    end + +    test "Sends test email with given address" do +      mail_to = "hewwo@example.com" + +      :ok = Mix.Tasks.Pleroma.Email.run(["test", "--to", mail_to]) + +      ObanHelpers.perform_all() + +      assert_receive {:mix_shell, :info, [message]} +      assert message =~ "Test email has been sent" + +      assert_email_sent( +        to: mail_to, +        html_body: ~r/a test email was requested./i +      ) +    end +  end +end diff --git a/test/tasks/instance_test.exs b/test/tasks/instance_test.exs index 6d7eed4c1..f6a4ba508 100644 --- a/test/tasks/instance_test.exs +++ b/test/tasks/instance_test.exs @@ -1,9 +1,9 @@  # Pleroma: A lightweight social networking server -# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Pleroma.InstanceTest do -  use ExUnit.Case, async: true +  use ExUnit.Case    setup do      File.mkdir_p!(tmp_path()) @@ -15,6 +15,8 @@ defmodule Pleroma.InstanceTest do        if File.exists?(static_dir) do          File.rm_rf(Path.join(static_dir, "robots.txt"))        end + +      Pleroma.Config.put([:instance, :static_dir], static_dir)      end)      :ok @@ -78,7 +80,7 @@ defmodule Pleroma.InstanceTest do      assert generated_config =~ "database: \"dbname\""      assert generated_config =~ "username: \"dbuser\""      assert generated_config =~ "password: \"dbpass\"" -    assert generated_config =~ "dynamic_configuration: true" +    assert generated_config =~ "configurable_from_database: true"      assert generated_config =~ "http: [ip: {127, 0, 0, 1}, port: 4000]"      assert File.read!(tmp_path() <> "setup.psql") == generated_setup_psql()    end diff --git a/test/tasks/pleroma_test.exs b/test/tasks/pleroma_test.exs index a20bd9cf2..c3e47b285 100644 --- a/test/tasks/pleroma_test.exs +++ b/test/tasks/pleroma_test.exs @@ -1,5 +1,5 @@  # Pleroma: A lightweight social networking server -# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Mix.PleromaTest do diff --git a/test/tasks/refresh_counter_cache_test.exs b/test/tasks/refresh_counter_cache_test.exs new file mode 100644 index 000000000..b63f44c08 --- /dev/null +++ b/test/tasks/refresh_counter_cache_test.exs @@ -0,0 +1,43 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Mix.Tasks.Pleroma.RefreshCounterCacheTest do +  use Pleroma.DataCase +  alias Pleroma.Web.CommonAPI +  import ExUnit.CaptureIO, only: [capture_io: 1] +  import Pleroma.Factory + +  test "counts statuses" do +    user = insert(:user) +    other_user = insert(:user) + +    CommonAPI.post(user, %{"visibility" => "public", "status" => "hey"}) + +    Enum.each(0..1, fn _ -> +      CommonAPI.post(user, %{ +        "visibility" => "unlisted", +        "status" => "hey" +      }) +    end) + +    Enum.each(0..2, fn _ -> +      CommonAPI.post(user, %{ +        "visibility" => "direct", +        "status" => "hey @#{other_user.nickname}" +      }) +    end) + +    Enum.each(0..3, fn _ -> +      CommonAPI.post(user, %{ +        "visibility" => "private", +        "status" => "hey" +      }) +    end) + +    assert capture_io(fn -> Mix.Tasks.Pleroma.RefreshCounterCache.run([]) end) =~ "Done\n" + +    assert %{direct: 3, private: 4, public: 1, unlisted: 2} = +             Pleroma.Stats.get_status_visibility_count() +  end +end diff --git a/test/tasks/relay_test.exs b/test/tasks/relay_test.exs index 04a1e45d7..d3d88467d 100644 --- a/test/tasks/relay_test.exs +++ b/test/tasks/relay_test.exs @@ -1,5 +1,5 @@  # Pleroma: A lightweight social networking server -# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Mix.Tasks.Pleroma.RelayTest do @@ -38,6 +38,9 @@ defmodule Mix.Tasks.Pleroma.RelayTest do        assert activity.data["type"] == "Follow"        assert activity.data["actor"] == local_user.ap_id        assert activity.data["object"] == target_user.ap_id + +      :ok = Mix.Tasks.Pleroma.Relay.run(["list"]) +      assert_receive {:mix_shell, :info, ["mastodon.example.org (no Accept received)"]}      end    end diff --git a/test/tasks/robots_txt_test.exs b/test/tasks/robots_txt_test.exs index 917df2675..e03c9c192 100644 --- a/test/tasks/robots_txt_test.exs +++ b/test/tasks/robots_txt_test.exs @@ -1,5 +1,5 @@  # Pleroma: A lightweight social networking server -# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Mix.Tasks.Pleroma.RobotsTxtTest do diff --git a/test/tasks/uploads_test.exs b/test/tasks/uploads_test.exs index b0b8eda11..d69e149a8 100644 --- a/test/tasks/uploads_test.exs +++ b/test/tasks/uploads_test.exs @@ -1,5 +1,5 @@  # Pleroma: A lightweight social networking server -# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/> +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Mix.Tasks.Pleroma.UploadsTest do diff --git a/test/tasks/user_test.exs b/test/tasks/user_test.exs index bfd0ccbc5..b45f37263 100644 --- a/test/tasks/user_test.exs +++ b/test/tasks/user_test.exs @@ -1,5 +1,5 @@  # Pleroma: A lightweight social networking server -# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>  # SPDX-License-Identifier: AGPL-3.0-only  defmodule Mix.Tasks.Pleroma.UserTest do | 
