Files
MyGoNavi/frontend/src/utils/columnDefinition.test.ts
Syngnat c9d0bce153 🐛 fix(workbench): 修复结果区切换与对象设计字段定义
- 修复手动隐藏结果区后快捷键无法再次显示的问题

- 补全 Dameng/Oracle-like 字段长度、精度和可空标识

- 增加 SQL 编辑器、字段元数据和对象设计回归测试
2026-06-10 15:51:03 +08:00

85 lines
2.6 KiB
TypeScript

import { describe, expect, it } from 'vitest';
import {
getColumnDefinitionComment,
getColumnDefinitionKey,
getColumnDefinitionName,
getColumnDefinitionType,
normalizeColumnDefinition,
} from './columnDefinition';
describe('columnDefinition metadata normalization', () => {
it('reads Go/Wails style column metadata fields', () => {
const column = { Name: 'UPDATED_AT', Type: 'TIMESTAMP', Key: 'PRI', Comment: '更新时间' };
expect(getColumnDefinitionName(column)).toBe('UPDATED_AT');
expect(getColumnDefinitionType(column)).toBe('TIMESTAMP');
expect(getColumnDefinitionKey(column)).toBe('PRI');
expect(getColumnDefinitionComment(column)).toBe('更新时间');
});
it('reads Oracle dictionary style column metadata aliases', () => {
const column = { COLUMN_NAME: 'UPDATED_AT', DATA_TYPE: 'TIMESTAMP', COLUMN_KEY: 'PRI', COMMENTS: '更新时间' };
expect(normalizeColumnDefinition(column)).toMatchObject({
name: 'UPDATED_AT',
type: 'TIMESTAMP',
key: 'PRI',
comment: '更新时间',
});
});
it('prefers complete column type aliases over base data type', () => {
const column = {
COLUMN_NAME: 'USER_NAME',
DATA_TYPE: 'varchar',
COLUMN_TYPE: 'varchar(64)',
IS_NULLABLE: 'NO',
};
expect(normalizeColumnDefinition(column)).toMatchObject({
name: 'USER_NAME',
type: 'varchar(64)',
nullable: 'NO',
});
});
it('builds display type from base type and length metadata', () => {
const column = {
column_name: 'amount',
data_type: 'decimal',
numeric_precision: 10,
numeric_scale: 2,
is_nullable: 'YES',
};
expect(normalizeColumnDefinition(column)).toMatchObject({
name: 'amount',
type: 'decimal(10,2)',
nullable: 'YES',
});
});
it('normalizes Dameng style data length and nullable flags', () => {
const column = {
COLUMN_NAME: 'USER_NAME',
DATA_TYPE: 'VARCHAR2',
DATA_LENGTH: 64,
NULLABLE: 'N',
};
expect(normalizeColumnDefinition(column)).toMatchObject({
name: 'USER_NAME',
type: 'VARCHAR2(64)',
nullable: 'NO',
});
});
it('maps boolean primary and unique metadata aliases to GoNavi keys', () => {
expect(getColumnDefinitionKey({ column_name: 'id', isPrimary: true })).toBe('PRI');
expect(getColumnDefinitionKey({ column_name: 'id', primary_key: 't' })).toBe('PRI');
expect(getColumnDefinitionKey({ column_name: 'email', is_unique: 'yes' })).toBe('UNI');
expect(getColumnDefinitionKey({ column_name: 'id', column_key: 'primary key' })).toBe('PRI');
});
});