SQLishFormatter.spec.tsx 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. import React from 'react';
  2. import {render} from 'sentry-test/reactTestingLibrary';
  3. import {SQLishFormatter} from 'sentry/views/starfish/utils/sqlish/SQLishFormatter';
  4. describe('SQLishFormatter', function () {
  5. describe('SQLishFormatter.toString()', () => {
  6. const formatter = new SQLishFormatter();
  7. it('Falls back to original string if unable to parse', () => {
  8. expect(formatter.toString('😤')).toEqual('😤');
  9. });
  10. it('Adds newlines for keywords in SELECTs', () => {
  11. expect(
  12. formatter.toString('SELECT hello FROM users ORDER BY name DESC LIMIT 1;')
  13. ).toEqual('SELECT hello \nFROM users \nORDER BY name DESC \nLIMIT 1;');
  14. });
  15. it('Adds newlines for keywords in INSERTs', () => {
  16. expect(
  17. formatter.toString('INSERT INTO users (id, name) VALUES (:c0, :c1) RETURNING *')
  18. ).toEqual('INSERT INTO users (id, name) \nVALUES (:c0, :c1) \nRETURNING *');
  19. });
  20. });
  21. describe('SQLishFormatter.toSimpleMarkup()', () => {
  22. const formatter = new SQLishFormatter();
  23. const getMarkup = (markup: any): string => {
  24. const {container} = render(<React.Fragment>{markup}</React.Fragment>);
  25. return container.innerHTML;
  26. };
  27. beforeEach(() => {
  28. // The renderer throws an error because elements in the list do not have
  29. // a `"key"` prop, but that's intentional. The list elements are spans
  30. // with no semantic meaning, and their keys are not meaningful.
  31. jest.spyOn(console, 'error').mockImplementation(jest.fn());
  32. });
  33. it('Capitalizes keywords', () => {
  34. expect(getMarkup(formatter.toSimpleMarkup('select hello'))).toEqual(
  35. '<b>SELECT</b><span> </span><span>hello</span>'
  36. );
  37. });
  38. it('Wraps every token in a `<span>` element', () => {
  39. expect(getMarkup(formatter.toSimpleMarkup('SELECT hello;'))).toEqual(
  40. '<b>SELECT</b><span> </span><span>hello;</span>'
  41. );
  42. });
  43. });
  44. });