mirror of
https://github.com/vodemn/m3_lightmeter.git
synced 2024-11-22 15:30:59 +00:00
5c27f726c5
* wip * added start/stop button * animated timeline * fixed timer stop state * added reset button (wip) * added `onExposurePairTap` callback * integrated `TimerScreen` to navigation * separated `TimerTimeline` * fixed timeline flickering * added milliseconds to timer * synchronized timeline with actual timer * reused `BottomControlsBar` * fixed default scaffold background color * moved center button size to the bar itself * display selected exposure pair on timer screen * separated reusable `AnimatedCircluarButton` * release camera when timer is opened * added `TimerInteractor` * added `TimerBloc` test * fixed hours parsing * added scenarios for timer golden test * adjusted timer timeline colors * show iso & nd values on timer screen * automatically close timer screen after timeout * added timer autostart * reverted theme changes * updated goldens * typo * removed timer screen auto-dismiss * increased timer vibration duration * replaced outlined locks * increased 1/3 values font size
74 lines
2.7 KiB
Dart
74 lines
2.7 KiB
Dart
import 'package:flutter_test/flutter_test.dart';
|
|
import 'package:lightmeter/data/haptics_service.dart';
|
|
import 'package:lightmeter/data/shared_prefs_service.dart';
|
|
import 'package:lightmeter/interactors/timer_interactor.dart';
|
|
import 'package:mocktail/mocktail.dart';
|
|
|
|
class _MockUserPreferencesService extends Mock implements UserPreferencesService {}
|
|
|
|
class _MockHapticsService extends Mock implements HapticsService {}
|
|
|
|
void main() {
|
|
late _MockUserPreferencesService mockUserPreferencesService;
|
|
late _MockHapticsService mockHapticsService;
|
|
|
|
late TimerInteractor interactor;
|
|
|
|
setUp(() {
|
|
mockUserPreferencesService = _MockUserPreferencesService();
|
|
mockHapticsService = _MockHapticsService();
|
|
|
|
interactor = TimerInteractor(
|
|
mockUserPreferencesService,
|
|
mockHapticsService,
|
|
);
|
|
});
|
|
|
|
group(
|
|
'Haptics',
|
|
() {
|
|
test('startVibration() - true', () async {
|
|
when(() => mockUserPreferencesService.haptics).thenReturn(true);
|
|
when(() => mockHapticsService.quickVibration()).thenAnswer((_) async {});
|
|
interactor.startVibration();
|
|
verify(() => mockUserPreferencesService.haptics).called(1);
|
|
verify(() => mockHapticsService.quickVibration()).called(1);
|
|
});
|
|
|
|
test('startVibration() - false', () async {
|
|
when(() => mockUserPreferencesService.haptics).thenReturn(false);
|
|
when(() => mockHapticsService.quickVibration()).thenAnswer((_) async {});
|
|
interactor.startVibration();
|
|
verify(() => mockUserPreferencesService.haptics).called(1);
|
|
verifyNever(() => mockHapticsService.quickVibration());
|
|
});
|
|
|
|
test('endVibration() - true', () async {
|
|
when(() => mockUserPreferencesService.haptics).thenReturn(true);
|
|
when(() => mockHapticsService.errorVibration()).thenAnswer((_) async {});
|
|
interactor.endVibration();
|
|
verify(() => mockUserPreferencesService.haptics).called(1);
|
|
verify(() => mockHapticsService.errorVibration()).called(1);
|
|
});
|
|
|
|
test('endVibration() - false', () async {
|
|
when(() => mockUserPreferencesService.haptics).thenReturn(false);
|
|
when(() => mockHapticsService.errorVibration()).thenAnswer((_) async {});
|
|
interactor.endVibration();
|
|
verify(() => mockUserPreferencesService.haptics).called(1);
|
|
verifyNever(() => mockHapticsService.errorVibration());
|
|
});
|
|
},
|
|
);
|
|
|
|
group(
|
|
'AutostartTimer',
|
|
() {
|
|
test('isAutostartTimerEnabled', () {
|
|
when(() => mockUserPreferencesService.autostartTimer).thenReturn(true);
|
|
expect(interactor.isAutostartTimerEnabled, true);
|
|
verify(() => mockUserPreferencesService.autostartTimer).called(1);
|
|
});
|
|
},
|
|
);
|
|
}
|