import FlinkSQL from '../../../../src/parser/flinksql'; import { readSQL } from '../../../helper'; const parser = new FlinkSQL(); const features = { base: readSQL(__dirname, 'select.sql'), withClause: readSQL(__dirname, 'selectWithClause.sql'), distinct: readSQL(__dirname, 'selectDistinct.sql'), windowTVF: readSQL(__dirname, 'selectWindowTVF.sql'), aggregation: readSQL(__dirname, 'selectAggregation.sql'), join: readSQL(__dirname, 'selectJoin.sql'), setOperation: readSQL(__dirname, 'selectSetOperations.sql'), pattern: readSQL(__dirname, 'selectPatternRecognition.sql'), where: readSQL(__dirname, 'selectWhere.sql'), }; describe('FlinkSQL Query Statement Tests', () => { describe('Base Select', () => { features.base.forEach((sql) => { it(sql, () => { expect(parser.validate(sql).length).toBe(0); }); }); }); describe('With Clause Select', () => { features.withClause.forEach((sql) => { it(sql, () => { expect(parser.validate(sql).length).toBe(0); }); }); }); describe('Select DISTINCT', () => { features.distinct.forEach((sql) => { it(sql, () => { expect(parser.validate(sql).length).toBe(0); }); }); }); describe('Select Window TVF', () => { features.windowTVF.forEach((sql) => { it(sql, () => { expect(parser.validate(sql).length).toBe(0); }); }); }); describe('Select Aggregation', () => { features.aggregation.forEach((sql) => { it(sql, () => { expect(parser.validate(sql).length).toBe(0); }); }); }); describe('Select Join', () => { features.join.forEach((sql) => { it(sql, () => { expect(parser.validate(sql).length).toBe(0); }); }); }); describe('Select Set Operations', () => { features.setOperation.forEach((sql) => { it(sql, () => { expect(parser.validate(sql).length).toBe(0); }); }); }); describe('Select Pattern Recognition', () => { features.pattern.forEach((sql) => { it(sql, () => { expect(parser.validate(sql).length).toBe(0); }); }); }); describe('Select Where', () => { features.where.forEach((sql) => { it(sql, () => { expect(parser.validate(sql).length).toBe(0); }); }); }); });