')).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/822b6/822b67b8b0e11a5cbe13baf81cdbac2e4606c1a4" alt="")
')).to eq('
')
expect(sanitize('
data:image/s3,"s3://crabby-images/822b6/822b67b8b0e11a5cbe13baf81cdbac2e4606c1a4" 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/dc9f4/dc9f463ede3016a71b00dab2ca5978ea332eb064" alt=""
')).to eq('
data:image/s3,"s3://crabby-images/dc9f4/dc9f463ede3016a71b00dab2ca5978ea332eb064" alt=""
')
expect(sanitize('
data:image/s3,"s3://crabby-images/b301a/b301a7aff4bf45abcc5888d2f2bd1ff3348833ab" alt=""//)
')).to eq('
data:image/s3,"s3://crabby-images/117df/117df9d979a4a6fc95c8d78bb8deb024b6871f2f" 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 }