2021-03-11 19:13:27 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
RSpec.describe Banzai::Pipeline::PlainMarkdownPipeline do
|
|
|
|
using RSpec::Parameterized::TableSyntax
|
|
|
|
|
2021-12-11 22:18:48 +05:30
|
|
|
shared_examples_for 'renders correct markdown' do
|
2021-03-11 19:13:27 +05:30
|
|
|
describe 'CommonMark tests', :aggregate_failures do
|
2021-04-17 20:07:23 +05:30
|
|
|
it 'converts all reference punctuation to literals' do
|
|
|
|
reference_chars = Banzai::Filter::MarkdownPreEscapeFilter::REFERENCE_CHARACTERS
|
|
|
|
markdown = reference_chars.split('').map {|char| char.prepend("\\") }.join
|
|
|
|
punctuation = Banzai::Filter::MarkdownPreEscapeFilter::REFERENCE_CHARACTERS.split('')
|
|
|
|
punctuation = punctuation.delete_if {|char| char == '&' }
|
|
|
|
punctuation << '&'
|
2021-03-11 19:13:27 +05:30
|
|
|
|
|
|
|
result = described_class.call(markdown, project: project)
|
|
|
|
output = result[:output].to_html
|
|
|
|
|
|
|
|
punctuation.each { |char| expect(output).to include("<span>#{char}</span>") }
|
|
|
|
expect(result[:escaped_literals]).to be_truthy
|
|
|
|
end
|
|
|
|
|
2021-12-11 22:18:48 +05:30
|
|
|
it 'ensure we handle all the GitLab reference characters', :eager_load do
|
2021-04-17 20:07:23 +05:30
|
|
|
reference_chars = ObjectSpace.each_object(Class).map do |klass|
|
|
|
|
next unless klass.included_modules.include?(Referable)
|
|
|
|
next unless klass.respond_to?(:reference_prefix)
|
|
|
|
next unless klass.reference_prefix.length == 1
|
2021-03-11 19:13:27 +05:30
|
|
|
|
2021-04-17 20:07:23 +05:30
|
|
|
klass.reference_prefix
|
|
|
|
end.compact
|
2021-03-11 19:13:27 +05:30
|
|
|
|
2021-04-17 20:07:23 +05:30
|
|
|
reference_chars.all? do |char|
|
|
|
|
Banzai::Filter::MarkdownPreEscapeFilter::REFERENCE_CHARACTERS.include?(char)
|
2021-03-11 19:13:27 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2021-04-17 20:07:23 +05:30
|
|
|
it 'does not convert non-reference punctuation to spans' do
|
|
|
|
markdown = %q(\"\'\*\+\,\-\.\/\:\;\<\=\>\?\[\]\_\`\{\|\}) + %q[\(\)\\\\]
|
2021-03-11 19:13:27 +05:30
|
|
|
|
2021-04-17 20:07:23 +05:30
|
|
|
result = described_class.call(markdown, project: project)
|
|
|
|
output = result[:output].to_html
|
|
|
|
|
|
|
|
expect(output).not_to include('<span>')
|
|
|
|
expect(result[:escaped_literals]).to be_falsey
|
2021-03-11 19:13:27 +05:30
|
|
|
end
|
|
|
|
|
2021-04-17 20:07:23 +05:30
|
|
|
it 'does not convert other characters to literals' do
|
|
|
|
markdown = %q(\→\A\a\ \3\φ\«)
|
|
|
|
expected = '\→\A\a\ \3\φ\«'
|
2021-03-11 19:13:27 +05:30
|
|
|
|
2021-04-17 20:07:23 +05:30
|
|
|
result = correct_html_included(markdown, expected)
|
|
|
|
expect(result[:escaped_literals]).to be_falsey
|
2021-03-11 19:13:27 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
describe 'backslash escapes do not work in code blocks, code spans, autolinks, or raw HTML' do
|
|
|
|
where(:markdown, :expected) do
|
2021-04-17 20:07:23 +05:30
|
|
|
%q(`` \@\! ``) | %q(<code>\@\!</code>)
|
|
|
|
%q( \@\!) | %Q(<code>\\@\\!\n</code>)
|
|
|
|
%Q(~~~\n\\@\\!\n~~~) | %Q(<code>\\@\\!\n</code>)
|
|
|
|
%q(<http://example.com?find=\@>) | %q(<a href="http://example.com?find=%5C@">http://example.com?find=\@</a>)
|
|
|
|
%q[<a href="/bar\@)">] | %q[<a href="/bar%5C@)">]
|
2021-03-11 19:13:27 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
with_them do
|
|
|
|
it { correct_html_included(markdown, expected) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'work in all other contexts, including URLs and link titles, link references, and info strings in fenced code blocks' do
|
2021-12-11 22:18:48 +05:30
|
|
|
let(:markdown) { %Q(``` foo\\@bar\nfoo\n```) }
|
|
|
|
|
|
|
|
it 'renders correct html' do
|
|
|
|
if Feature.enabled?(:use_cmark_renderer)
|
|
|
|
correct_html_included(markdown, %Q(<pre data-sourcepos="1:1-3:3" lang="foo@bar"><code>foo\n</code></pre>))
|
|
|
|
else
|
|
|
|
correct_html_included(markdown, %Q(<code lang="foo@bar">foo\n</code>))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2021-03-11 19:13:27 +05:30
|
|
|
where(:markdown, :expected) do
|
2021-04-17 20:07:23 +05:30
|
|
|
%q![foo](/bar\@ "\@title")! | %q(<a href="/bar@" title="@title">foo</a>)
|
|
|
|
%Q![foo]\n\n[foo]: /bar\\@ "\\@title"! | %q(<a href="/bar@" title="@title">foo</a>)
|
2021-03-11 19:13:27 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
with_them do
|
|
|
|
it { correct_html_included(markdown, expected) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2021-12-11 22:18:48 +05:30
|
|
|
|
|
|
|
describe 'backslash escapes' do
|
|
|
|
let_it_be(:project) { create(:project, :public) }
|
|
|
|
let_it_be(:issue) { create(:issue, project: project) }
|
|
|
|
|
|
|
|
def correct_html_included(markdown, expected)
|
|
|
|
result = described_class.call(markdown, {})
|
|
|
|
|
|
|
|
expect(result[:output].to_html).to include(expected)
|
|
|
|
|
|
|
|
result
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'using ruby-based HTML renderer' do
|
|
|
|
before do
|
|
|
|
stub_feature_flags(use_cmark_renderer: false)
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'renders correct markdown'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'using c-based HTML renderer' do
|
|
|
|
before do
|
|
|
|
stub_feature_flags(use_cmark_renderer: true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'renders correct markdown'
|
|
|
|
end
|
|
|
|
end
|
2021-03-11 19:13:27 +05:30
|
|
|
end
|