PromQueryField.jest.tsx 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. import React from 'react';
  2. import Enzyme, { shallow } from 'enzyme';
  3. import Adapter from 'enzyme-adapter-react-16';
  4. Enzyme.configure({ adapter: new Adapter() });
  5. import PromQueryField from './PromQueryField';
  6. describe('PromQueryField typeahead handling', () => {
  7. const defaultProps = {
  8. request: () => ({ data: { data: [] } }),
  9. };
  10. it('returns default suggestions on emtpty context', () => {
  11. const instance = shallow(<PromQueryField {...defaultProps} />).instance() as PromQueryField;
  12. const result = instance.getTypeahead({ text: '', prefix: '', wrapperClasses: [] });
  13. expect(result.context).toBeUndefined();
  14. expect(result.refresher).toBeUndefined();
  15. expect(result.suggestions.length).toEqual(2);
  16. });
  17. describe('range suggestions', () => {
  18. it('returns range suggestions in range context', () => {
  19. const instance = shallow(<PromQueryField {...defaultProps} />).instance() as PromQueryField;
  20. const result = instance.getTypeahead({ text: '1', prefix: '1', wrapperClasses: ['context-range'] });
  21. expect(result.context).toBe('context-range');
  22. expect(result.refresher).toBeUndefined();
  23. expect(result.suggestions).toEqual([
  24. {
  25. items: [{ label: '1m' }, { label: '5m' }, { label: '10m' }, { label: '30m' }, { label: '1h' }],
  26. label: 'Range vector',
  27. },
  28. ]);
  29. });
  30. });
  31. describe('metric suggestions', () => {
  32. it('returns metrics suggestions by default', () => {
  33. const instance = shallow(
  34. <PromQueryField {...defaultProps} metrics={['foo', 'bar']} />
  35. ).instance() as PromQueryField;
  36. const result = instance.getTypeahead({ text: 'a', prefix: 'a', wrapperClasses: [] });
  37. expect(result.context).toBeUndefined();
  38. expect(result.refresher).toBeUndefined();
  39. expect(result.suggestions.length).toEqual(2);
  40. });
  41. it('returns default suggestions after a binary operator', () => {
  42. const instance = shallow(
  43. <PromQueryField {...defaultProps} metrics={['foo', 'bar']} />
  44. ).instance() as PromQueryField;
  45. const result = instance.getTypeahead({ text: '*', prefix: '', wrapperClasses: [] });
  46. expect(result.context).toBeUndefined();
  47. expect(result.refresher).toBeUndefined();
  48. expect(result.suggestions.length).toEqual(2);
  49. });
  50. });
  51. describe('label suggestions', () => {
  52. it('returns default label suggestions on label context and no metric', () => {
  53. const instance = shallow(<PromQueryField {...defaultProps} />).instance() as PromQueryField;
  54. const result = instance.getTypeahead({ text: 'j', prefix: 'j', wrapperClasses: ['context-labels'] });
  55. expect(result.context).toBe('context-labels');
  56. expect(result.suggestions).toEqual([{ items: [{ label: 'job' }, { label: 'instance' }], label: 'Labels' }]);
  57. });
  58. it('returns label suggestions on label context and metric', () => {
  59. const instance = shallow(
  60. <PromQueryField {...defaultProps} labelKeys={{ foo: ['bar'] }} />
  61. ).instance() as PromQueryField;
  62. const result = instance.getTypeahead({
  63. text: 'job',
  64. prefix: 'job',
  65. wrapperClasses: ['context-labels'],
  66. metric: 'foo',
  67. });
  68. expect(result.context).toBe('context-labels');
  69. expect(result.suggestions).toEqual([{ items: [{ label: 'bar' }], label: 'Labels' }]);
  70. });
  71. it('returns a refresher on label context and unavailable metric', () => {
  72. const instance = shallow(
  73. <PromQueryField {...defaultProps} labelKeys={{ foo: ['bar'] }} />
  74. ).instance() as PromQueryField;
  75. const result = instance.getTypeahead({
  76. text: 'job',
  77. prefix: 'job',
  78. wrapperClasses: ['context-labels'],
  79. metric: 'xxx',
  80. });
  81. expect(result.context).toBeUndefined();
  82. expect(result.refresher).toBeInstanceOf(Promise);
  83. expect(result.suggestions).toEqual([]);
  84. });
  85. it('returns label values on label context when given a metric and a label key', () => {
  86. const instance = shallow(
  87. <PromQueryField {...defaultProps} labelKeys={{ foo: ['bar'] }} labelValues={{ foo: { bar: ['baz'] } }} />
  88. ).instance() as PromQueryField;
  89. const result = instance.getTypeahead({
  90. text: '=ba',
  91. prefix: 'ba',
  92. wrapperClasses: ['context-labels'],
  93. metric: 'foo',
  94. labelKey: 'bar',
  95. });
  96. expect(result.context).toBe('context-label-values');
  97. expect(result.suggestions).toEqual([{ items: [{ label: 'baz' }], label: 'Label values' }]);
  98. });
  99. it('returns label suggestions on aggregation context and metric', () => {
  100. const instance = shallow(
  101. <PromQueryField {...defaultProps} labelKeys={{ foo: ['bar'] }} />
  102. ).instance() as PromQueryField;
  103. const result = instance.getTypeahead({
  104. text: 'job',
  105. prefix: 'job',
  106. wrapperClasses: ['context-aggregation'],
  107. metric: 'foo',
  108. });
  109. expect(result.context).toBe('context-aggregation');
  110. expect(result.suggestions).toEqual([{ items: [{ label: 'bar' }], label: 'Labels' }]);
  111. });
  112. });
  113. });