codeframe.spec.ts 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. import { generateCodeFrame } from '../src/codeframe'
  2. describe('compiler: codeframe', () => {
  3. const source = `
  4. <div>
  5. <template key="one"></template>
  6. <ul>
  7. <li v-for="foobar">hi</li>
  8. </ul>
  9. <template key="two"></template>
  10. </div>
  11. `.trim()
  12. test('line near top', () => {
  13. const keyStart = source.indexOf(`key="one"`)
  14. const keyEnd = keyStart + `key="one"`.length
  15. expect(generateCodeFrame(source, keyStart, keyEnd)).toMatchSnapshot()
  16. })
  17. test('line in middle', () => {
  18. // should cover 5 lines
  19. const forStart = source.indexOf(`v-for=`)
  20. const forEnd = forStart + `v-for="foobar"`.length
  21. expect(generateCodeFrame(source, forStart, forEnd)).toMatchSnapshot()
  22. })
  23. test('line near bottom', () => {
  24. const keyStart = source.indexOf(`key="two"`)
  25. const keyEnd = keyStart + `key="two"`.length
  26. expect(generateCodeFrame(source, keyStart, keyEnd)).toMatchSnapshot()
  27. })
  28. test('multi-line highlights', () => {
  29. const source = `
  30. <div attr="some
  31. multiline
  32. attr
  33. ">
  34. </div>
  35. `.trim()
  36. const attrStart = source.indexOf(`attr=`)
  37. const attrEnd = source.indexOf(`">`) + 1
  38. expect(generateCodeFrame(source, attrStart, attrEnd)).toMatchSnapshot()
  39. })
  40. test('invalid start and end', () => {
  41. expect(generateCodeFrame(source, -Infinity, 0)).toMatchSnapshot()
  42. expect(generateCodeFrame(source, 0, Infinity)).toMatchSnapshot()
  43. expect(generateCodeFrame(source, Infinity, 0)).toMatchSnapshot()
  44. })
  45. {
  46. const source = `
  47. <template>
  48. <div>
  49. <h1>Sign In</h1>
  50. <form>
  51. <div>
  52. <label for="email">Email</label>
  53. <input name="email" type="text"/>
  54. </div>
  55. <div id="hook">
  56. <label for="password">Password</label>
  57. <input name="password" type="password"/>
  58. </div>
  59. </form>
  60. </div>
  61. </template>
  62. `
  63. const startToken = '<div id="hook">'
  64. const endToken = '</div>'
  65. // Explicitly ensure the line-ending for the platform instead of assuming
  66. // the newline sequences used in the source above.
  67. const unixNewlineSource = source.replace(/\r\n/g, '\n')
  68. const windowsNewLineSource = unixNewlineSource.replace(/\n/g, '\r\n')
  69. test('newline sequences - windows', () => {
  70. const keyStart = windowsNewLineSource.indexOf(startToken)
  71. const keyEnd =
  72. windowsNewLineSource.indexOf(endToken, keyStart) + endToken.length
  73. expect(
  74. generateCodeFrame(windowsNewLineSource, keyStart, keyEnd),
  75. ).toMatchSnapshot()
  76. })
  77. test('newline sequences - unix', () => {
  78. const keyStart = unixNewlineSource.indexOf(startToken)
  79. const keyEnd =
  80. unixNewlineSource.indexOf(endToken, keyStart) + endToken.length
  81. expect(
  82. generateCodeFrame(unixNewlineSource, keyStart, keyEnd),
  83. ).toMatchSnapshot()
  84. })
  85. }
  86. })