drift/drift_dev/test/services/schema/verifier_impl_test.dart

103 lines
3.2 KiB
Dart

import 'package:drift/drift.dart';
import 'package:drift/native.dart';
import 'package:drift_dev/api/migrations.dart';
import 'package:drift_dev/src/services/schema/verifier_impl.dart';
import 'package:test/test.dart';
void main() {
final verifier = SchemaVerifier(_TestHelper());
group('startAt', () {
test('starts at the requested version', () async {
final db = (await verifier.startAt(17)).executor;
await db.ensureOpen(_DelegatedUser(17, (_, details) async {
expect(details.wasCreated, isFalse, reason: 'was opened before');
expect(details.hadUpgrade, isFalse, reason: 'no upgrade expected');
}));
});
});
group('migrateAndValidate', () {
test('invokes a migration', () async {
driftRuntimeOptions.dontWarnAboutMultipleDatabases = true;
OpeningDetails? capturedDetails;
final connection = await verifier.startAt(3);
final db = _TestDatabase(connection.executor, 7)
..migration = MigrationStrategy(onUpgrade: (m, from, to) async {
capturedDetails = OpeningDetails(from, to);
});
await verifier.migrateAndValidate(db, 4);
expect(capturedDetails!.versionBefore, 3);
expect(capturedDetails!.versionNow, 4);
driftRuntimeOptions.dontWarnAboutMultipleDatabases = false;
});
});
group('collectSchemaInput', () {
test('contains only user-defined entities', () async {
final db = _TestDatabase(NativeDatabase.memory(), 1);
addTearDown(db.close);
await db.customStatement('CREATE TABLE x1 (bar UNIQUE);');
await db.customStatement('CREATE VIEW x2 AS SELECT * FROM x1;');
await db.customStatement('CREATE INDEX x3 ON x1 (bar);');
await db.customStatement('CREATE TRIGGER x4 AFTER INSERT ON x1 BEGIN '
'DELETE FROM x1;'
'END;');
final inputs = await db.collectSchemaInput(const []);
expect(inputs.map((e) => e.name), ['x1', 'x2', 'x3', 'x4']);
});
test('does not contain shadow tables', () async {
final db = _TestDatabase(NativeDatabase.memory(), 1);
addTearDown(db.close);
await db.customStatement('CREATE VIRTUAL TABLE x USING fts5(foo, bar);');
await db
.customStatement('INSERT INTO x VALUES (?, ?)', ['test', 'another']);
final inputs = await db.collectSchemaInput(const ['x']);
expect(inputs.map((e) => e.name), ['x']);
});
});
}
class _TestHelper implements SchemaInstantiationHelper {
@override
GeneratedDatabase databaseForVersion(QueryExecutor db, int version) {
return _TestDatabase(db, version);
}
}
class _TestDatabase extends GeneratedDatabase {
@override
final int schemaVersion;
@override
MigrationStrategy migration = MigrationStrategy();
_TestDatabase(super.executor, this.schemaVersion);
@override
Iterable<TableInfo<Table, DataClass>> get allTables {
return const Iterable.empty();
}
}
class _DelegatedUser extends QueryExecutorUser {
@override
final int schemaVersion;
final Future<void> Function(QueryExecutor, OpeningDetails) _beforeOpen;
_DelegatedUser(this.schemaVersion, this._beforeOpen);
@override
Future<void> beforeOpen(QueryExecutor executor, OpeningDetails details) {
return _beforeOpen(executor, details);
}
}