# Pleroma: A lightweight social networking server
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only

defmodule Pleroma.EmojiTest do
  use ExUnit.Case, async: true
  alias Pleroma.Emoji

  describe "is_unicode_emoji?/1" do
    test "tells if a string is an unicode emoji" do
      refute Emoji.is_unicode_emoji?("X")
      refute Emoji.is_unicode_emoji?("ね")

      # Only accept fully-qualified (RGI) emoji
      # See http://www.unicode.org/reports/tr51/
      refute Emoji.is_unicode_emoji?("❤")
      refute Emoji.is_unicode_emoji?("☂")

      assert Emoji.is_unicode_emoji?("🥺")
      assert Emoji.is_unicode_emoji?("🤰")
      assert Emoji.is_unicode_emoji?("❤️")
      assert Emoji.is_unicode_emoji?("🏳️‍⚧️")

      # Additionally, we accept regional indicators.
      assert Emoji.is_unicode_emoji?("🇵")
      assert Emoji.is_unicode_emoji?("🇴")
      assert Emoji.is_unicode_emoji?("🇬")
    end
  end

  describe "get_all/0" do
    setup do
      emoji_list = Emoji.get_all()
      {:ok, emoji_list: emoji_list}
    end

    test "first emoji", %{emoji_list: emoji_list} do
      [emoji | _others] = emoji_list
      {code, %Emoji{file: path, tags: tags}} = emoji

      assert tuple_size(emoji) == 2
      assert is_binary(code)
      assert is_binary(path)
      assert is_list(tags)
    end

    test "random emoji", %{emoji_list: emoji_list} do
      emoji = Enum.random(emoji_list)
      {code, %Emoji{file: path, tags: tags}} = emoji

      assert tuple_size(emoji) == 2
      assert is_binary(code)
      assert is_binary(path)
      assert is_list(tags)
    end
  end
end