2019-08-29 06:52:29 -07:00
|
|
|
import 'package:moor/moor.dart';
|
2019-09-26 13:52:20 -07:00
|
|
|
import 'package:test/test.dart';
|
2019-07-07 07:04:55 -07:00
|
|
|
|
|
|
|
import 'data/tables/todos.dart';
|
|
|
|
import 'data/utils/mocks.dart';
|
|
|
|
|
|
|
|
void main() {
|
|
|
|
TodoDb db;
|
|
|
|
MockExecutor executor;
|
2019-08-29 06:52:29 -07:00
|
|
|
MockStreamQueries streamQueries;
|
2019-07-07 07:04:55 -07:00
|
|
|
|
|
|
|
setUp(() {
|
|
|
|
executor = MockExecutor();
|
2019-08-29 06:52:29 -07:00
|
|
|
streamQueries = MockStreamQueries();
|
|
|
|
db = TodoDb(executor)..streamQueries = streamQueries;
|
2019-07-07 07:04:55 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
group('compiled custom queries', () {
|
|
|
|
// defined query: SELECT * FROM todos WHERE title = ?2 OR id IN ? OR title = ?1
|
|
|
|
test('work with arrays', () async {
|
|
|
|
await db.withIn('one', 'two', [1, 2, 3]);
|
|
|
|
|
|
|
|
verify(
|
|
|
|
executor.runSelect(
|
2019-08-16 06:08:07 -07:00
|
|
|
'SELECT * FROM todos WHERE title = ?2 OR id IN (?3, ?4, ?5) OR title = ?1',
|
2019-07-07 07:04:55 -07:00
|
|
|
['one', 'two', 1, 2, 3],
|
|
|
|
),
|
|
|
|
);
|
|
|
|
});
|
|
|
|
});
|
2019-08-29 06:52:29 -07:00
|
|
|
|
2019-09-29 07:33:09 -07:00
|
|
|
test('custom select reads values', () async {
|
|
|
|
final time = DateTime(2019, 10, 1);
|
|
|
|
final unix = time.millisecondsSinceEpoch ~/ 1000;
|
|
|
|
|
|
|
|
when(executor.runSelect(any, any)).thenAnswer((i) {
|
|
|
|
return Future.value([
|
|
|
|
<String, dynamic>{
|
|
|
|
'bool': true,
|
|
|
|
'int': 3,
|
|
|
|
'double': 3.14,
|
|
|
|
'dateTime': unix,
|
|
|
|
'blob': Uint8List.fromList([1, 2, 3]),
|
|
|
|
}
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
|
|
|
|
final rows = await db.customSelectQuery('').get();
|
|
|
|
final row = rows.single;
|
|
|
|
|
|
|
|
expect(row.readBool('bool'), isTrue);
|
|
|
|
expect(row.readInt('int'), 3);
|
|
|
|
expect(row.readDouble('double'), 3.14);
|
|
|
|
expect(row.readDateTime('dateTime'), time);
|
|
|
|
expect(row.readBlob('blob'), Uint8List.fromList([1, 2, 3]));
|
|
|
|
});
|
|
|
|
|
2019-08-29 06:52:29 -07:00
|
|
|
test('custom update informs stream queries', () async {
|
|
|
|
await db.customUpdate('UPDATE tbl SET a = ?',
|
|
|
|
variables: [Variable.withString('hi')], updates: {db.users});
|
|
|
|
|
|
|
|
verify(executor.runUpdate('UPDATE tbl SET a = ?', ['hi']));
|
|
|
|
verify(streamQueries.handleTableUpdates({db.users}));
|
|
|
|
});
|
|
|
|
|
|
|
|
test('custom insert', () async {
|
|
|
|
when(executor.runInsert(any, any)).thenAnswer((_) => Future.value(32));
|
|
|
|
|
|
|
|
final id =
|
|
|
|
await db.customInsert('fake insert', variables: [Variable.withInt(3)]);
|
|
|
|
expect(id, 32);
|
|
|
|
|
|
|
|
// shouldn't call stream queries - we didn't set the updates parameter
|
|
|
|
verifyNever(streamQueries.handleTableUpdates(any));
|
|
|
|
});
|
2019-10-20 02:39:24 -07:00
|
|
|
|
|
|
|
test('custom statement', () async {
|
|
|
|
// regression test for https://github.com/simolus3/moor/issues/199 - the
|
|
|
|
// mock will throw when used before opening
|
|
|
|
expect(db.customStatement('UPDATE tbl SET a = b'), completes);
|
|
|
|
});
|
2019-07-07 07:04:55 -07:00
|
|
|
}
|