X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/eab2eeaa47b2aa8c7f52371f9bfdd60711a41fb6..d750cc3e808191e9a5a7a43148bd91b42a1b16e8:/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 e99d594a4..8dc9e49b1 100644 --- a/test/lib/rich_text_test.rb +++ b/test/lib/rich_text_test.rb @@ -1,21 +1,28 @@ -require 'test_helper' +require "test_helper" class RichTextTest < ActiveSupport::TestCase - include ActionDispatch::Assertions::SelectorAssertions + include Rails::Dom::Testing::Assertions::SelectorAssertions def test_html_to_html r = RichText.new("html", "foo http://example.com/ bar") 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 + 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") @@ -152,16 +236,51 @@ class RichTextTest < ActiveSupport::TestCase r = RichText.new("text", "foo < bar & baz > qux") assert_html r do - assert_select "p", "foo < bar & baz > qux" + assert_select "p", "foo < bar & baz > qux" 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 + end + + def test_html_no_image + r = RichText.new("html", "foo bar baz") + assert_nil r.image + end + + def test_markdown_no_image + r = RichText.new("markdown", "foo [bar](https://example.com/) baz") + assert_nil r.image + 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 + 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 + end + + private def assert_html(richtext, &block) html = richtext.to_html - assert html.html_safe? - root = HTML::Document.new(richtext.to_html, false, true).root + assert_predicate html, :html_safe? + root = Nokogiri::HTML::DocumentFragment.parse(html) assert_select root, "*" do yield block end