parser.jest.ts 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. import { Parser } from '../parser';
  2. describe('when parsing', function() {
  3. it('simple metric expression', function() {
  4. var parser = new Parser('metric.test.*.asd.count');
  5. var rootNode = parser.getAst();
  6. expect(rootNode.type).toBe('metric');
  7. expect(rootNode.segments.length).toBe(5);
  8. expect(rootNode.segments[0].value).toBe('metric');
  9. });
  10. it('simple metric expression with numbers in segments', function() {
  11. var parser = new Parser('metric.10.15_20.5');
  12. var rootNode = parser.getAst();
  13. expect(rootNode.type).toBe('metric');
  14. expect(rootNode.segments.length).toBe(4);
  15. expect(rootNode.segments[1].value).toBe('10');
  16. expect(rootNode.segments[2].value).toBe('15_20');
  17. expect(rootNode.segments[3].value).toBe('5');
  18. });
  19. it('simple metric expression with curly braces', function() {
  20. var parser = new Parser('metric.se1-{count, max}');
  21. var rootNode = parser.getAst();
  22. expect(rootNode.type).toBe('metric');
  23. expect(rootNode.segments.length).toBe(2);
  24. expect(rootNode.segments[1].value).toBe('se1-{count,max}');
  25. });
  26. it('simple metric expression with curly braces at start of segment and with post chars', function() {
  27. var parser = new Parser('metric.{count, max}-something.count');
  28. var rootNode = parser.getAst();
  29. expect(rootNode.type).toBe('metric');
  30. expect(rootNode.segments.length).toBe(3);
  31. expect(rootNode.segments[1].value).toBe('{count,max}-something');
  32. });
  33. it('simple function', function() {
  34. var parser = new Parser('sum(test)');
  35. var rootNode = parser.getAst();
  36. expect(rootNode.type).toBe('function');
  37. expect(rootNode.params.length).toBe(1);
  38. });
  39. it('simple function2', function() {
  40. var parser = new Parser('offset(test.metric, -100)');
  41. var rootNode = parser.getAst();
  42. expect(rootNode.type).toBe('function');
  43. expect(rootNode.params[0].type).toBe('metric');
  44. expect(rootNode.params[1].type).toBe('number');
  45. });
  46. it('simple function with string arg', function() {
  47. var parser = new Parser("randomWalk('test')");
  48. var rootNode = parser.getAst();
  49. expect(rootNode.type).toBe('function');
  50. expect(rootNode.params.length).toBe(1);
  51. expect(rootNode.params[0].type).toBe('string');
  52. });
  53. it('function with multiple args', function() {
  54. var parser = new Parser("sum(test, 1, 'test')");
  55. var rootNode = parser.getAst();
  56. expect(rootNode.type).toBe('function');
  57. expect(rootNode.params.length).toBe(3);
  58. expect(rootNode.params[0].type).toBe('metric');
  59. expect(rootNode.params[1].type).toBe('number');
  60. expect(rootNode.params[2].type).toBe('string');
  61. });
  62. it('function with nested function', function() {
  63. var parser = new Parser('sum(scaleToSeconds(test, 1))');
  64. var rootNode = parser.getAst();
  65. expect(rootNode.type).toBe('function');
  66. expect(rootNode.params.length).toBe(1);
  67. expect(rootNode.params[0].type).toBe('function');
  68. expect(rootNode.params[0].name).toBe('scaleToSeconds');
  69. expect(rootNode.params[0].params.length).toBe(2);
  70. expect(rootNode.params[0].params[0].type).toBe('metric');
  71. expect(rootNode.params[0].params[1].type).toBe('number');
  72. });
  73. it('function with multiple series', function() {
  74. var parser = new Parser('sum(test.test.*.count, test.timers.*.count)');
  75. var rootNode = parser.getAst();
  76. expect(rootNode.type).toBe('function');
  77. expect(rootNode.params.length).toBe(2);
  78. expect(rootNode.params[0].type).toBe('metric');
  79. expect(rootNode.params[1].type).toBe('metric');
  80. });
  81. it('function with templated series', function() {
  82. var parser = new Parser('sum(test.[[server]].count)');
  83. var rootNode = parser.getAst();
  84. expect(rootNode.message).toBe(undefined);
  85. expect(rootNode.params[0].type).toBe('metric');
  86. expect(rootNode.params[0].segments[1].type).toBe('segment');
  87. expect(rootNode.params[0].segments[1].value).toBe('[[server]]');
  88. });
  89. it('invalid metric expression', function() {
  90. var parser = new Parser('metric.test.*.asd.');
  91. var rootNode = parser.getAst();
  92. expect(rootNode.message).toBe(
  93. 'Expected metric identifier instead found end of string'
  94. );
  95. expect(rootNode.pos).toBe(19);
  96. });
  97. it('invalid function expression missing closing parenthesis', function() {
  98. var parser = new Parser('sum(test');
  99. var rootNode = parser.getAst();
  100. expect(rootNode.message).toBe(
  101. 'Expected closing parenthesis instead found end of string'
  102. );
  103. expect(rootNode.pos).toBe(9);
  104. });
  105. it('unclosed string in function', function() {
  106. var parser = new Parser("sum('test)");
  107. var rootNode = parser.getAst();
  108. expect(rootNode.message).toBe('Unclosed string parameter');
  109. expect(rootNode.pos).toBe(11);
  110. });
  111. it('handle issue #69', function() {
  112. var parser = new Parser(
  113. 'cactiStyle(offset(scale(net.192-168-1-1.192-168-1-9.ping_value.*,0.001),-100))'
  114. );
  115. var rootNode = parser.getAst();
  116. expect(rootNode.type).toBe('function');
  117. });
  118. it('handle float function arguments', function() {
  119. var parser = new Parser('scale(test, 0.002)');
  120. var rootNode = parser.getAst();
  121. expect(rootNode.type).toBe('function');
  122. expect(rootNode.params[1].type).toBe('number');
  123. expect(rootNode.params[1].value).toBe(0.002);
  124. });
  125. it('handle curly brace pattern at start', function() {
  126. var parser = new Parser('{apps}.test');
  127. var rootNode = parser.getAst();
  128. expect(rootNode.type).toBe('metric');
  129. expect(rootNode.segments[0].value).toBe('{apps}');
  130. expect(rootNode.segments[1].value).toBe('test');
  131. });
  132. it('series parameters', function() {
  133. var parser = new Parser('asPercent(#A, #B)');
  134. var rootNode = parser.getAst();
  135. expect(rootNode.type).toBe('function');
  136. expect(rootNode.params[0].type).toBe('series-ref');
  137. expect(rootNode.params[0].value).toBe('#A');
  138. expect(rootNode.params[1].value).toBe('#B');
  139. });
  140. it('series parameters, issue 2788', function() {
  141. var parser = new Parser(
  142. "summarize(diffSeries(#A, #B), '10m', 'sum', false)"
  143. );
  144. var rootNode = parser.getAst();
  145. expect(rootNode.type).toBe('function');
  146. expect(rootNode.params[0].type).toBe('function');
  147. expect(rootNode.params[1].value).toBe('10m');
  148. expect(rootNode.params[3].type).toBe('bool');
  149. });
  150. it('should parse metric expression with ip number segments', function() {
  151. var parser = new Parser('5.10.123.5');
  152. var rootNode = parser.getAst();
  153. expect(rootNode.segments[0].value).toBe('5');
  154. expect(rootNode.segments[1].value).toBe('10');
  155. expect(rootNode.segments[2].value).toBe('123');
  156. expect(rootNode.segments[3].value).toBe('5');
  157. });
  158. });