offendersHelpersTest.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328
  1. var should = require('chai').should();
  2. var offendersHelpers = require('../../lib/offendersHelpers');
  3. describe('offendersHelpers', function() {
  4. describe('domPathToArray', function() {
  5. it('should transform a path to an array', function() {
  6. var result = offendersHelpers.domPathToArray('body > section#page > div.alternate-color > ul.retroGuide > li[0] > div.retro-chaine.france2');
  7. result.should.deep.equal(['body', 'section#page', 'div.alternate-color', 'ul.retroGuide', 'li[0]', 'div.retro-chaine.france2']);
  8. });
  9. it('should work even if a space is missing', function() {
  10. var result = offendersHelpers.domPathToArray('body > section#page> div.alternate-color > ul.retroGuide >li[0] > div.retro-chaine.france2');
  11. result.should.deep.equal(['body', 'section#page', 'div.alternate-color', 'ul.retroGuide', 'li[0]', 'div.retro-chaine.france2']);
  12. });
  13. });
  14. describe('listOfDomArraysToTree', function() {
  15. it('should transform a list of arrays into a tree', function() {
  16. var input = [
  17. ['body', 'section#page', 'div.alternate-color', 'ul.retroGuide', 'li[0]', 'div.retro-chaine.france2'],
  18. ['body', 'section#page', 'div.alternate-color', 'ul.retroGuide', 'li[0]', 'div.retro-chaine.france2'],
  19. ['body', 'section#page', 'div.alternate-color', 'ul.retroGuide', 'li[1]', 'div.retro-chaine.france2']
  20. ];
  21. var inputClone = input.slice();
  22. var result = offendersHelpers.listOfDomArraysToTree(input);
  23. result.should.deep.equal({
  24. 'body': {
  25. 'section#page': {
  26. 'div.alternate-color': {
  27. 'ul.retroGuide': {
  28. 'li[0]': {
  29. 'div.retro-chaine.france2': 2
  30. },
  31. 'li[1]': {
  32. 'div.retro-chaine.france2': 1
  33. }
  34. }
  35. }
  36. }
  37. }
  38. });
  39. input.should.deep.equal(inputClone);
  40. });
  41. });
  42. describe('domPathToDomElementObj', function() {
  43. it('should transform html', function() {
  44. var result = offendersHelpers.domPathToDomElementObj('html');
  45. result.should.deep.equal({
  46. type: 'html'
  47. });
  48. });
  49. it('should transform body', function() {
  50. var result = offendersHelpers.domPathToDomElementObj('body');
  51. result.should.deep.equal({
  52. type: 'body'
  53. });
  54. });
  55. it('should transform head', function() {
  56. var result = offendersHelpers.domPathToDomElementObj('head');
  57. result.should.deep.equal({
  58. type: 'head'
  59. });
  60. });
  61. it('should transform #document', function() {
  62. var result = offendersHelpers.domPathToDomElementObj('#document');
  63. result.should.deep.equal({
  64. type: 'document'
  65. });
  66. });
  67. it('should transform window', function() {
  68. var result = offendersHelpers.domPathToDomElementObj('window');
  69. result.should.deep.equal({
  70. type: 'window'
  71. });
  72. });
  73. it('should transform a standard in-body element', function() {
  74. var result = offendersHelpers.domPathToDomElementObj('body > div#colorbox > div#cboxContent');
  75. result.should.deep.equal({
  76. type: 'domElement',
  77. element: 'div#cboxContent',
  78. tree: {
  79. 'body': {
  80. 'div#colorbox': {
  81. 'div#cboxContent': 1
  82. }
  83. }
  84. }
  85. });
  86. });
  87. it('should transform a domFragment element', function() {
  88. var result = offendersHelpers.domPathToDomElementObj('DocumentFragment');
  89. result.should.deep.equal({
  90. type: 'fragment'
  91. });
  92. });
  93. it('should transform a domFragment element', function() {
  94. var result = offendersHelpers.domPathToDomElementObj('DocumentFragment > div#colorbox > div#cboxContent');
  95. result.should.deep.equal({
  96. type: 'fragmentElement',
  97. element: 'div#cboxContent',
  98. tree: {
  99. 'DocumentFragment': {
  100. 'div#colorbox': {
  101. 'div#cboxContent': 1
  102. }
  103. }
  104. }
  105. });
  106. });
  107. it('should transform an not-attached element', function() {
  108. var result = offendersHelpers.domPathToDomElementObj('div#sizcache');
  109. result.should.deep.equal({
  110. type: 'createdElement',
  111. element: 'div#sizcache'
  112. });
  113. });
  114. it('should transform an not-attached element path', function() {
  115. var result = offendersHelpers.domPathToDomElementObj('div > div#sizcache');
  116. result.should.deep.equal({
  117. type: 'createdElement',
  118. element: 'div#sizcache',
  119. tree: {
  120. 'div': {
  121. 'div#sizcache': 1
  122. }
  123. }
  124. });
  125. });
  126. });
  127. describe('backtraceToArray', function() {
  128. it('should transform a backtrace into an array', function() {
  129. var result = offendersHelpers.backtraceToArray('http://pouet.com/js/jquery.footer-transverse-min-v1.0.20.js:1 / callback http://pouet.com/js/main.js:1');
  130. result.should.deep.equal([
  131. {
  132. file: 'http://pouet.com/js/jquery.footer-transverse-min-v1.0.20.js',
  133. line: 1
  134. },
  135. {
  136. functionName: 'callback',
  137. file: 'http://pouet.com/js/main.js',
  138. line: 1
  139. }
  140. ]);
  141. });
  142. it('should transform another backtrace syntax into an array', function() {
  143. var result = offendersHelpers.backtraceToArray('phantomjs://webpage.evaluate():38 / e (http://s7.addthis.com/js/300/addthis_widget.js:1) / a (http://s7.addthis.com/js/300/addthis_widget.js:1) / http://s7.addthis.com/js/300/addthis_widget.js:3 / e (http://s7.addthis.com/js/300/addthis_widget.js:1) / http://s7.addthis.com/js/300/addthis_widget.js:8');
  144. result.should.deep.equal([
  145. {
  146. file: 'phantomjs://webpage.evaluate()',
  147. line: 38
  148. },
  149. {
  150. functionName: 'e',
  151. file: 'http://s7.addthis.com/js/300/addthis_widget.js',
  152. line: 1
  153. },
  154. {
  155. functionName: 'a',
  156. file: 'http://s7.addthis.com/js/300/addthis_widget.js',
  157. line: 1
  158. },
  159. {
  160. file: 'http://s7.addthis.com/js/300/addthis_widget.js',
  161. line: 3
  162. },
  163. {
  164. functionName: 'e',
  165. file: 'http://s7.addthis.com/js/300/addthis_widget.js',
  166. line: 1
  167. },
  168. {
  169. file: 'http://s7.addthis.com/js/300/addthis_widget.js',
  170. line: 8
  171. }
  172. ]);
  173. });
  174. it('should return null if it fails', function() {
  175. var result = offendersHelpers.backtraceToArray('http://pouet.com/js/jquery.footer-transverse-min-v1.0.20.js:1 /http://pouet.com/js/main.js:1');
  176. should.equal(result, null);
  177. });
  178. });
  179. describe('sortVarsLikeChromeDevTools', function() {
  180. it('should sort in the same strange order', function() {
  181. var result = offendersHelpers.sortVarsLikeChromeDevTools([
  182. 'a',
  183. 'aaa',
  184. 'a2',
  185. 'b',
  186. 'A',
  187. 'AAA',
  188. 'B',
  189. '_a',
  190. '_aaa',
  191. '__a',
  192. 'a_a',
  193. 'aA',
  194. 'a__',
  195. '$',
  196. '$a'
  197. ]);
  198. result.should.deep.equal([
  199. '$',
  200. '$a',
  201. 'A',
  202. 'AAA',
  203. 'B',
  204. '__a',
  205. '_a',
  206. '_aaa',
  207. 'a',
  208. 'a2',
  209. 'aA',
  210. 'a__',
  211. 'a_a',
  212. 'aaa',
  213. 'b'
  214. ]);
  215. });
  216. });
  217. describe('urlToLink', function() {
  218. it('should transform an url into an html link', function() {
  219. var result = offendersHelpers.urlToLink('http://www.google.com/js/main.js');
  220. result.should.equal('<a href="http://www.google.com/js/main.js" target="_blank" title="http://www.google.com/js/main.js">http://www.google.com/js/main.js</a>');
  221. });
  222. it('should ellypsis the url if too long', function() {
  223. var result = offendersHelpers.urlToLink('http://www.google.com/js/longlonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglong/main.js');
  224. result.should.equal('<a href="http://www.google.com/js/longlonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglong/main.js" target="_blank" title="http://www.google.com/js/longlonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglong/main.js">http://www.google.com/js/longlonglonglonglonglo ... longlonglonglonglonglonglonglonglonglong/main.js</a>');
  225. });
  226. });
  227. describe('cssOffenderPattern', function() {
  228. it('should transform a css offender into an object', function() {
  229. var result = offendersHelpers.cssOffenderPattern('.pagination .plus ul li <http://www.pouet.com/css/main.css> @ 30:31862');
  230. result.should.deep.equal({
  231. css: '.pagination .plus ul li',
  232. file: 'http://www.pouet.com/css/main.css',
  233. line: 30,
  234. column: 31862
  235. });
  236. });
  237. it('should work with an inline css', function() {
  238. var result = offendersHelpers.cssOffenderPattern('.pagination .plus ul li [inline CSS] @ 1:32');
  239. result.should.deep.equal({
  240. css: '.pagination .plus ul li',
  241. file: null,
  242. line: 1,
  243. column: 32
  244. });
  245. });
  246. it('should handle the case where line and char are not here', function() {
  247. var result = offendersHelpers.cssOffenderPattern('.pagination .plus ul li');
  248. result.should.deep.equal({
  249. offender: '.pagination .plus ul li'
  250. });
  251. });
  252. it('should handle line breaks inside the string', function() {
  253. var result = offendersHelpers.cssOffenderPattern('.card-mask-wrap { -moz-transform: translate3d(0, \n-288px\n, 0) } // was required by firefox 15 and earlier [inline CSS] @ 29:3');
  254. result.should.deep.equal({
  255. css: '.card-mask-wrap { -moz-transform: translate3d(0, -288px, 0) } // was required by firefox 15 and earlier',
  256. file: null,
  257. line: 29,
  258. column: 3
  259. });
  260. });
  261. });
  262. describe('fileWithSizePattern', function() {
  263. it('should return an object', function() {
  264. var result = offendersHelpers.fileWithSizePattern('http://img3.pouet.com/2008/portail/js/jq-timer.js (1.72 kB)');
  265. result.should.deep.equal({
  266. file: 'http://img3.pouet.com/2008/portail/js/jq-timer.js',
  267. size: 1.72
  268. });
  269. });
  270. });
  271. });