')).to eq('
')
expect(sanitize('
test')).to eq('
test')
expect(sanitize('
test')).to eq('
test')
expect(sanitize('
test', external: true)).to eq('
test')
expect(sanitize('
data:image/s3,"s3://crabby-images/dbd05/dbd0567c33dc92eea5b20d42974c10bb948e2905" alt="")
')).to eq('
')
expect(sanitize('
data:image/s3,"s3://crabby-images/dbd05/dbd0567c33dc92eea5b20d42974c10bb948e2905" alt="")
')).to eq('')
expect(sanitize('
+ADw-SCRIPT+AD4-alert(\'XSS\');+ADw-/SCRIPT+AD4-')).to eq(' +ADw-SCRIPT+AD4-alert(\'XSS\');+ADw-/SCRIPT+AD4-')
expect(sanitize('')).to eq('')
expect(sanitize("
XSS")).to eq('
XSS')
expect(sanitize("
XSS", external: true)).to eq('
XSS')
expect(sanitize('
XSS')).to eq('
XSS')
expect(sanitize('
XSS', external: true)).to eq('
XSS')
expect(sanitize('
')).to eq('X')
expect(sanitize('
CLICKME')).to eq('CLICKME')
expect(sanitize('
CLICKME')).to eq('CLICKME')
expect(sanitize('
CLICKME', external: true)).to eq('CLICKME')
expect(sanitize('
data:image/s3,"s3://crabby-images/6f626/6f626d274717daf84010e92786052dd6bf0b8b76" alt=""
')).to eq('
data:image/s3,"s3://crabby-images/6f626/6f626d274717daf84010e92786052dd6bf0b8b76" alt=""
')
expect(sanitize('
data:image/s3,"s3://crabby-images/dafd0/dafd062e549c7968ce4e06b911c6ac6037d11b2b" alt=""//)
')).to eq('
data:image/s3,"s3://crabby-images/ad43f/ad43f094ce85ee8dca21c31aeb062491829c2560" alt=""//)
')
expect(sanitize('
')).to eq('')
expect(sanitize('
')).to eq('
')
expect(sanitize('')).to eq('')
expect(sanitize('')).to eq('')
expect(sanitize('
')).to eq('
')
expect(sanitize('XXX')).to eq('XXX')
expect(sanitize('XXX', external: true)).to eq('XXX')
expect(sanitize('')).to eq('')
end
it 'performs style cleanups' do
expect(sanitize('')).to eq('')
expect(sanitize('', external: true)).to eq('')
expect(sanitize('')).to eq('')
expect(sanitize('')).to eq('')
expect(sanitize('')).to eq('')
expect(sanitize('')).to eq('')
expect(sanitize('')).to eq('')
expect(sanitize('')).to eq('')
expect(sanitize('')).to eq('')
expect(sanitize('')).to eq('')
expect(sanitize('')).to eq('')
expect(sanitize('')).to eq('')
expect(sanitize('このアドレスへのメルマガを解除してください。
')).to eq('このアドレスへのメルマガを解除してください。
')
end
context 'when performing multiline style cleanup' do
let(:input) { <<~INPUT }
INPUT
let(:output) { <<~OUTPUT }
OUTPUT
it 'filters correctly' do
expect(sanitize(input)).to eq(output)
end
end
context 'when performing more multiline style cleanup' do
let(:input) { <<~INPUT }
123
abc
INPUT
let(:output) { <<~OUTPUT }