drift/sqlparser/test/analysis/errors/syntax_error_test.dart

72 lines
2.3 KiB
Dart

// tests for syntax errors revealed during static analysis.
import 'package:sqlparser/sqlparser.dart';
import 'package:sqlparser/src/analysis/analysis.dart';
import 'package:sqlparser/src/engine/sql_engine.dart';
import 'package:test/test.dart';
import '../data.dart';
void main() {
group('DO UPDATE clause without conflict target', () {
test('is forbidden on older sqlite versions', () {
final engine = SqlEngine()..registerTable(demoTable);
final result = engine.analyze('INSERT INTO demo VALUES (?, ?) '
'ON CONFLICT DO UPDATE SET id = 3;');
expect(result.errors, [
const TypeMatcher<AnalysisError>()
.having((e) => e.type, 'type', AnalysisErrorType.synctactic)
.having((e) => e.message, 'message',
contains('Expected a conflict clause'))
]);
});
test('is allowed on the last clause', () {
final engine = SqlEngine(EngineOptions(version: SqliteVersion.v3_35))
..registerTable(demoTable);
expect(
engine
.analyze('INSERT INTO demo VALUES (?, ?) '
'ON CONFLICT DO UPDATE SET id = 3;')
.errors,
isEmpty,
);
});
test('is not allowed on previous clauses', () {
final engine = SqlEngine(EngineOptions(version: SqliteVersion.v3_35))
..registerTable(demoTable);
expect(
engine
.analyze('INSERT INTO demo VALUES (?, ?) '
'ON CONFLICT DO UPDATE SET id = 3'
'ON CONFLICT DO NOTHING;')
.errors,
hasLength(1),
);
});
});
test('complex expressions in PRIMARY KEY clause', () {
final engine = SqlEngine();
final parseResult = engine.parse('''
CREATE TABLE tbl (
foo INTEGER NOT NULL,
bar TEXT NOT NULL,
PRIMARY KEY (foo DESC, bar || 'test')
);
''');
engine.registerTable(const SchemaFromCreateTable()
.read(parseResult.rootNode as CreateTableStatement));
final analyzeResult = engine.analyzeParsed(parseResult);
expect(analyzeResult.errors, [
const TypeMatcher<AnalysisError>()
.having((e) => e.type, 'type', AnalysisErrorType.synctactic)
.having((e) => e.message, 'message',
contains('Only column names can be used in a PRIMARY KEY clause'))
]);
});
}