X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/cb87f02642d0097ebc067ca1f9371dde274a41e3..00db1066ef1198355bfec4e043c3e51411112294:/test/lib/rich_text_test.rb?ds=inline diff --git a/test/lib/rich_text_test.rb b/test/lib/rich_text_test.rb index 74d396b68..e0b315276 100644 --- a/test/lib/rich_text_test.rb +++ b/test/lib/rich_text_test.rb @@ -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
column |
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 @@ -64,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") @@ -145,6 +176,39 @@ 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 @@ -162,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") @@ -186,11 +250,89 @@ class RichTextTest < ActiveSupport::TestCase 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", "") + 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", "") + assert_nil r.image + assert_nil r.image_alt + end + + def test_markdown_skip_html_image_with_empty_src + r = RichText.new("markdown", " ") + 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", "") + assert_nil r.image + assert_nil r.image_alt + end + + def test_markdown_skip_html_image_without_src + r = RichText.new("markdown", " ") + 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