diff options
Diffstat (limited to 'test/support')
| -rw-r--r-- | test/support/builders/user_builder.ex | 3 | ||||
| -rw-r--r-- | test/support/channel_case.ex | 1 | ||||
| -rw-r--r-- | test/support/factory.ex | 15 | ||||
| -rw-r--r-- | test/support/helpers.ex | 17 | 
4 files changed, 34 insertions, 2 deletions
| diff --git a/test/support/builders/user_builder.ex b/test/support/builders/user_builder.ex index 6da16f71a..fcfea666f 100644 --- a/test/support/builders/user_builder.ex +++ b/test/support/builders/user_builder.ex @@ -10,7 +10,8 @@ defmodule Pleroma.Builders.UserBuilder do        password_hash: Comeonin.Pbkdf2.hashpwsalt("test"),        bio: "A tester.",        ap_id: "some id", -      last_digest_emailed_at: NaiveDateTime.truncate(NaiveDateTime.utc_now(), :second) +      last_digest_emailed_at: NaiveDateTime.truncate(NaiveDateTime.utc_now(), :second), +      notification_settings: %Pleroma.User.NotificationSetting{}      }      Map.merge(user, data) diff --git a/test/support/channel_case.ex b/test/support/channel_case.ex index 466d8986f..4a4585844 100644 --- a/test/support/channel_case.ex +++ b/test/support/channel_case.ex @@ -23,6 +23,7 @@ defmodule Pleroma.Web.ChannelCase do      quote do        # Import conveniences for testing with channels        use Phoenix.ChannelTest +      use Pleroma.Tests.Helpers        # The default endpoint for testing        @endpoint Pleroma.Web.Endpoint diff --git a/test/support/factory.ex b/test/support/factory.ex index bb8a64e72..314f26ec9 100644 --- a/test/support/factory.ex +++ b/test/support/factory.ex @@ -31,7 +31,8 @@ defmodule Pleroma.Factory do        nickname: sequence(:nickname, &"nick#{&1}"),        password_hash: Comeonin.Pbkdf2.hashpwsalt("test"),        bio: sequence(:bio, &"Tester Number #{&1}"), -      last_digest_emailed_at: NaiveDateTime.utc_now() +      last_digest_emailed_at: NaiveDateTime.utc_now(), +      notification_settings: %Pleroma.User.NotificationSetting{}      }      %{ @@ -42,6 +43,18 @@ defmodule Pleroma.Factory do      }    end +  def user_relationship_factory(attrs \\ %{}) do +    source = attrs[:source] || insert(:user) +    target = attrs[:target] || insert(:user) +    relationship_type = attrs[:relationship_type] || :block + +    %Pleroma.UserRelationship{ +      source_id: source.id, +      target_id: target.id, +      relationship_type: relationship_type +    } +  end +    def note_factory(attrs \\ %{}) do      text = sequence(:text, &"This is :moominmamma: note #{&1}") diff --git a/test/support/helpers.ex b/test/support/helpers.ex index ce39dd9d8..af2b2eddf 100644 --- a/test/support/helpers.ex +++ b/test/support/helpers.ex @@ -75,6 +75,23 @@ defmodule Pleroma.Tests.Helpers do          |> Poison.decode!()        end +      def stringify_keys(nil), do: nil + +      def stringify_keys(key) when key in [true, false], do: key +      def stringify_keys(key) when is_atom(key), do: Atom.to_string(key) + +      def stringify_keys(map) when is_map(map) do +        map +        |> Enum.map(fn {k, v} -> {stringify_keys(k), stringify_keys(v)} end) +        |> Enum.into(%{}) +      end + +      def stringify_keys([head | rest] = list) when is_list(list) do +        [stringify_keys(head) | stringify_keys(rest)] +      end + +      def stringify_keys(key), do: key +        defmacro guards_config(config_path) do          quote do            initial_setting = Pleroma.Config.get(config_path) | 
