summaryrefslogtreecommitdiff
path: root/test/pleroma/ecto_type/activity_pub/object_validators/safe_text_test.exs
blob: 7eddd2388e9f750a005781db654a8a379628dc3c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
# Pleroma: A lightweight social networking server
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only

defmodule Pleroma.EctoType.ActivityPub.ObjectValidators.SafeTextTest do
  use Pleroma.DataCase

  alias Pleroma.EctoType.ActivityPub.ObjectValidators.SafeText

  test "it lets normal text go through" do
    text = "hey how are you"
    assert {:ok, text} == SafeText.cast(text)
  end

  test "it removes html tags from text" do
    text = "hey look xss <script>alert('foo')</script>"
    assert {:ok, "hey look xss alert(&#39;foo&#39;)"} == SafeText.cast(text)
  end

  test "it keeps basic html tags" do
    text = "hey <a href='http://gensokyo.2hu'>look</a> xss <script>alert('foo')</script>"

    assert {:ok, "hey <a href=\"http://gensokyo.2hu\">look</a> xss alert(&#39;foo&#39;)"} ==
             SafeText.cast(text)
  end

  test "errors for non-text" do
    assert :error == SafeText.cast(1)
  end
end