mirror of
https://github.com/supabase/supabase.git
synced 2026-05-09 02:09:50 -04:00
58 lines
1.6 KiB
TypeScript
58 lines
1.6 KiB
TypeScript
import { describe, expect, it } from 'vitest'
|
|
|
|
import { quoteLiteral } from './pg-format'
|
|
|
|
describe('quoteLiteral', () => {
|
|
it('returns NULL for null and undefined', () => {
|
|
expect(quoteLiteral(null)).toBe('NULL')
|
|
expect(quoteLiteral(undefined)).toBe('NULL')
|
|
})
|
|
|
|
it('returns correct literals for booleans', () => {
|
|
expect(quoteLiteral(true)).toBe("'t'")
|
|
expect(quoteLiteral(false)).toBe("'f'")
|
|
})
|
|
|
|
it('returns quoted string for numbers', () => {
|
|
expect(quoteLiteral(123)).toBe("'123'")
|
|
expect(quoteLiteral(-45.67)).toBe("'-45.67'")
|
|
})
|
|
|
|
it('escapes single quotes and backslashes in strings', () => {
|
|
expect(quoteLiteral("O'Reilly")).toBe("'O''Reilly'")
|
|
expect(quoteLiteral('back\\slash')).toBe("E'back\\\\slash'")
|
|
expect(quoteLiteral("quote'and\\backslash")).toBe("E'quote''and\\\\backslash'")
|
|
})
|
|
|
|
it('formats Date objects as UTC strings', () => {
|
|
const date = new Date('2023-01-01T12:34:56Z')
|
|
expect(quoteLiteral(date)).toBe("'2023-01-01 12:34:56.000+00'")
|
|
})
|
|
|
|
it('handles Buffer objects', () => {
|
|
expect(quoteLiteral(Buffer.from('abc'))).toBe("E'\\\\x616263'")
|
|
})
|
|
|
|
it('formats arrays of primitives', () => {
|
|
expect(quoteLiteral([1, 2, 3])).toBe("'1','2','3'")
|
|
expect(quoteLiteral(['a', "b'c", 'd'])).toBe("'a','b''c','d'")
|
|
})
|
|
|
|
it('formats nested arrays', () => {
|
|
expect(
|
|
quoteLiteral([
|
|
[1, 2],
|
|
[3, 4],
|
|
])
|
|
).toBe("('1', '2'), ('3', '4')")
|
|
})
|
|
|
|
it('formats objects as jsonb', () => {
|
|
expect(quoteLiteral({ foo: 'bar', n: 1 })).toBe('\'{"foo":"bar","n":1}\'::jsonb')
|
|
})
|
|
|
|
it('handles empty string', () => {
|
|
expect(quoteLiteral('')).toBe("''")
|
|
})
|
|
})
|