2021-06-10 12:54:57 -07:00
|
|
|
@TestOn('vm')
|
2020-06-26 13:54:42 -07:00
|
|
|
import 'dart:convert';
|
|
|
|
import 'dart:ffi';
|
|
|
|
|
|
|
|
import 'package:ffi/ffi.dart';
|
2021-09-10 02:43:21 -07:00
|
|
|
import 'package:sqlite3/open.dart';
|
2020-06-26 13:54:42 -07:00
|
|
|
import 'package:sqlparser/src/reader/tokenizer/token.dart';
|
2021-09-10 02:43:21 -07:00
|
|
|
import 'package:test/test.dart';
|
2020-06-26 13:54:42 -07:00
|
|
|
|
2021-05-18 13:19:57 -07:00
|
|
|
typedef SqliteKeywordCountNative = Int32 Function();
|
|
|
|
typedef SqliteKeywordCount = int Function();
|
2020-06-26 13:54:42 -07:00
|
|
|
|
2021-05-18 13:19:57 -07:00
|
|
|
typedef SqliteKeywordNameNative = Int32 Function(
|
2020-06-26 13:54:42 -07:00
|
|
|
Int32, Pointer<Pointer<Uint8>>, Pointer<Int32>);
|
2021-05-18 13:19:57 -07:00
|
|
|
typedef SqliteKeywordName = int Function(
|
2020-06-26 13:54:42 -07:00
|
|
|
int, Pointer<Pointer<Uint8>>, Pointer<Int32>);
|
|
|
|
|
|
|
|
void main() {
|
2020-12-11 01:53:17 -08:00
|
|
|
String? skip;
|
|
|
|
late DynamicLibrary library;
|
2020-06-26 13:54:42 -07:00
|
|
|
|
|
|
|
try {
|
|
|
|
library = open.openSqlite();
|
2020-11-20 09:25:53 -08:00
|
|
|
|
|
|
|
// Some platforms have sqlite3, but no sqlite3_keyword_count
|
|
|
|
library.lookup('sqlite3_keyword_count');
|
2020-12-11 01:53:17 -08:00
|
|
|
} on Object {
|
2020-06-26 13:54:42 -07:00
|
|
|
skip = 'sqlite3 is not available in test environment';
|
|
|
|
}
|
|
|
|
|
|
|
|
test(
|
2022-02-23 13:06:42 -08:00
|
|
|
'recognizes all sqlite keywords',
|
2020-06-26 13:54:42 -07:00
|
|
|
() {
|
2021-05-18 13:19:57 -07:00
|
|
|
final keywordCount =
|
|
|
|
library.lookupFunction<SqliteKeywordCountNative, SqliteKeywordCount>(
|
|
|
|
'sqlite3_keyword_count')();
|
|
|
|
final nameFunction =
|
|
|
|
library.lookupFunction<SqliteKeywordNameNative, SqliteKeywordName>(
|
|
|
|
'sqlite3_keyword_name');
|
2020-06-26 13:54:42 -07:00
|
|
|
|
2021-02-14 05:06:51 -08:00
|
|
|
final charOut = malloc<Pointer<Uint8>>();
|
|
|
|
final lengthOut = malloc<Int32>();
|
2020-06-26 13:54:42 -07:00
|
|
|
|
|
|
|
final missingNames = <String>[];
|
|
|
|
|
|
|
|
for (var i = 0; i < keywordCount; i++) {
|
|
|
|
nameFunction(i, charOut, lengthOut);
|
|
|
|
|
|
|
|
final bytes = charOut.value.asTypedList(lengthOut.value);
|
|
|
|
final name = utf8.decode(bytes);
|
|
|
|
|
|
|
|
if (!keywords.containsKey(name)) {
|
|
|
|
missingNames.add(name);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
missingNames.sort();
|
|
|
|
|
2021-02-14 05:06:51 -08:00
|
|
|
malloc.free(charOut);
|
|
|
|
malloc.free(lengthOut);
|
2020-06-26 13:54:42 -07:00
|
|
|
|
|
|
|
expect(missingNames, isEmpty);
|
|
|
|
},
|
|
|
|
skip: skip,
|
|
|
|
);
|
|
|
|
}
|