mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-31 02:27:08 -04:00 
			
		
		
		
	* refactor: autoroutex pushroute * refactor: autoroutex popRoute * refactor: autoroutex navigate and replace * chore: add doc comments for extension methods * refactor: Add LoggerMixin and refactor Album activities to use mixin * refactor: Activity page * chore: activity user from user constructor * fix: update current asset after build method * refactor: tests with similar structure as lib * chore: remove avoid-declaring-call-method rule from dcm analysis * test: fix proper expect order * test: activity_statistics_provider_test * test: activity_provider_test * test: use proper matchers * test: activity_text_field_test & dismissible_activity_test added * test: add http mock to return transparent image * test: download isar core libs during test * test: add widget tags to widget test cases * test: activity_tile_test * build: currentAlbumProvider to generator * movie add / remove like to activity input tile * test: activities_page_test.dart * chore: better error logs * chore: dismissibleactivity as statelesswidget --------- Co-authored-by: shalong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
		
			
				
	
	
		
			155 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			155 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'package:flutter/widgets.dart';
 | |
| import 'package:flutter_test/flutter_test.dart';
 | |
| import 'package:immich_mobile/shared/models/asset.dart';
 | |
| import 'package:immich_mobile/shared/models/store.dart';
 | |
| import 'package:immich_mobile/shared/models/user.dart';
 | |
| import 'package:immich_mobile/shared/services/immich_logger.service.dart';
 | |
| import 'package:immich_mobile/shared/services/sync.service.dart';
 | |
| import 'package:isar/isar.dart';
 | |
| 
 | |
| import '../../test_utils.dart';
 | |
| import 'shared_mocks.dart';
 | |
| 
 | |
| void main() {
 | |
|   Asset makeAsset({
 | |
|     required String checksum,
 | |
|     String? localId,
 | |
|     String? remoteId,
 | |
|     int ownerId = 590700560494856554, // hash of "1"
 | |
|   }) {
 | |
|     final DateTime date = DateTime(2000);
 | |
|     return Asset(
 | |
|       checksum: checksum,
 | |
|       localId: localId,
 | |
|       remoteId: remoteId,
 | |
|       ownerId: ownerId,
 | |
|       fileCreatedAt: date,
 | |
|       fileModifiedAt: date,
 | |
|       updatedAt: date,
 | |
|       durationInSeconds: 0,
 | |
|       type: AssetType.image,
 | |
|       fileName: localId ?? remoteId ?? "",
 | |
|       isFavorite: false,
 | |
|       isArchived: false,
 | |
|       isTrashed: false,
 | |
|       stackCount: 0,
 | |
|     );
 | |
|   }
 | |
| 
 | |
|   group('Test SyncService grouped', () {
 | |
|     late final Isar db;
 | |
|     final MockHashService hs = MockHashService();
 | |
|     final owner = User(
 | |
|       id: "1",
 | |
|       updatedAt: DateTime.now(),
 | |
|       email: "a@b.c",
 | |
|       name: "first last",
 | |
|       isAdmin: false,
 | |
|     );
 | |
|     setUpAll(() async {
 | |
|       WidgetsFlutterBinding.ensureInitialized();
 | |
|       db = await TestUtils.initIsar();
 | |
|       ImmichLogger();
 | |
|       db.writeTxnSync(() => db.clearSync());
 | |
|       Store.init(db);
 | |
|       await Store.put(StoreKey.currentUser, owner);
 | |
|     });
 | |
|     final List<Asset> initialAssets = [
 | |
|       makeAsset(checksum: "a", remoteId: "0-1"),
 | |
|       makeAsset(checksum: "b", remoteId: "2-1"),
 | |
|       makeAsset(checksum: "c", localId: "1", remoteId: "1-1"),
 | |
|       makeAsset(checksum: "d", localId: "2"),
 | |
|       makeAsset(checksum: "e", localId: "3"),
 | |
|     ];
 | |
|     setUp(() {
 | |
|       db.writeTxnSync(() {
 | |
|         db.assets.clearSync();
 | |
|         db.assets.putAllSync(initialAssets);
 | |
|       });
 | |
|     });
 | |
|     test('test inserting existing assets', () async {
 | |
|       SyncService s = SyncService(db, hs);
 | |
|       final List<Asset> remoteAssets = [
 | |
|         makeAsset(checksum: "a", remoteId: "0-1"),
 | |
|         makeAsset(checksum: "b", remoteId: "2-1"),
 | |
|         makeAsset(checksum: "c", remoteId: "1-1"),
 | |
|       ];
 | |
|       expect(db.assets.countSync(), 5);
 | |
|       final bool c1 =
 | |
|           await s.syncRemoteAssetsToDb(owner, _failDiff, (u) => remoteAssets);
 | |
|       expect(c1, isFalse);
 | |
|       expect(db.assets.countSync(), 5);
 | |
|     });
 | |
| 
 | |
|     test('test inserting new assets', () async {
 | |
|       SyncService s = SyncService(db, hs);
 | |
|       final List<Asset> remoteAssets = [
 | |
|         makeAsset(checksum: "a", remoteId: "0-1"),
 | |
|         makeAsset(checksum: "b", remoteId: "2-1"),
 | |
|         makeAsset(checksum: "c", remoteId: "1-1"),
 | |
|         makeAsset(checksum: "d", remoteId: "1-2"),
 | |
|         makeAsset(checksum: "f", remoteId: "1-4"),
 | |
|         makeAsset(checksum: "g", remoteId: "3-1"),
 | |
|       ];
 | |
|       expect(db.assets.countSync(), 5);
 | |
|       final bool c1 =
 | |
|           await s.syncRemoteAssetsToDb(owner, _failDiff, (u) => remoteAssets);
 | |
|       expect(c1, isTrue);
 | |
|       expect(db.assets.countSync(), 7);
 | |
|     });
 | |
| 
 | |
|     test('test syncing duplicate assets', () async {
 | |
|       SyncService s = SyncService(db, hs);
 | |
|       final List<Asset> remoteAssets = [
 | |
|         makeAsset(checksum: "a", remoteId: "0-1"),
 | |
|         makeAsset(checksum: "b", remoteId: "1-1"),
 | |
|         makeAsset(checksum: "c", remoteId: "2-1"),
 | |
|         makeAsset(checksum: "h", remoteId: "2-1b"),
 | |
|         makeAsset(checksum: "i", remoteId: "2-1c"),
 | |
|         makeAsset(checksum: "j", remoteId: "2-1d"),
 | |
|       ];
 | |
|       expect(db.assets.countSync(), 5);
 | |
|       final bool c1 =
 | |
|           await s.syncRemoteAssetsToDb(owner, _failDiff, (u) => remoteAssets);
 | |
|       expect(c1, isTrue);
 | |
|       expect(db.assets.countSync(), 8);
 | |
|       final bool c2 =
 | |
|           await s.syncRemoteAssetsToDb(owner, _failDiff, (u) => remoteAssets);
 | |
|       expect(c2, isFalse);
 | |
|       expect(db.assets.countSync(), 8);
 | |
|       remoteAssets.removeAt(4);
 | |
|       final bool c3 =
 | |
|           await s.syncRemoteAssetsToDb(owner, _failDiff, (u) => remoteAssets);
 | |
|       expect(c3, isTrue);
 | |
|       expect(db.assets.countSync(), 7);
 | |
|       remoteAssets.add(makeAsset(checksum: "k", remoteId: "2-1e"));
 | |
|       remoteAssets.add(makeAsset(checksum: "l", remoteId: "2-2"));
 | |
|       final bool c4 =
 | |
|           await s.syncRemoteAssetsToDb(owner, _failDiff, (u) => remoteAssets);
 | |
|       expect(c4, isTrue);
 | |
|       expect(db.assets.countSync(), 9);
 | |
|     });
 | |
| 
 | |
|     test('test efficient sync', () async {
 | |
|       SyncService s = SyncService(db, hs);
 | |
|       final List<Asset> toUpsert = [
 | |
|         makeAsset(checksum: "a", remoteId: "0-1"), // changed
 | |
|         makeAsset(checksum: "f", remoteId: "0-2"), // new
 | |
|         makeAsset(checksum: "g", remoteId: "0-3"), // new
 | |
|       ];
 | |
|       toUpsert[0].isFavorite = true;
 | |
|       final List<String> toDelete = ["2-1", "1-1"];
 | |
|       final bool c = await s.syncRemoteAssetsToDb(
 | |
|         owner,
 | |
|         (user, since) async => (toUpsert, toDelete),
 | |
|         (user) => throw Exception(),
 | |
|       );
 | |
|       expect(c, isTrue);
 | |
|       expect(db.assets.countSync(), 6);
 | |
|     });
 | |
|   });
 | |
| }
 | |
| 
 | |
| Future<(List<Asset>?, List<String>?)> _failDiff(User user, DateTime time) =>
 | |
|     Future.value((null, null));
 |