mirror of
https://github.com/Hopiu/angular.js.git
synced 2026-03-23 01:40:25 +00:00
155 lines
5.3 KiB
JavaScript
155 lines
5.3 KiB
JavaScript
|
|
describe('HTML', function(){
|
||
|
|
|
||
|
|
function expectHTML(html) {
|
||
|
|
return expect(new HTML(html).get());
|
||
|
|
}
|
||
|
|
|
||
|
|
it('should echo html', function(){
|
||
|
|
expectHTML('hello<b class="1\'23" align=\'""\'>world</b>.').
|
||
|
|
toEqual('hello<b class="1\'23" align="""">world</b>.');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should remove script', function(){
|
||
|
|
expectHTML('a<SCRIPT>evil< / scrIpt >c.').toEqual('ac.');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should remove nested script', function(){
|
||
|
|
expectHTML('a< SCRIPT >A< SCRIPT >evil< / scrIpt >B< / scrIpt >c.').toEqual('ac.');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should remove attrs', function(){
|
||
|
|
expectHTML('a<div style="abc">b</div>c').toEqual('a<div>b</div>c');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should remove style', function(){
|
||
|
|
expectHTML('a<STyle>evil</stYle>c.').toEqual('ac.');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should remove script and style', function(){
|
||
|
|
expectHTML('a<STyle>evil<script></script></stYle>c.').toEqual('ac.');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should remove double nested script', function(){
|
||
|
|
expectHTML('a<SCRIPT>ev<script>evil</sCript>il</scrIpt>c.').toEqual('ac.');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should remove unknown tag names', function(){
|
||
|
|
expectHTML('a<xxx><B>b</B></xxx>c').toEqual('a<b>b</b>c');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should remove unsafe value', function(){
|
||
|
|
expectHTML('<a href="javascript:alert()">').toEqual('<a></a>');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should handle self closed elements', function(){
|
||
|
|
expectHTML('a<hr/>c').toEqual('a<hr/>c');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should handle namespace', function(){
|
||
|
|
expectHTML('a<my:hr/><my:div>b</my:div>c').toEqual('abc');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should handle improper html', function(){
|
||
|
|
expectHTML('< div id="</div>" alt=abc href=\'"\' >text< /div>').
|
||
|
|
toEqual('<div id="</div>" alt="abc" href=""">text</div>');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should handle improper html2', function(){
|
||
|
|
expectHTML('< div id="</div>" / >').
|
||
|
|
toEqual('<div id="</div>"/>');
|
||
|
|
});
|
||
|
|
|
||
|
|
describe('htmlSanitizerWriter', function(){
|
||
|
|
var writer, html;
|
||
|
|
beforeEach(function(){
|
||
|
|
html = '';
|
||
|
|
writer = htmlSanitizeWriter({push:function(text){html+=text;}});
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should write basic HTML', function(){
|
||
|
|
writer.chars('before');
|
||
|
|
writer.start('div', {id:'123'}, false);
|
||
|
|
writer.chars('in');
|
||
|
|
writer.end('div');
|
||
|
|
writer.chars('after');
|
||
|
|
|
||
|
|
expect(html).toEqual('before<div id="123">in</div>after');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should escape text nodes', function(){
|
||
|
|
writer.chars('a<div>&</div>c');
|
||
|
|
expect(html).toEqual('a<div>&</div>c');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should not double escape entities', function(){
|
||
|
|
writer.chars(' ><');
|
||
|
|
expect(html).toEqual(' ><');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should escape IE script', function(){
|
||
|
|
writer.chars('&{}');
|
||
|
|
expect(html).toEqual('&{}');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should escape attributes', function(){
|
||
|
|
writer.start('div', {id:'\"\'<>'});
|
||
|
|
expect(html).toEqual('<div id=""\'<>">');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should ignore missformed elements', function(){
|
||
|
|
writer.start('d>i&v', {});
|
||
|
|
expect(html).toEqual('');
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should ignore unknown attributes', function(){
|
||
|
|
writer.start('div', {unknown:""});
|
||
|
|
expect(html).toEqual('<div>');
|
||
|
|
});
|
||
|
|
|
||
|
|
describe('javascript URL attribute', function(){
|
||
|
|
beforeEach(function(){
|
||
|
|
this.addMatchers({
|
||
|
|
toBeValidUrl: function(){
|
||
|
|
return !isJavaScriptUrl(this.actual);
|
||
|
|
}
|
||
|
|
});
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should ignore javascript:', function(){
|
||
|
|
expect('JavaScript:abc').not.toBeValidUrl();
|
||
|
|
expect(' \n Java\n Script:abc').not.toBeValidUrl();
|
||
|
|
expect('JavaScript/my.js').toBeValidUrl();
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should ignore dec encoded javascript:', function(){
|
||
|
|
expect('javascript:').not.toBeValidUrl();
|
||
|
|
expect('javascript:').not.toBeValidUrl();
|
||
|
|
expect('j avascript:').not.toBeValidUrl();
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should ignore decimal with leading 0 encodede javascript:', function(){
|
||
|
|
expect('javascript:').not.toBeValidUrl();
|
||
|
|
expect('j avascript:').not.toBeValidUrl();
|
||
|
|
expect('j avascript:').not.toBeValidUrl();
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should ignore hex encoded javascript:', function(){
|
||
|
|
expect('javascript:').not.toBeValidUrl();
|
||
|
|
expect('javascript:').not.toBeValidUrl();
|
||
|
|
expect('j avascript:').not.toBeValidUrl();
|
||
|
|
});
|
||
|
|
|
||
|
|
it('should ignore hex encoded whitespace javascript:', function(){
|
||
|
|
expect('jav	ascript:alert("A");').not.toBeValidUrl();
|
||
|
|
expect('jav
ascript:alert("B");').not.toBeValidUrl();
|
||
|
|
expect('jav
 ascript:alert("C");').not.toBeValidUrl();
|
||
|
|
expect('jav\u0000ascript:alert("D");').not.toBeValidUrl();
|
||
|
|
expect('java\u0000\u0000script:alert("D");').not.toBeValidUrl();
|
||
|
|
expect('  java\u0000\u0000script:alert("D");').not.toBeValidUrl();
|
||
|
|
});
|
||
|
|
});
|
||
|
|
|
||
|
|
});
|
||
|
|
|
||
|
|
});
|