offendersHelpersTest.js 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283
  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 return null if it fails', function() {
  143. var result = offendersHelpers.backtraceToArray('http://pouet.com/js/jquery.footer-transverse-min-v1.0.20.js:1 /http://pouet.com/js/main.js:1');
  144. should.equal(result, null);
  145. });
  146. });
  147. describe('sortVarsLikeChromeDevTools', function() {
  148. it('should sort in the same strange order', function() {
  149. var result = offendersHelpers.sortVarsLikeChromeDevTools([
  150. 'a',
  151. 'aaa',
  152. 'a2',
  153. 'b',
  154. 'A',
  155. 'AAA',
  156. 'B',
  157. '_a',
  158. '_aaa',
  159. '__a',
  160. 'a_a',
  161. 'aA',
  162. 'a__',
  163. '$',
  164. '$a'
  165. ]);
  166. result.should.deep.equal([
  167. '$',
  168. '$a',
  169. 'A',
  170. 'AAA',
  171. 'B',
  172. '__a',
  173. '_a',
  174. '_aaa',
  175. 'a',
  176. 'a2',
  177. 'aA',
  178. 'a__',
  179. 'a_a',
  180. 'aaa',
  181. 'b'
  182. ]);
  183. });
  184. });
  185. describe('urlToLink', function() {
  186. it('should transform an url into an html link', function() {
  187. var result = offendersHelpers.urlToLink('http://www.google.com/js/main.js');
  188. 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>');
  189. });
  190. it('should ellypsis the url if too long', function() {
  191. var result = offendersHelpers.urlToLink('http://www.google.com/js/longlonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglonglong/main.js');
  192. 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>');
  193. });
  194. });
  195. describe('cssOffenderPattern', function() {
  196. it('should transform a css offender into an object', function() {
  197. var result = offendersHelpers.cssOffenderPattern('.pagination .plus ul li <http://www.pouet.com/css/main.css> @ 30:31862');
  198. result.should.deep.equal({
  199. css: '.pagination .plus ul li',
  200. file: 'http://www.pouet.com/css/main.css',
  201. line: 30,
  202. column: 31862
  203. });
  204. });
  205. it('should work with an inline css', function() {
  206. var result = offendersHelpers.cssOffenderPattern('.pagination .plus ul li [inline CSS] @ 1:32');
  207. result.should.deep.equal({
  208. css: '.pagination .plus ul li',
  209. file: null,
  210. line: 1,
  211. column: 32
  212. });
  213. });
  214. it('should handle the case where line and char are not here', function() {
  215. var result = offendersHelpers.cssOffenderPattern('.pagination .plus ul li');
  216. result.should.deep.equal({
  217. offender: '.pagination .plus ul li'
  218. });
  219. });
  220. });
  221. describe('fileWithSizePattern', function() {
  222. it('should return an object', function() {
  223. var result = offendersHelpers.fileWithSizePattern('http://img3.pouet.com/2008/portail/js/jq-timer.js (1.72 kB)');
  224. result.should.deep.equal({
  225. file: 'http://img3.pouet.com/2008/portail/js/jq-timer.js',
  226. size: 1.72
  227. });
  228. });
  229. });
  230. });