mirror of
https://github.com/immich-app/immich.git
synced 2025-01-04 02:46:47 +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>
67 lines
2.2 KiB
Dart
67 lines
2.2 KiB
Dart
import 'dart:io';
|
|
|
|
import 'package:immich_mobile/shared/ui/transparent_image.dart';
|
|
import 'package:mocktail/mocktail.dart';
|
|
|
|
/// Mocks the http client to always return a transparent image for all the requests. Only useful in widget
|
|
/// tests to return network images
|
|
class MockHttpOverrides extends HttpOverrides {
|
|
@override
|
|
HttpClient createHttpClient(SecurityContext? context) {
|
|
final client = _MockHttpClient();
|
|
final request = _MockHttpClientRequest();
|
|
final response = _MockHttpClientResponse();
|
|
final headers = _MockHttpHeaders();
|
|
|
|
// Client mocks
|
|
when(() => client.autoUncompress).thenReturn(true);
|
|
|
|
// Request mocks
|
|
when(() => request.headers).thenAnswer((_) => headers);
|
|
when(() => request.close())
|
|
.thenAnswer((_) => Future<HttpClientResponse>.value(response));
|
|
|
|
// Response mocks
|
|
when(() => response.statusCode).thenReturn(HttpStatus.ok);
|
|
when(() => response.compressionState)
|
|
.thenReturn(HttpClientResponseCompressionState.decompressed);
|
|
when(() => response.contentLength)
|
|
.thenAnswer((_) => kTransparentImage.length);
|
|
when(
|
|
() => response.listen(
|
|
captureAny(),
|
|
cancelOnError: captureAny(named: 'cancelOnError'),
|
|
onDone: captureAny(named: 'onDone'),
|
|
onError: captureAny(named: 'onError'),
|
|
),
|
|
).thenAnswer((invocation) {
|
|
final onData =
|
|
invocation.positionalArguments[0] as void Function(List<int>);
|
|
|
|
final onDone = invocation.namedArguments[#onDone] as void Function();
|
|
|
|
final onError = invocation.namedArguments[#onError] as void
|
|
Function(Object, [StackTrace]);
|
|
|
|
final cancelOnError = invocation.namedArguments[#cancelOnError] as bool;
|
|
|
|
return Stream<List<int>>.fromIterable([kTransparentImage.toList()])
|
|
.listen(
|
|
onData,
|
|
onDone: onDone,
|
|
onError: onError,
|
|
cancelOnError: cancelOnError,
|
|
);
|
|
});
|
|
|
|
return client;
|
|
}
|
|
}
|
|
|
|
class _MockHttpClient extends Mock implements HttpClient {}
|
|
|
|
class _MockHttpClientRequest extends Mock implements HttpClientRequest {}
|
|
|
|
class _MockHttpClientResponse extends Mock implements HttpClientResponse {}
|
|
|
|
class _MockHttpHeaders extends Mock implements HttpHeaders {}
|