2022-08-15 10:55:06 -07:00
|
|
|
import 'package:drift/drift.dart';
|
|
|
|
import 'package:drift/native.dart';
|
2023-09-16 09:38:22 -07:00
|
|
|
import 'package:drift_docs/snippets/dart_api/datetime_conversion.dart';
|
2023-11-07 14:42:07 -08:00
|
|
|
import 'package:drift_docs/snippets/log_interceptor.dart';
|
2023-02-17 08:56:48 -08:00
|
|
|
import 'package:drift_docs/snippets/modular/schema_inspection.dart';
|
2022-08-15 10:55:06 -07:00
|
|
|
import 'package:test/test.dart';
|
|
|
|
|
|
|
|
import 'generated/database.dart';
|
|
|
|
|
|
|
|
/// Test for some snippets embedded on https://drift.simonbinder.eu to make sure
|
|
|
|
/// that they are still up to date and work as intended with the latest drift
|
|
|
|
/// version.
|
|
|
|
void main() {
|
|
|
|
group('changing datetime format', () {
|
|
|
|
test('unix timestamp to text', () async {
|
2023-02-17 08:56:48 -08:00
|
|
|
final db = Database(DatabaseConnection(NativeDatabase.memory()));
|
2022-08-15 10:55:06 -07:00
|
|
|
addTearDown(db.close);
|
|
|
|
|
|
|
|
final time = DateTime.fromMillisecondsSinceEpoch(
|
|
|
|
// Drop milliseconds which are not supported by the old format
|
|
|
|
1000 * (DateTime.now().millisecondsSinceEpoch ~/ 1000),
|
|
|
|
);
|
|
|
|
|
|
|
|
// The database is currently using unix timstamps. Let's add some rows in
|
|
|
|
// that format:
|
|
|
|
await db.users.insertOne(
|
|
|
|
UsersCompanion.insert(name: 'name', createdAt: Value(time)));
|
|
|
|
await db.users.insertOne(
|
|
|
|
UsersCompanion.insert(name: 'name2', createdAt: Value(null)));
|
|
|
|
|
|
|
|
// Run conversion from unix timestamps to text
|
|
|
|
await db.migrateFromUnixTimestampsToText(db.createMigrator());
|
|
|
|
|
|
|
|
// Check that the values are still there!
|
|
|
|
final rows = await (db.select(db.users)
|
|
|
|
..orderBy([(row) => OrderingTerm.asc(row.rowId)]))
|
|
|
|
.get();
|
|
|
|
|
|
|
|
expect(rows, [
|
|
|
|
User(id: 1, name: 'name', createdAt: time),
|
|
|
|
const User(id: 2, name: 'name2', createdAt: null),
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('text to unix timestamp', () async {
|
|
|
|
// First, create all tables using text as datetime
|
2023-02-17 08:56:48 -08:00
|
|
|
final db = Database(DatabaseConnection(NativeDatabase.memory()));
|
2022-08-15 10:55:06 -07:00
|
|
|
db.options = const DriftDatabaseOptions(storeDateTimeAsText: true);
|
|
|
|
addTearDown(db.close);
|
|
|
|
|
|
|
|
final time = DateTime.fromMillisecondsSinceEpoch(
|
|
|
|
1000 * (DateTime.now().millisecondsSinceEpoch ~/ 1000));
|
|
|
|
|
|
|
|
// Add rows, storing date time as text
|
|
|
|
await db.users.insertOne(
|
|
|
|
UsersCompanion.insert(name: 'name', createdAt: Value(time)));
|
|
|
|
await db.users.insertOne(
|
|
|
|
UsersCompanion.insert(name: 'name2', createdAt: Value(null)));
|
|
|
|
|
|
|
|
// Next, migrate back to unix timestamps
|
|
|
|
db.options = const DriftDatabaseOptions(storeDateTimeAsText: false);
|
|
|
|
final migrator = db.createMigrator();
|
|
|
|
await db.migrateFromTextDateTimesToUnixTimestamps(migrator);
|
|
|
|
|
|
|
|
final rows = await (db.select(db.users)
|
|
|
|
..orderBy([(row) => OrderingTerm.asc(row.rowId)]))
|
|
|
|
.get();
|
|
|
|
|
|
|
|
expect(rows, [
|
|
|
|
User(id: 1, name: 'name', createdAt: time),
|
|
|
|
const User(id: 2, name: 'name2', createdAt: null),
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('text to unix timestamp, support old sqlite', () async {
|
|
|
|
// First, create all tables using text as datetime
|
2023-02-17 08:56:48 -08:00
|
|
|
final db = Database(DatabaseConnection(NativeDatabase.memory()));
|
2022-08-15 10:55:06 -07:00
|
|
|
db.options = const DriftDatabaseOptions(storeDateTimeAsText: true);
|
|
|
|
addTearDown(db.close);
|
|
|
|
|
|
|
|
final time = DateTime.fromMillisecondsSinceEpoch(
|
|
|
|
1000 * (DateTime.now().millisecondsSinceEpoch ~/ 1000));
|
|
|
|
|
|
|
|
// Add rows, storing date time as text
|
|
|
|
await db.users.insertOne(
|
|
|
|
UsersCompanion.insert(name: 'name', createdAt: Value(time)));
|
|
|
|
await db.users.insertOne(
|
|
|
|
UsersCompanion.insert(name: 'name2', createdAt: Value(null)));
|
|
|
|
|
|
|
|
// Next, migrate back to unix timestamps
|
|
|
|
db.options = const DriftDatabaseOptions(storeDateTimeAsText: false);
|
|
|
|
final migrator = db.createMigrator();
|
|
|
|
await db.migrateFromTextDateTimesToUnixTimestampsPre338(migrator);
|
|
|
|
|
|
|
|
final rows = await (db.select(db.users)
|
|
|
|
..orderBy([(row) => OrderingTerm.asc(row.rowId)]))
|
|
|
|
.get();
|
|
|
|
|
|
|
|
expect(rows, [
|
|
|
|
User(id: 1, name: 'name', createdAt: time),
|
|
|
|
const User(id: 2, name: 'name2', createdAt: null),
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
});
|
2023-02-17 08:56:48 -08:00
|
|
|
|
|
|
|
group('runtime schema inspection', () {
|
|
|
|
test('findById', () async {
|
|
|
|
final db = Database(NativeDatabase.memory());
|
|
|
|
addTearDown(db.close);
|
|
|
|
|
|
|
|
await db.batch((batch) {
|
|
|
|
batch.insert(db.users, UsersCompanion.insert(name: 'foo')); // 1
|
|
|
|
batch.insert(db.users, UsersCompanion.insert(name: 'bar')); // 2
|
|
|
|
batch.insert(db.users, UsersCompanion.insert(name: 'baz')); // 3
|
|
|
|
});
|
|
|
|
|
|
|
|
final row = await db.users.findById(2).getSingle();
|
|
|
|
expect(row.name, 'bar');
|
|
|
|
});
|
|
|
|
});
|
2023-11-07 14:42:07 -08:00
|
|
|
|
|
|
|
test('interceptor', () {
|
|
|
|
expect(
|
|
|
|
() async {
|
|
|
|
final db =
|
|
|
|
Database(NativeDatabase.memory().interceptWith(LogInterceptor()));
|
|
|
|
|
|
|
|
await db.batch((batch) {
|
|
|
|
batch.insert(db.users, UsersCompanion.insert(name: 'foo'));
|
|
|
|
});
|
|
|
|
|
|
|
|
await db.users.all().get();
|
|
|
|
},
|
|
|
|
prints(
|
|
|
|
allOf(
|
|
|
|
stringContainsInOrder(
|
|
|
|
[
|
|
|
|
'begin',
|
|
|
|
'Running batch with BatchedStatements',
|
|
|
|
' => succeeded after ',
|
|
|
|
'Running commit',
|
|
|
|
' => succeeded after ',
|
|
|
|
'Running SELECT * FROM "users"; with []',
|
|
|
|
' => succeeded after'
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
});
|
2022-08-15 10:55:06 -07:00
|
|
|
}
|