logo

pleroma

My custom branche(s) on git.pleroma.social/pleroma/pleroma git clone https://hacktivis.me/git/pleroma.git

emoji_react_handling_test.exs (3299B)


  1. # Pleroma: A lightweight social networking server
  2. # Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/>
  3. # SPDX-License-Identifier: AGPL-3.0-only
  4. defmodule Pleroma.Web.ActivityPub.ObjectValidators.EmojiReactHandlingTest do
  5. use Pleroma.DataCase, async: true
  6. alias Pleroma.Web.ActivityPub.Builder
  7. alias Pleroma.Web.ActivityPub.ObjectValidator
  8. alias Pleroma.Web.CommonAPI
  9. import Pleroma.Factory
  10. describe "EmojiReacts" do
  11. setup do
  12. user = insert(:user)
  13. {:ok, post_activity} = CommonAPI.post(user, %{status: "uguu"})
  14. object = Pleroma.Object.get_by_ap_id(post_activity.data["object"])
  15. {:ok, valid_emoji_react, []} = Builder.emoji_react(user, object, "👌")
  16. %{user: user, post_activity: post_activity, valid_emoji_react: valid_emoji_react}
  17. end
  18. test "it validates a valid EmojiReact", %{valid_emoji_react: valid_emoji_react} do
  19. assert {:ok, _, _} = ObjectValidator.validate(valid_emoji_react, [])
  20. end
  21. test "it is not valid without a 'content' field", %{valid_emoji_react: valid_emoji_react} do
  22. without_content =
  23. valid_emoji_react
  24. |> Map.delete("content")
  25. {:error, cng} = ObjectValidator.validate(without_content, [])
  26. refute cng.valid?
  27. assert {:content, {"can't be blank", [validation: :required]}} in cng.errors
  28. end
  29. test "it is valid when custom emoji is used", %{valid_emoji_react: valid_emoji_react} do
  30. without_emoji_content =
  31. valid_emoji_react
  32. |> Map.put("content", ":hello:")
  33. |> Map.put("tag", [
  34. %{
  35. "type" => "Emoji",
  36. "name" => ":hello:",
  37. "icon" => %{"url" => "http://somewhere", "type" => "Image"}
  38. }
  39. ])
  40. {:ok, _, _} = ObjectValidator.validate(without_emoji_content, [])
  41. end
  42. test "it is not valid when custom emoji don't have a matching tag", %{
  43. valid_emoji_react: valid_emoji_react
  44. } do
  45. without_emoji_content =
  46. valid_emoji_react
  47. |> Map.put("content", ":hello:")
  48. |> Map.put("tag", [
  49. %{
  50. "type" => "Emoji",
  51. "name" => ":whoops:",
  52. "icon" => %{"url" => "http://somewhere", "type" => "Image"}
  53. }
  54. ])
  55. {:error, cng} = ObjectValidator.validate(without_emoji_content, [])
  56. refute cng.valid?
  57. assert {:tag, {"does not contain an Emoji tag", []}} in cng.errors
  58. end
  59. test "it is not valid when custom emoji have no tags", %{
  60. valid_emoji_react: valid_emoji_react
  61. } do
  62. without_emoji_content =
  63. valid_emoji_react
  64. |> Map.put("content", ":hello:")
  65. |> Map.put("tag", [])
  66. {:error, cng} = ObjectValidator.validate(without_emoji_content, [])
  67. refute cng.valid?
  68. assert {:tag, {"does not contain an Emoji tag", []}} in cng.errors
  69. end
  70. test "it is not valid when custom emoji doesn't match a shortcode format", %{
  71. valid_emoji_react: valid_emoji_react
  72. } do
  73. without_emoji_content =
  74. valid_emoji_react
  75. |> Map.put("content", "hello")
  76. |> Map.put("tag", [])
  77. {:error, cng} = ObjectValidator.validate(without_emoji_content, [])
  78. refute cng.valid?
  79. assert {:tag, {"does not contain an Emoji tag", []}} in cng.errors
  80. end
  81. end
  82. end