parser_specs.ts 6.6 KB

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