diff --git a/integration_test/e2e_test.dart b/integration_test/e2e_test.dart index 5d320740..a5b43c3f 100644 --- a/integration_test/e2e_test.dart +++ b/integration_test/e2e_test.dart @@ -17,6 +17,7 @@ import 'package:lightmeter/screens/settings/components/shared/dialog_filter/widg import 'package:lightmeter/screens/settings/components/shared/dialog_range_picker/widget_dialog_picker_range.dart'; import 'package:lightmeter/screens/settings/screen_settings.dart'; import 'package:lightmeter/utils/double_to_zoom.dart'; +import 'package:lightmeter/utils/platform_utils.dart'; import 'package:m3_lightmeter_resources/m3_lightmeter_resources.dart'; import 'package:meta/meta.dart'; import 'package:shared_preferences/shared_preferences.dart'; @@ -27,7 +28,7 @@ import 'utils/expectations.dart'; @isTest void testE2E(String description) { - setUp(() { + setUp(() async { SharedPreferences.setMockInitialValues({ /// Metering values UserPreferencesService.evSourceTypeKey: EvSourceType.camera.index, @@ -38,6 +39,8 @@ void testE2E(String description) { MeteringScreenLayoutFeature.filmPicker: true, }.toJson(), ), + + UserPreferencesService.seenChangelogVersionKey: await const PlatformUtils().version, }); }); diff --git a/integration_test/metering_screen_layout_test.dart b/integration_test/metering_screen_layout_test.dart index 37758707..ec2ce7b5 100644 --- a/integration_test/metering_screen_layout_test.dart +++ b/integration_test/metering_screen_layout_test.dart @@ -10,6 +10,7 @@ import 'package:lightmeter/screens/metering/components/shared/readings_container import 'package:lightmeter/screens/metering/components/shared/readings_container/components/extreme_exposure_pairs_container/widget_container_extreme_exposure_pairs.dart'; import 'package:lightmeter/screens/metering/components/shared/readings_container/components/film_picker/widget_picker_film.dart'; import 'package:lightmeter/screens/settings/screen_settings.dart'; +import 'package:lightmeter/utils/platform_utils.dart'; import 'package:meta/meta.dart'; import 'package:shared_preferences/shared_preferences.dart'; @@ -22,7 +23,7 @@ void testToggleLayoutFeatures(String description) { group( description, () { - setUp(() { + setUp(() async { SharedPreferences.setMockInitialValues({ /// Metering values UserPreferencesService.evSourceTypeKey: EvSourceType.camera.index, @@ -33,6 +34,7 @@ void testToggleLayoutFeatures(String description) { MeteringScreenLayoutFeature.filmPicker: true, }.toJson(), ), + UserPreferencesService.seenChangelogVersionKey: await const PlatformUtils().version, }); }); diff --git a/integration_test/purchases_test.dart b/integration_test/purchases_test.dart index f001a5c8..a0862fb3 100644 --- a/integration_test/purchases_test.dart +++ b/integration_test/purchases_test.dart @@ -14,6 +14,7 @@ import 'package:lightmeter/screens/metering/components/shared/readings_container import 'package:lightmeter/screens/metering/components/shared/readings_container/components/nd_picker/widget_picker_nd.dart'; import 'package:lightmeter/screens/settings/components/shared/disable/widget_disable.dart'; import 'package:lightmeter/screens/settings/screen_settings.dart'; +import 'package:lightmeter/utils/platform_utils.dart'; import 'package:m3_lightmeter_iap/m3_lightmeter_iap.dart'; import 'package:meta/meta.dart'; import 'package:shared_preferences/shared_preferences.dart'; @@ -38,6 +39,7 @@ void testPurchases(String description) { MeteringScreenLayoutFeature.filmPicker: true, }.toJson(), ), + UserPreferencesService.seenChangelogVersionKey: await const PlatformUtils().version, }); await tester.pumpApplication(productStatus: IAPProductStatus.purchasable); diff --git a/lib/screens/settings/components/about/components/version/widget_list_tile_version.dart b/lib/screens/settings/components/about/components/version/widget_list_tile_version.dart index c37d80fd..48496cb9 100644 --- a/lib/screens/settings/components/about/components/version/widget_list_tile_version.dart +++ b/lib/screens/settings/components/about/components/version/widget_list_tile_version.dart @@ -1,15 +1,15 @@ import 'package:flutter/material.dart'; import 'package:lightmeter/generated/l10n.dart'; import 'package:lightmeter/screens/shared/release_notes_dialog/widget_dialog_release_notes.dart'; -import 'package:package_info_plus/package_info_plus.dart'; +import 'package:lightmeter/utils/platform_utils.dart'; class VersionListTile extends StatelessWidget { const VersionListTile({super.key}); @override Widget build(BuildContext context) { - return FutureBuilder( - future: PackageInfo.fromPlatform(), + return FutureBuilder<({String buildNumber, String version})>( + future: const PlatformUtils().buildVersion, builder: (context, snapshot) => ListTile( leading: const Icon(Icons.info_outline), title: Text(S.of(context).version), diff --git a/lib/screens/shared/release_notes_dialog/bloc_release_notes.dart b/lib/screens/shared/release_notes_dialog/bloc_release_notes.dart index c0acf42e..e39e6fc0 100644 --- a/lib/screens/shared/release_notes_dialog/bloc_release_notes.dart +++ b/lib/screens/shared/release_notes_dialog/bloc_release_notes.dart @@ -3,19 +3,23 @@ import 'dart:async'; import 'package:flutter_bloc/flutter_bloc.dart'; import 'package:lightmeter/data/shared_prefs_service.dart'; import 'package:lightmeter/screens/shared/release_notes_dialog/state_release_notes.dart'; -import 'package:package_info_plus/package_info_plus.dart'; +import 'package:lightmeter/utils/platform_utils.dart'; class ReleaseNotesBloc extends Cubit { final UserPreferencesService _userPreferencesService; + final PlatformUtils _platformUtils; - ReleaseNotesBloc(this._userPreferencesService) : super(const HiddenReleaseNotesDialogState()) { + ReleaseNotesBloc( + this._userPreferencesService, + this._platformUtils, + ) : super(const HiddenReleaseNotesDialogState()) { _showDialogIfNeeded(); } Future _showDialogIfNeeded() async { - PackageInfo.fromPlatform().then((value) { - if (value.version != _userPreferencesService.seenChangelogVersion) { - emit(ShowReleaseNotesDialogState(value.version)); + _platformUtils.version.then((version) { + if (version != _userPreferencesService.seenChangelogVersion) { + emit(ShowReleaseNotesDialogState(version)); } }); } diff --git a/lib/screens/shared/release_notes_dialog/flow_dialog_release_notes.dart b/lib/screens/shared/release_notes_dialog/flow_dialog_release_notes.dart index b52710e8..de7af059 100644 --- a/lib/screens/shared/release_notes_dialog/flow_dialog_release_notes.dart +++ b/lib/screens/shared/release_notes_dialog/flow_dialog_release_notes.dart @@ -4,6 +4,7 @@ import 'package:lightmeter/providers/services_provider.dart'; import 'package:lightmeter/screens/shared/release_notes_dialog/bloc_release_notes.dart'; import 'package:lightmeter/screens/shared/release_notes_dialog/state_release_notes.dart'; import 'package:lightmeter/screens/shared/release_notes_dialog/widget_dialog_release_notes.dart'; +import 'package:lightmeter/utils/platform_utils.dart'; class ReleaseNotesFlow extends StatelessWidget { final Widget child; @@ -13,7 +14,10 @@ class ReleaseNotesFlow extends StatelessWidget { @override Widget build(BuildContext context) { return BlocProvider( - create: (context) => ReleaseNotesBloc(ServicesProvider.of(context).userPreferencesService), + create: (context) => ReleaseNotesBloc( + ServicesProvider.of(context).userPreferencesService, + const PlatformUtils(), + ), child: BlocListener( listener: (context, state) { if (state is ShowReleaseNotesDialogState) { diff --git a/lib/utils/platform_utils.dart b/lib/utils/platform_utils.dart new file mode 100644 index 00000000..2cca8d22 --- /dev/null +++ b/lib/utils/platform_utils.dart @@ -0,0 +1,10 @@ +import 'package:package_info_plus/package_info_plus.dart'; + +class PlatformUtils { + const PlatformUtils(); + + Future get version async => (await PackageInfo.fromPlatform()).version; + + Future<({String version, String buildNumber})> get buildVersion async => + PackageInfo.fromPlatform().then((value) => (version: value.version, buildNumber: value.buildNumber)); +} diff --git a/screenshots/generate_screenshots.dart b/screenshots/generate_screenshots.dart index 307c3687..13aa98d6 100644 --- a/screenshots/generate_screenshots.dart +++ b/screenshots/generate_screenshots.dart @@ -22,6 +22,7 @@ import 'package:lightmeter/screens/settings/components/metering/components/equip import 'package:lightmeter/screens/settings/screen_settings.dart'; import 'package:lightmeter/screens/shared/animated_circular_button/widget_button_circular_animated.dart'; import 'package:lightmeter/screens/timer/screen_timer.dart'; +import 'package:lightmeter/utils/platform_utils.dart'; import 'package:m3_lightmeter_resources/m3_lightmeter_resources.dart'; import 'package:shared_preferences/shared_preferences.dart'; @@ -42,13 +43,13 @@ void main() { final binding = IntegrationTestWidgetsFlutterBinding(); IntegrationTestWidgetsFlutterBinding.ensureInitialized(); - void mockSharedPrefs({ + Future mockSharedPrefs({ int iso = 400, int nd = 0, double calibration = 0.0, required ThemeType theme, required Color color, - }) { + }) async { SharedPreferences.setMockInitialValues({ /// Metering values UserPreferencesService.evSourceTypeKey: EvSourceType.camera.index, @@ -78,6 +79,8 @@ void main() { UserPreferencesService.themeTypeKey: theme.index, UserPreferencesService.primaryColorKey: color.value, UserPreferencesService.dynamicColorKey: false, + + UserPreferencesService.seenChangelogVersionKey: await const PlatformUtils().version, }); } @@ -87,7 +90,7 @@ void main() { /// Generates several screenshots with the light theme testWidgets('Generate light theme screenshots', (tester) async { - mockSharedPrefs(theme: ThemeType.light, color: _lightThemeColor); + await mockSharedPrefs(theme: ThemeType.light, color: _lightThemeColor); await tester.pumpApplication( availableFilms: [_mockFilm], filmsInUse: [_mockFilm], @@ -127,7 +130,7 @@ void main() { testWidgets( 'Generate dark theme screenshots', (tester) async { - mockSharedPrefs(theme: ThemeType.dark, color: _darkThemeColor); + await mockSharedPrefs(theme: ThemeType.dark, color: _darkThemeColor); await tester.pumpApplication( availableFilms: [_mockFilm], filmsInUse: [_mockFilm], @@ -146,7 +149,7 @@ void main() { ApertureValue(16, StopType.full), ShutterSpeedValue(8, false, StopType.full), ); - mockSharedPrefs( + await mockSharedPrefs( iso: 100, nd: 8, calibration: -0.3,