# Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
require 'rails_helper'
RSpec.describe HtmlSanitizer::Scrubber::Wipe do
let(:scrubber) { described_class.new }
describe('#scrubber') do
subject(:actual) do
# export with extra options to avoid html indentation
fragment.scrub!(scrubber)
.to_html save_with: Nokogiri::XML::Node::SaveOptions::DEFAULT_HTML ^ Nokogiri::XML::Node::SaveOptions::FORMAT
end
let(:fragment) { Loofah.fragment(input) }
context 'when has not allowed tag' do
let(:input) { 'asd' }
let(:target) { 'asd' }
it { is_expected.to eq target }
end
context 'when has not allowed tag in not allowed' do
let(:input) { 'asd' }
let(:target) { 'asd' }
it { is_expected.to eq target }
end
context 'when has not allowed tag inside of an allowed tag' do
let(:input) { '
' }
let(:target) { '' }
it { is_expected.to eq target }
end
context 'when insecure source' do
let(:input) { '' }
let(:target) { '' }
it { is_expected.to eq target }
end
context 'when has not allowed classes' do
let(:input) { '' }
let(:target) { '' }
it { is_expected.to eq target }
end
context 'when has width and height attributes' do
let(:input) { '' }
let(:target) { '' }
it { is_expected.to eq target }
end
context 'when has width and max-width attributes' do
let(:input) { '' }
let(:target) { '' }
it { is_expected.to eq target }
end
context 'when has not allowed attributes' do
let(:input) { 'test
' }
let(:target) { 'test
' }
it { is_expected.to eq target }
end
context 'when has style' do
let(:input) { 'test
test
' }
let(:target) { 'test
test
' }
it { is_expected.to eq target }
end
context 'when has executeable link' do
let(:input) { '' }
let(:target) { '' }
it { is_expected.to eq target }
it 'does not mark remote content as removed' do
expect { actual }.not_to change(scrubber, :remote_content_removed)
end
end
context 'when has an image with a proper link' do
let(:input) { '' }
let(:target) { '' }
it { is_expected.to eq target }
it 'does mark remote content as removed' do
expect { actual }.to change(scrubber, :remote_content_removed).from(false).to(true)
end
end
end
end