lava-oushudb-dt-sql-parser/test/parser/hive/visitor.test.ts

36 lines
1.2 KiB
TypeScript
Raw Normal View History

import { HiveSQL } from 'src/parser/hive';
import { HiveSqlParserVisitor } from 'src/lib/hive/HiveSqlParserVisitor';
import { ProgramContext, TableNameContext } from 'src/lib/hive/HiveSqlParser';
describe('HiveSQL Visitor Tests', () => {
2020-11-25 17:04:55 +08:00
const expectTableName = 'dm_gis.dlv_addr_tc_count';
const sql = `select citycode,tc,inc_day from ${expectTableName} where inc_day='20190501' limit 100;`;
const hive = new HiveSQL();
const parseTree = hive.parse(sql, (error) => {
console.error('Parse error:', error);
});
test('Visitor visitTableName', () => {
class MyVisitor extends HiveSqlParserVisitor<string> {
defaultResult(): string {
return '';
}
aggregateResult(aggregate: string, nextResult: string): string {
return aggregate + nextResult;
}
visitProgram = (ctx: ProgramContext) => {
return this.visitChildren(ctx);
};
visitTableName = (ctx: TableNameContext) => {
return ctx.getText().toLowerCase();
};
}
2020-11-25 17:04:55 +08:00
2023-05-04 10:13:05 +08:00
const visitor = new MyVisitor();
const result = visitor.visit(parseTree);
expect(result).toBe(expectTableName);
});
});