mirror of
https://github.com/Syngnat/GoNavi.git
synced 2026-06-15 19:19:35 +08:00
- 统一 Sidebar 与 SQL 编辑器的元数据方言解析 - 兼容 GDB/GoldenDB/GreatDB 等 MySQL 兼容驱动的视图元数据 - 放宽左侧树视图定位对 objectType 节点的识别
80 lines
4.8 KiB
TypeScript
80 lines
4.8 KiB
TypeScript
import { describe, expect, it } from 'vitest';
|
|
|
|
import {
|
|
isMysqlFamilyDialect,
|
|
resolveColumnTypeOptions,
|
|
resolveSqlDialect,
|
|
resolveSqlFunctions,
|
|
resolveSqlKeywords,
|
|
} from './sqlDialect';
|
|
|
|
const values = (options: Array<{ value: string }>) => options.map((item) => item.value);
|
|
const names = (items: Array<{ name: string }>) => items.map((item) => item.name);
|
|
|
|
describe('sqlDialect', () => {
|
|
it('normalizes datasource aliases without collapsing all dialects to mysql', () => {
|
|
expect(resolveSqlDialect('postgresql')).toBe('postgres');
|
|
expect(resolveSqlDialect('OpenGauss')).toBe('opengauss');
|
|
expect(resolveSqlDialect('OceanBase')).toBe('oceanbase');
|
|
expect(resolveSqlDialect('doris')).toBe('diros');
|
|
expect(resolveSqlDialect('StarRocks')).toBe('starrocks');
|
|
expect(resolveSqlDialect('dameng')).toBe('dameng');
|
|
expect(resolveSqlDialect('InterSystems IRIS')).toBe('iris');
|
|
expect(resolveSqlDialect('custom', 'intersystemsiris')).toBe('iris');
|
|
expect(resolveSqlDialect('custom', 'kingbase8')).toBe('kingbase');
|
|
expect(resolveSqlDialect('custom', 'dm8')).toBe('dameng');
|
|
expect(resolveSqlDialect('custom', 'mariadb')).toBe('mariadb');
|
|
expect(resolveSqlDialect('custom', 'gdb')).toBe('mysql');
|
|
expect(resolveSqlDialect('custom', 'goldendb')).toBe('mysql');
|
|
expect(resolveSqlDialect('custom', 'greatdb')).toBe('mysql');
|
|
expect(resolveSqlDialect('custom', 'open_gauss')).toBe('opengauss');
|
|
expect(resolveSqlDialect('Elasticsearch')).toBe('elasticsearch');
|
|
expect(resolveSqlDialect('custom', 'elastic')).toBe('elasticsearch');
|
|
expect(resolveSqlDialect('OceanBase', '', { oceanBaseProtocol: 'oracle' })).toBe('oracle');
|
|
expect(resolveSqlDialect('custom', 'oceanbase', { oceanBaseProtocol: 'oracle' })).toBe('oracle');
|
|
expect(isMysqlFamilyDialect('mariadb')).toBe(true);
|
|
expect(isMysqlFamilyDialect('oceanbase')).toBe(true);
|
|
expect(isMysqlFamilyDialect('starrocks')).toBe(true);
|
|
expect(isMysqlFamilyDialect('oracle')).toBe(false);
|
|
});
|
|
|
|
it('resolves field type options per datasource family', () => {
|
|
expect(values(resolveColumnTypeOptions('oracle'))).toContain('VARCHAR2(255)');
|
|
expect(values(resolveColumnTypeOptions('oracle'))).not.toContain('tinyint(1)');
|
|
expect(values(resolveColumnTypeOptions('dameng'))).toContain('VARCHAR2(255)');
|
|
expect(values(resolveColumnTypeOptions('kingbase'))).toContain('integer');
|
|
expect(values(resolveColumnTypeOptions('opengauss'))).toContain('integer');
|
|
expect(values(resolveColumnTypeOptions('oceanbase'))).toContain('varchar(255)');
|
|
expect(values(resolveColumnTypeOptions('kingbase'))).not.toContain('tinyint(1)');
|
|
expect(values(resolveColumnTypeOptions('diros'))).toContain('LARGEINT');
|
|
expect(values(resolveColumnTypeOptions('starrocks'))).toContain('PERCENTILE');
|
|
expect(values(resolveColumnTypeOptions('sphinx'))).toContain('text');
|
|
expect(values(resolveColumnTypeOptions('clickhouse'))).toContain('DateTime64(3)');
|
|
expect(values(resolveColumnTypeOptions('iris'))).toContain('varchar(255)');
|
|
expect(values(resolveColumnTypeOptions('tdengine'))).toContain('TIMESTAMP');
|
|
expect(values(resolveColumnTypeOptions('duckdb'))).toContain('STRUCT');
|
|
});
|
|
|
|
it('resolves oracle completion keywords and functions without mysql-only suggestions', () => {
|
|
expect(resolveSqlKeywords('oracle')).toEqual(expect.arrayContaining(['ROWNUM', 'FETCH', 'VARCHAR2', 'NUMBER']));
|
|
expect(resolveSqlKeywords('oracle')).not.toEqual(expect.arrayContaining(['AUTO_INCREMENT', 'CHANGE', 'LIMIT']));
|
|
|
|
expect(names(resolveSqlFunctions('oracle'))).toEqual(expect.arrayContaining(['NVL', 'SYSDATE', 'TO_DATE']));
|
|
expect(names(resolveSqlFunctions('oracle'))).not.toEqual(expect.arrayContaining(['DATE_FORMAT', 'GROUP_CONCAT']));
|
|
});
|
|
|
|
it('resolves mysql-family completion keywords and functions with mysql syntax', () => {
|
|
expect(resolveSqlKeywords('mariadb')).toEqual(expect.arrayContaining(['LIMIT', 'CHANGE', 'AUTO_INCREMENT']));
|
|
expect(names(resolveSqlFunctions('diros'))).toEqual(expect.arrayContaining(['DATE_FORMAT', 'GROUP_CONCAT']));
|
|
expect(resolveSqlKeywords('starrocks')).toEqual(expect.arrayContaining(['OLAP', 'DISTRIBUTED BY', 'BUCKETS', 'ADD ROLLUP', 'EXTERNAL CATALOG']));
|
|
expect(names(resolveSqlFunctions('starrocks'))).toEqual(expect.arrayContaining(['TO_BITMAP', 'HLL_UNION_AGG']));
|
|
});
|
|
|
|
it('resolves sqlserver completion without mysql-only ddl tokens', () => {
|
|
expect(resolveSqlKeywords('sqlserver')).toEqual(expect.arrayContaining(['TOP', 'IDENTITY', 'NVARCHAR']));
|
|
expect(resolveSqlKeywords('sqlserver')).not.toEqual(expect.arrayContaining(['AUTO_INCREMENT', 'CHANGE']));
|
|
expect(names(resolveSqlFunctions('sqlserver'))).toEqual(expect.arrayContaining(['GETDATE', 'ISNULL', 'NEWID']));
|
|
expect(names(resolveSqlFunctions('sqlserver'))).not.toEqual(expect.arrayContaining(['GROUP_CONCAT']));
|
|
});
|
|
});
|