mirror of
https://github.com/immich-app/immich.git
synced 2025-01-09 21:36:46 +01:00
af32183728
* 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>
131 lines
4.4 KiB
Dart
131 lines
4.4 KiB
Dart
import 'package:flutter_test/flutter_test.dart';
|
|
import 'package:immich_mobile/extensions/asset_extensions.dart';
|
|
import 'package:immich_mobile/shared/models/asset.dart';
|
|
import 'package:immich_mobile/shared/models/exif_info.dart';
|
|
import 'package:timezone/data/latest.dart';
|
|
import 'package:timezone/timezone.dart';
|
|
|
|
ExifInfo makeExif({
|
|
DateTime? dateTimeOriginal,
|
|
String? timeZone,
|
|
}) {
|
|
return ExifInfo(
|
|
dateTimeOriginal: dateTimeOriginal,
|
|
timeZone: timeZone,
|
|
);
|
|
}
|
|
|
|
Asset makeAsset({
|
|
required String id,
|
|
required DateTime createdAt,
|
|
ExifInfo? exifInfo,
|
|
}) {
|
|
return Asset(
|
|
checksum: '',
|
|
localId: id,
|
|
remoteId: id,
|
|
ownerId: 1,
|
|
fileCreatedAt: createdAt,
|
|
fileModifiedAt: DateTime.now(),
|
|
updatedAt: DateTime.now(),
|
|
durationInSeconds: 0,
|
|
type: AssetType.image,
|
|
fileName: id,
|
|
isFavorite: false,
|
|
isArchived: false,
|
|
isTrashed: false,
|
|
stackCount: 0,
|
|
exifInfo: exifInfo,
|
|
);
|
|
}
|
|
|
|
void main() {
|
|
// Init Timezone DB
|
|
initializeTimeZones();
|
|
|
|
group("Returns local time and offset if no exifInfo", () {
|
|
test('returns createdAt directly if in local', () {
|
|
final createdAt = DateTime(2023, 12, 12, 12, 12, 12);
|
|
final a = makeAsset(id: '1', createdAt: createdAt);
|
|
final (dt, tz) = a.getTZAdjustedTimeAndOffset();
|
|
|
|
expect(createdAt, dt);
|
|
expect(createdAt.timeZoneOffset, tz);
|
|
});
|
|
|
|
test('returns createdAt in local if in utc', () {
|
|
final createdAt = DateTime.utc(2023, 12, 12, 12, 12, 12);
|
|
final a = makeAsset(id: '1', createdAt: createdAt);
|
|
final (dt, tz) = a.getTZAdjustedTimeAndOffset();
|
|
|
|
final localCreatedAt = createdAt.toLocal();
|
|
expect(localCreatedAt, dt);
|
|
expect(localCreatedAt.timeZoneOffset, tz);
|
|
});
|
|
});
|
|
|
|
group("Returns dateTimeOriginal", () {
|
|
test('Returns dateTimeOriginal in UTC from exifInfo without timezone', () {
|
|
final createdAt = DateTime.parse("2023-01-27T14:00:00-0500");
|
|
final dateTimeOriginal = DateTime.parse("2022-01-27T14:00:00+0530");
|
|
final e = makeExif(dateTimeOriginal: dateTimeOriginal);
|
|
final a = makeAsset(id: '1', createdAt: createdAt, exifInfo: e);
|
|
final (dt, tz) = a.getTZAdjustedTimeAndOffset();
|
|
|
|
final dateTimeInUTC = dateTimeOriginal.toUtc();
|
|
expect(dateTimeInUTC, dt);
|
|
expect(dateTimeInUTC.timeZoneOffset, tz);
|
|
});
|
|
|
|
test('Returns dateTimeOriginal in UTC from exifInfo with invalid timezone',
|
|
() {
|
|
final createdAt = DateTime.parse("2023-01-27T14:00:00-0500");
|
|
final dateTimeOriginal = DateTime.parse("2022-01-27T14:00:00+0530");
|
|
final e = makeExif(
|
|
dateTimeOriginal: dateTimeOriginal,
|
|
timeZone: "#_#",
|
|
); // Invalid timezone
|
|
final a = makeAsset(id: '1', createdAt: createdAt, exifInfo: e);
|
|
final (dt, tz) = a.getTZAdjustedTimeAndOffset();
|
|
|
|
final dateTimeInUTC = dateTimeOriginal.toUtc();
|
|
expect(dateTimeInUTC, dt);
|
|
expect(dateTimeInUTC.timeZoneOffset, tz);
|
|
});
|
|
});
|
|
|
|
group("Returns adjusted time if timezone available", () {
|
|
test('With timezone as location', () {
|
|
final createdAt = DateTime.parse("2023-01-27T14:00:00-0500");
|
|
final dateTimeOriginal = DateTime.parse("2022-01-27T14:00:00+0530");
|
|
const location = "Asia/Hong_Kong";
|
|
final e =
|
|
makeExif(dateTimeOriginal: dateTimeOriginal, timeZone: location);
|
|
final a = makeAsset(id: '1', createdAt: createdAt, exifInfo: e);
|
|
final (dt, tz) = a.getTZAdjustedTimeAndOffset();
|
|
|
|
final adjustedTime =
|
|
TZDateTime.from(dateTimeOriginal.toUtc(), getLocation(location));
|
|
expect(adjustedTime, dt);
|
|
expect(adjustedTime.timeZoneOffset, tz);
|
|
});
|
|
|
|
test('With timezone as offset', () {
|
|
final createdAt = DateTime.parse("2023-01-27T14:00:00-0500");
|
|
final dateTimeOriginal = DateTime.parse("2022-01-27T14:00:00+0530");
|
|
const offset = "utc+08:00";
|
|
final e = makeExif(dateTimeOriginal: dateTimeOriginal, timeZone: offset);
|
|
final a = makeAsset(id: '1', createdAt: createdAt, exifInfo: e);
|
|
final (dt, tz) = a.getTZAdjustedTimeAndOffset();
|
|
|
|
final location = getLocation("Asia/Hong_Kong");
|
|
final offsetFromLocation =
|
|
Duration(milliseconds: location.currentTimeZone.offset);
|
|
final adjustedTime = dateTimeOriginal.toUtc().add(offsetFromLocation);
|
|
|
|
// Adds the offset to the actual time and returns the offset separately
|
|
expect(adjustedTime, dt);
|
|
expect(offsetFromLocation, tz);
|
|
});
|
|
});
|
|
}
|