X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/c3e2e6462f293596aef5d5de18b0a173edc046c7..00db1066ef1198355bfec4e043c3e51411112294:/test/lib/rich_text_test.rb?ds=sidebyside diff --git a/test/lib/rich_text_test.rb b/test/lib/rich_text_test.rb index 14e6f2196..e0b315276 100644 --- a/test/lib/rich_text_test.rb +++ b/test/lib/rich_text_test.rb @@ -1,4 +1,4 @@ -require 'test_helper' +require "test_helper" class RichTextTest < ActiveSupport::TestCase include Rails::Dom::Testing::Assertions::SelectorAssertions @@ -8,14 +8,21 @@ class RichTextTest < ActiveSupport::TestCase assert_html r do assert_select "a", 1 assert_select "a[href='http://example.com/']", 1 - assert_select "a[rel='nofollow']", 1 + assert_select "a[rel='nofollow noopener noreferrer']", 1 end r = RichText.new("html", "foo bar baz") assert_html r do assert_select "a", 1 assert_select "a[href='http://example.com/']", 1 - assert_select "a[rel='nofollow']", 1 + assert_select "a[rel='nofollow noopener noreferrer']", 1 + end + + r = RichText.new("html", "foo bar baz") + assert_html r do + assert_select "a", 1 + assert_select "a[href='http://example.com/']", 1 + assert_select "a[rel='me nofollow noopener noreferrer']", 1 end r = RichText.new("html", "foo example@example.com bar") @@ -27,7 +34,7 @@ class RichTextTest < ActiveSupport::TestCase assert_html r do assert_select "a", 1 assert_select "a[href='mailto:example@example.com']", 1 - assert_select "a[rel='nofollow']", 1 + assert_select "a[rel='nofollow noopener noreferrer']", 1 end r = RichText.new("html", "foo
bar
baz") @@ -47,6 +54,33 @@ class RichTextTest < ActiveSupport::TestCase assert_select "style", false assert_select "p", /^foo *baz$/ end + + r = RichText.new("html", "
column
") + assert_html r do + assert_select "table[class='table table-sm w-auto']" + end + + r = RichText.new("html", "

Click Me

") + assert_html r do + assert_select "p[class='btn btn-warning']", false + assert_select "p", /^Click Me$/ + end + + r = RichText.new("html", "

Danger

") + assert_html r do + assert_select "p[style='color:red']", false + assert_select "p", /^Danger$/ + end + end + + def test_html_to_text + r = RichText.new("html", "foo bar baz") + assert_equal "foo bar baz", r.to_text + end + + def test_html_spam_score + r = RichText.new("html", "foo bar baz") + assert_equal 55, r.spam_score.round end def test_markdown_to_html @@ -54,28 +88,35 @@ class RichTextTest < ActiveSupport::TestCase assert_html r do assert_select "a", 1 assert_select "a[href='http://example.com/']", 1 - assert_select "a[rel='nofollow']", 1 + assert_select "a[rel='nofollow noopener noreferrer']", 1 end r = RichText.new("markdown", "foo [bar](http://example.com/) baz") assert_html r do assert_select "a", 1 assert_select "a[href='http://example.com/']", 1 - assert_select "a[rel='nofollow']", 1 + assert_select "a[rel='nofollow noopener noreferrer']", 1 + end + + r = RichText.new("markdown", "foo bar) baz") + assert_html r do + assert_select "a", 1 + assert_select "a[href='http://example.com/']", 1 + assert_select "a[rel='me nofollow noopener noreferrer']", 1 end r = RichText.new("markdown", "foo example@example.com bar") assert_html r do assert_select "a", 1 assert_select "a[href='mailto:example@example.com']", 1 - assert_select "a[rel='nofollow']", 1 + assert_select "a[rel='nofollow noopener noreferrer']", 1 end r = RichText.new("markdown", "foo [bar](mailto:example@example.com) bar") assert_html r do assert_select "a", 1 assert_select "a[href='mailto:example@example.com']", 1 - assert_select "a[rel='nofollow']", 1 + assert_select "a[rel='nofollow noopener noreferrer']", 1 end r = RichText.new("markdown", "foo ![bar](http://example.com/example.png) bar") @@ -135,6 +176,49 @@ class RichTextTest < ActiveSupport::TestCase assert_html r do assert_select "pre", /^\s*foo bar baz\s*$/ end + + r = RichText.new("markdown", "|column|column") + assert_html r do + assert_select "table[class='table table-sm w-auto']" + end + + r = RichText.new("markdown", "Click Me\n{:.btn.btn-warning}") + assert_html r do + assert_select "p[class='btn btn-warning']", false + assert_select "p", /^Click Me$/ + end + + r = RichText.new("markdown", "

Danger

") + assert_html r do + assert_select "p[style='color:red']", false + assert_select "p", /^Danger$/ + end + end + + def test_markdown_table_alignment + # Ensure that kramdown table alignment styles are converted to bootstrap classes + markdown_table = <<~MARKDOWN + | foo | bar | + |:----:|----:| + |center|right| + MARKDOWN + r = RichText.new("markdown", markdown_table) + assert_html r do + assert_select "td[style='text-align:center']", false + assert_select "td[class='text-center']", true + assert_select "td[style='text-align:right']", false + assert_select "td[class='text-end']", true + end + end + + def test_markdown_to_text + r = RichText.new("markdown", "foo [bar](http://example.com/) baz") + assert_equal "foo [bar](http://example.com/) baz", r.to_text + end + + def test_markdown_spam_score + r = RichText.new("markdown", "foo [bar](http://example.com/) baz") + assert_equal 50, r.spam_score.round end def test_text_to_html @@ -142,7 +226,7 @@ class RichTextTest < ActiveSupport::TestCase assert_html r do assert_select "a", 1 assert_select "a[href='http://example.com/']", 1 - assert_select "a[rel='nofollow']", 1 + assert_select "a[rel='nofollow noopener noreferrer']", 1 end r = RichText.new("text", "foo example@example.com bar") @@ -156,11 +240,99 @@ class RichTextTest < ActiveSupport::TestCase end end -private + def test_text_to_text + r = RichText.new("text", "foo http://example.com/ bar") + assert_equal "foo http://example.com/ bar", r.to_text + end + + def test_text_spam_score + r = RichText.new("text", "foo http://example.com/ bar") + assert_equal 141, r.spam_score.round + end + + def test_text_no_image + r = RichText.new("text", "foo https://example.com/ bar") + assert_nil r.image + assert_nil r.image_alt + end + + def test_html_no_image + r = RichText.new("html", "foo bar baz") + assert_nil r.image + assert_nil r.image_alt + end + + def test_markdown_no_image + r = RichText.new("markdown", "foo [bar](https://example.com/) baz") + assert_nil r.image + assert_nil r.image_alt + end + + def test_markdown_image + r = RichText.new("markdown", "foo ![bar](https://example.com/image.jpg) baz") + assert_equal "https://example.com/image.jpg", r.image + assert_equal "bar", r.image_alt + end + + def test_markdown_first_image + r = RichText.new("markdown", "foo ![bar1](https://example.com/image1.jpg) baz\nfoo ![bar2](https://example.com/image2.jpg) baz") + assert_equal "https://example.com/image1.jpg", r.image + assert_equal "bar1", r.image_alt + end + + def test_markdown_image_with_empty_src + r = RichText.new("markdown", "![invalid]()") + assert_nil r.image + assert_nil r.image_alt + end + + def test_markdown_skip_image_with_empty_src + r = RichText.new("markdown", "![invalid]() ![valid](https://example.com/valid.gif)") + assert_equal "https://example.com/valid.gif", r.image + assert_equal "valid", r.image_alt + end + + def test_markdown_html_image + r = RichText.new("markdown", "alt text here") + assert_equal "https://example.com/img_element.png", r.image + assert_equal "alt text here", r.image_alt + end + + def test_markdown_html_image_without_alt + r = RichText.new("markdown", "") + assert_equal "https://example.com/img_element.png", r.image + assert_nil r.image_alt + end + + def test_markdown_html_image_with_empty_src + r = RichText.new("markdown", "forgot src") + assert_nil r.image + assert_nil r.image_alt + end + + def test_markdown_skip_html_image_with_empty_src + r = RichText.new("markdown", "forgot src have src") + assert_equal "https://example.com/next_img_element.png", r.image + assert_equal "have src", r.image_alt + end + + def test_markdown_html_image_without_src + r = RichText.new("markdown", "totally forgot src") + assert_nil r.image + assert_nil r.image_alt + end + + def test_markdown_skip_html_image_without_src + r = RichText.new("markdown", "totally forgot src have src") + assert_equal "https://example.com/next_img_element.png", r.image + assert_equal "have src", r.image_alt + end + + private def assert_html(richtext, &block) html = richtext.to_html - assert html.html_safe? + assert_predicate html, :html_safe? root = Nokogiri::HTML::DocumentFragment.parse(html) assert_select root, "*" do yield block