mirror of
https://github.com/supabase/supabase.git
synced 2026-07-02 13:34:27 +08:00
* Add all missing libraries in the packages/apps. * Add all missing Vitest imports to the tests. * Add some missing exports to ui. * Fix the admonition export. * Fix various minor bugs. * Migrate the ui package to use vitest.
68 lines
2.9 KiB
TypeScript
68 lines
2.9 KiB
TypeScript
import { inferColumnType } from 'components/interfaces/TableGridEditor/SidePanelEditor/SpreadsheetImport/SpreadsheetImport.utils'
|
|
import { describe, test, expect } from 'vitest'
|
|
|
|
describe('SpreadsheedImport.utils: inferColumnType', () => {
|
|
test('should default column type to text if no rows to infer from', () => {
|
|
const mockData: any[] = []
|
|
const type = inferColumnType('id', mockData)
|
|
expect(type).toBe('text')
|
|
})
|
|
test('should default column type to text if the first row has no data to infer from', () => {
|
|
const mockData = [{ name: 'bob', age: '42' }]
|
|
const type = inferColumnType('id', mockData)
|
|
expect(type).toBe('text')
|
|
})
|
|
test('should default column type to text if the first row data value is null', () => {
|
|
const mockData = [{ id: 'null', name: 'bob', age: '42' }]
|
|
const type = inferColumnType('id', mockData)
|
|
expect(type).toBe('text')
|
|
})
|
|
test('should infer integer types correctly', () => {
|
|
const mockData = [{ name: 'bob', age: '42' }]
|
|
const type = inferColumnType('age', mockData)
|
|
expect(type).toBe('int8')
|
|
})
|
|
test('should infer float types correctly', () => {
|
|
const mockData = [{ name: 'bob', height: '161.72' }]
|
|
const type = inferColumnType('height', mockData)
|
|
expect(type).toBe('float8')
|
|
})
|
|
test('should infer boolean types correctly', () => {
|
|
const mockData1 = [{ name: 'bob', height: '161.72', isWorking: 'true' }]
|
|
const type1 = inferColumnType('isWorking', mockData1)
|
|
expect(type1).toBe('bool')
|
|
|
|
const mockData2 = [{ name: 'bob', height: '161.72', isRetired: 'false' }]
|
|
const type2 = inferColumnType('isRetired', mockData2)
|
|
expect(type2).toBe('bool')
|
|
})
|
|
test('should infer boolean type for a supposed boolean column if one of the rows has a null value', () => {
|
|
const mockData3 = [
|
|
{ name: 'bob', height: '161.72', isRetired: 'false' },
|
|
{ name: 'bob', height: '161.72', isRetired: 'true' },
|
|
{ name: 'bob', height: '161.72', isRetired: null },
|
|
]
|
|
const type3 = inferColumnType('isRetired', mockData3)
|
|
expect(type3).toBe('bool')
|
|
})
|
|
test('should infer objects as jsonb types correctly', () => {
|
|
const mockData = [{ name: 'bob', metadata: '{}' }]
|
|
const type = inferColumnType('metadata', mockData)
|
|
expect(type).toBe('jsonb')
|
|
})
|
|
test('should infer date type correctly', () => {
|
|
const mockData4 = [
|
|
{ event: 'christmas', date: '2022-12-25 17:45:23 UTC' },
|
|
{ event: 'christmas', date: '2022-12-25' },
|
|
{ event: 'christmas', date: '2022-12-25T12:03:40Z' },
|
|
{ event: 'christmas', date: new Date() },
|
|
{ event: 'christmas', date: new Date().toISOString() },
|
|
{ event: 'christmas', date: 1410715640579 },
|
|
{ event: 'christmas', date: '25 Dec 2022' },
|
|
{ event: 'christmas', date: 'Dec 25 2022' },
|
|
]
|
|
const type4 = inferColumnType('date', mockData4)
|
|
expect(type4).toBe('timestamptz')
|
|
})
|
|
})
|