bin: add test tool
This commit is contained in:
@@ -15,7 +15,7 @@ ArgParser argParser() {
|
||||
help:
|
||||
'Path to the SQLite library. This is used to load the SQLite library dynamically.',
|
||||
valueHelp: 'PATH',
|
||||
mandatory: true,
|
||||
defaultsTo: Platform.environment['LIBSQLITE_PATH'],
|
||||
);
|
||||
return parser;
|
||||
}
|
||||
@@ -24,7 +24,7 @@ Future<void> main(List<String> arguments) async {
|
||||
final parser = argParser();
|
||||
final ArgResults args = parser.parse(arguments);
|
||||
|
||||
if (!args.wasParsed('libsqlite')) {
|
||||
if (args.option('libsqlite') == null) {
|
||||
print(parser.usage);
|
||||
exit(64);
|
||||
}
|
||||
|
||||
50
bin/test_tool.dart
Normal file
50
bin/test_tool.dart
Normal file
@@ -0,0 +1,50 @@
|
||||
import 'dart:ffi';
|
||||
import 'dart:io';
|
||||
|
||||
import 'package:args/args.dart';
|
||||
import 'package:jadb/search.dart';
|
||||
import 'package:sqflite_common_ffi/sqflite_ffi.dart';
|
||||
import 'package:sqlite3/open.dart';
|
||||
|
||||
ArgParser argParser() {
|
||||
final parser = ArgParser();
|
||||
|
||||
parser.addOption(
|
||||
'libsqlite',
|
||||
help:
|
||||
'Path to the SQLite library. This is used to load the SQLite library dynamically.',
|
||||
valueHelp: 'PATH',
|
||||
defaultsTo: Platform.environment['LIBSQLITE_PATH'],
|
||||
);
|
||||
|
||||
parser.addOption(
|
||||
'jadb',
|
||||
help: 'Path to the SQLite database file.',
|
||||
valueHelp: 'PATH',
|
||||
mandatory: true,
|
||||
);
|
||||
|
||||
return parser;
|
||||
}
|
||||
|
||||
Future<void> main(List<String> arguments) async {
|
||||
final parser = argParser();
|
||||
final ArgResults args = parser.parse(arguments);
|
||||
|
||||
if (args.option('libsqlite') == null || !args.wasParsed('jadb')) {
|
||||
print(parser.usage);
|
||||
exit(64);
|
||||
}
|
||||
|
||||
final db = await createDatabaseFactoryFfi(ffiInit: () {
|
||||
open.overrideForAll(() => DynamicLibrary.open(args.option('libsqlite')!));
|
||||
}).openDatabase(Directory.current.uri.resolve(args.option('jadb')!).path);
|
||||
|
||||
final result = await JaDBConnection(db).searchKanji('漢');
|
||||
|
||||
if (result == null) {
|
||||
print("No such kanji");
|
||||
} else {
|
||||
print(result.toJson().toString());
|
||||
}
|
||||
}
|
||||
@@ -65,6 +65,9 @@
|
||||
sqlint
|
||||
sqlfluff
|
||||
];
|
||||
env = {
|
||||
LIBSQLITE_PATH = "${pkgs.sqlite.out}/lib/libsqlite3.so";
|
||||
};
|
||||
};
|
||||
});
|
||||
|
||||
|
||||
@@ -19,6 +19,7 @@ dev_dependencies:
|
||||
|
||||
executables:
|
||||
jadb: jadb
|
||||
test: test_tool
|
||||
|
||||
topics:
|
||||
- database
|
||||
|
||||
Reference in New Issue
Block a user