@@ -606,6 +606,56 @@ def test_disallow_the_dangerous_safelist_combination_of_select_and_style
606
606
refute_includes ( sanitized , "style" )
607
607
end
608
608
609
+ %w[ text/plain text/css image/png image/gif image/jpeg ] . each do |mediatype |
610
+ define_method "test_mediatype_#{ mediatype } _allowed" do
611
+ input = %Q(<img src="data:#{ mediatype } ;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4=">)
612
+ expected = input
613
+ actual = safe_list_sanitize ( input )
614
+ assert_equal ( expected , actual )
615
+
616
+ input = %Q(<img src="DATA:#{ mediatype } ;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4=">)
617
+ expected = input
618
+ actual = safe_list_sanitize ( input )
619
+ assert_equal ( expected , actual )
620
+ end
621
+ end
622
+
623
+ def test_mediatype_text_html_disallowed
624
+ input = %q(<img src="data:text/html;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4=">)
625
+ expected = %q(<img>)
626
+ actual = safe_list_sanitize ( input )
627
+ assert_equal ( expected , actual )
628
+
629
+ input = %q(<img src="DATA:text/html;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4=">)
630
+ expected = %q(<img>)
631
+ actual = safe_list_sanitize ( input )
632
+ assert_equal ( expected , actual )
633
+ end
634
+
635
+ def test_mediatype_image_svg_xml_disallowed
636
+ input = %q(<img src="">)
637
+ expected = %q(<img>)
638
+ actual = safe_list_sanitize ( input )
639
+ assert_equal ( expected , actual )
640
+
641
+ input = %q(<img src="DATA:image/svg+xml;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4=">)
642
+ expected = %q(<img>)
643
+ actual = safe_list_sanitize ( input )
644
+ assert_equal ( expected , actual )
645
+ end
646
+
647
+ def test_mediatype_other_disallowed
648
+ input = %q(<a href="data:foo;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4=">foo</a>)
649
+ expected = %q(<a>foo</a>)
650
+ actual = safe_list_sanitize ( input )
651
+ assert_equal ( expected , actual )
652
+
653
+ input = %q(<a href="DATA:foo;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4=">foo</a>)
654
+ expected = %q(<a>foo</a>)
655
+ actual = safe_list_sanitize ( input )
656
+ assert_equal ( expected , actual )
657
+ end
658
+
609
659
def test_scrubbing_svg_attr_values_that_allow_ref
610
660
input = %Q(<div fill="yellow url(http://bad.com/) #fff">hey</div>)
611
661
expected = %Q(<div fill="yellow #fff">hey</div>)
0 commit comments