, mixed with other HTML elements' do
let(:html) { '
data:image/s3,"s3://crabby-images/bcf87/bcf87505babcc7039a76553bf0d771b8d528f19c" alt=""
123
data:image/s3,"s3://crabby-images/bcf87/bcf87505babcc7039a76553bf0d771b8d528f19c" alt=""
' }
it 'converts embedded image to cid' do
expect(body).to match(%r{
\s+
data:image/s3,"s3://crabby-images/63685/6368588590dd921e22d2cb01b0a9128f4e238f13" alt=""
123
\s+
data:image/s3,"s3://crabby-images/63685/6368588590dd921e22d2cb01b0a9128f4e238f13" alt=""
\s+
})
end
it 'extracts two attachments' do
expect(inline_attachments.length).to be(2)
end
it 'sets filenames sequentially (as imageN.jpeg)' do
expect(inline_attachments.first[:filename]).to eq('image1.jpeg')
expect(inline_attachments.second[:filename]).to eq('image2.jpeg')
end
it 'sets Content-Types to image/jpeg' do
expect(inline_attachments.first[:preferences]['Content-Type']).to eq('image/jpeg')
expect(inline_attachments.second[:preferences]['Content-Type']).to eq('image/jpeg')
end
it 'sets Content-IDs based on Zammad fqdn' do
expect(inline_attachments.first[:preferences]['Content-ID']).to match(%r{@#{Setting.get('fqdn')}})
expect(inline_attachments.second[:preferences]['Content-ID']).to match(%r{@#{Setting.get('fqdn')}})
end
it 'sets Content-Dispositions to inline' do
expect(inline_attachments.first[:preferences]['Content-Disposition']).to eq('inline')
expect(inline_attachments.second[:preferences]['Content-Disposition']).to eq('inline')
end
end
end
context 'when processing pre elements' do
let(:html) do
'
apt-get update
Get:1 http://security.ubuntu.com/ubuntu focal-security InRelease [114 kB]
Hit:2 http://de.archive.ubuntu.com/ubuntu focal InRelease
Building dependency tree...
'
end
it 'does not convert links' do
expect(body).to eq(html)
end
end
end
describe '.dynamic_image_size' do
context 'when called for image at absolute path' do
context 'with src attr last' do
it 'add max-width: 100% rule to style attr' do
expect(described_class.dynamic_image_size(<<~HTML.chomp)).to match(Regexp.new(<<~REGEX.chomp))
data:image/s3,"s3://crabby-images/bcf87/bcf87505babcc7039a76553bf0d771b8d528f19c" alt=""
HTML
data:image/s3,"s3://crabby-images/96579/96579508de64a6f25fc1b61395780dbedb6ddb22" alt=""
REGEX
end
end
context 'with src attr first' do
it 'add max-width: 100% rule to style attr' do
expect(described_class.dynamic_image_size(<<~HTML.chomp)).to match(Regexp.new(<<~REGEX.chomp))
data:image/s3,"s3://crabby-images/bcf87/bcf87505babcc7039a76553bf0d771b8d528f19c" alt="abc"
HTML
data:image/s3,"s3://crabby-images/96579/96579508de64a6f25fc1b61395780dbedb6ddb22" alt="abc"
REGEX
end
end
end
context 'when called for base64-encoded inline images' do
context 'with src attr last' do
it 'add max-width: 100% rule to style attr' do
expect(described_class.dynamic_image_size(<<~HTML.chomp)).to match(Regexp.new(<<~REGEX.chomp))
data:image/s3,"s3://crabby-images/bfe95/bfe95f3d43c26df16a8412c68e0b76d7ac6af6fa" alt="abc"
HTML
data:image/s3,"s3://crabby-images/bfe95/bfe95f3d43c26df16a8412c68e0b76d7ac6af6fa" alt="abc"
REGEX
end
end
context 'with src attr first' do
it 'add max-width: 100% rule to style attr' do
expect(described_class.dynamic_image_size(<<~HTML.chomp)).to match(Regexp.new(<<~REGEX.chomp))
data:image/s3,"s3://crabby-images/bfe95/bfe95f3d43c26df16a8412c68e0b76d7ac6af6fa" alt="abc"
HTML
data:image/s3,"s3://crabby-images/bfe95/bfe95f3d43c26df16a8412c68e0b76d7ac6af6fa" alt="abc"
REGEX
end
end
end
end
# Issue #2416 - html_sanitizer goes into loop for specific content
describe '.strict' do
context 'with strings that take a long time (>10s) to parse' do
before { allow(Timeout).to receive(:timeout).and_raise(Timeout::Error) }
it 'returns a timeout error message for the user' do
expect(described_class.strict(+'
data:image/s3,"s3://crabby-images/bfe95/bfe95f3d43c26df16a8412c68e0b76d7ac6af6fa" alt=""
', true))
.to match(HtmlSanitizer::UNPROCESSABLE_HTML_MSG)
end
end
context 'with href links that contain square brackets' do
it 'correctly URL encodes them' do
expect(described_class.strict(+'
example', true))
.to eq('
example')
end
end
context 'with href links that contain http urls' do
it 'correctly URL encodes them' do
expect(described_class.strict(+'
example', true))
.to eq('
example')
end
end
context 'when HTML sanitizer is removing attributes/styles which are white listed. #4605' do
it 'does not remove whitelisted attributes width' do
expect(described_class.strict('
')).to eq('
')
end
end
context 'when handling
tags' do
let(:source) { 'some titleactual content
' }
let(:target) { 'actual content
' }
it 'removes them' do
expect(described_class.strict(source)).to eq(target)
end
end
end
describe '.cleanup' do
context 'with strings that take a long time (>10s) to parse' do
before { allow(Timeout).to receive(:timeout).and_raise(Timeout::Error) }
it 'returns a timeout error message for the user' do
expect(described_class.cleanup(+'
'))
.to match(HtmlSanitizer::UNPROCESSABLE_HTML_MSG)
end
end
end
end