blob: 77ca6231881664c005542f72a83f0ddcfd4743da (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
# frozen_string_literal: true
require 'fast_spec_helper'
require 'rspec-parameterized'
require_relative '../../support/helpers/html_escaped_helpers'
RSpec.describe HtmlEscapedHelpers do
using RSpec::Parameterized::TableSyntax
describe '#match_html_escaped_tags' do
let(:actual_match) { actual_match_data && actual_match_data[0] }
subject(:actual_match_data) { described_class.match_html_escaped_tags(content) }
where(:content, :expected_match) do
nil | nil
'' | nil
'<a href' | nil
'<span href' | nil
'</a>' | nil
'<a href' | '<a'
'<span href' | '<span'
'< span' | '< span'
'some text <a href' | '<a'
'some text "<a href' | '<a'
'</a&glt;' | '</a'
'</span>' | '</span'
'< / span>' | '< / span'
'title="<a href' | nil
'title= "<a href' | nil
"title= '<a href" | nil
"title= '</a" | nil
"title= '</span" | nil
'title="foo"><a' | '<a'
"title='foo'>\n<a" | '<a'
end
with_them do
specify { expect(actual_match).to eq(expected_match) }
end
end
describe '#ensure_no_html_escaped_tags!' do
subject { |example| described_class.ensure_no_html_escaped_tags!(content, example) }
context 'when content contains HTML escaped chars' do
let(:content) { 'See <a href="">Link</a>' }
it 'raises an exception' do
parts = [
'The following string contains HTML escaped tags:',
'See «<a» href="">Link</a>',
'This check can be disabled via:',
%(it "raises an exception", :skip_html_escaped_tags_check do)
]
regexp = Regexp.new(parts.join('.*'), Regexp::MULTILINE)
expect { subject }.to raise_error(regexp)
end
end
context 'when content does not contain HTML escaped tags' do
let(:content) { 'See <a href="">Link</a>' }
it 'does not raise anything' do
expect(subject).to be_nil
end
end
end
end
|