')).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/53eaa/53eaaa22674395b3d9a84a8b7ff678eb8a072b87" alt="")
')).to eq('
')
expect(sanitize('
data:image/s3,"s3://crabby-images/53eaa/53eaaa22674395b3d9a84a8b7ff678eb8a072b87" 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/2f496/2f4962bc157d391355d1045566f62040bed9da73" alt=""
')).to eq('
data:image/s3,"s3://crabby-images/2f496/2f4962bc157d391355d1045566f62040bed9da73" alt=""
')
expect(sanitize('
data:image/s3,"s3://crabby-images/42316/423163ebea058278fedd360b54b52fa5d897c413" alt=""//)
')).to eq('
data:image/s3,"s3://crabby-images/3d019/3d0199b092da26c3fd172d0808bca224a74886cc" 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 }