From 1c1fe4e240be91b800c372b024dd04aad55fcc3b Mon Sep 17 00:00:00 2001 From: hieubt Date: Wed, 28 Feb 2024 01:43:23 +0700 Subject: [PATCH] TW-1503 Write unit test `localizedTimeShort` and `isInCurrentWeek` --- lib/utils/date_time_extension.dart | 12 +- test/utils/date_time_extension_test.dart | 653 +++++++++++++++++++++++ 2 files changed, 660 insertions(+), 5 deletions(-) create mode 100644 test/utils/date_time_extension_test.dart diff --git a/lib/utils/date_time_extension.dart b/lib/utils/date_time_extension.dart index b155bc4956..25c6e8e25c 100644 --- a/lib/utils/date_time_extension.dart +++ b/lib/utils/date_time_extension.dart @@ -41,11 +41,12 @@ extension DateTimeExtension on DateTime { /// Returns [localizedTimeOfDay()] if the ChatTime is today, the name of the week /// day if the ChatTime is this week and a date string else. String localizedTimeShort(BuildContext context, {DateTime? currentTime}) { - final now = currentTime ?? DateTime.now(); + currentTime ??= DateTime.now(); - final sameYear = now.year == year; + final sameYear = currentTime.year == year; - final sameDay = sameYear && now.month == month && now.day == day; + final sameDay = + sameYear && currentTime.month == month && currentTime.day == day; final sameWeek = isInCurrentWeek(currentTime: currentTime); @@ -81,9 +82,10 @@ extension DateTimeExtension on DateTime { } bool isInCurrentWeek({DateTime? currentTime}) { - final now = currentTime ?? DateTime.now(); + currentTime ??= DateTime.now(); - final currentWeekStart = now.subtract(Duration(days: now.weekday - 1)); + final currentWeekStart = + currentTime.subtract(Duration(days: currentTime.weekday - 1)); final weekStart = subtract(Duration(days: weekday - 1)); diff --git a/test/utils/date_time_extension_test.dart b/test/utils/date_time_extension_test.dart new file mode 100644 index 0000000000..3ca5b6d204 --- /dev/null +++ b/test/utils/date_time_extension_test.dart @@ -0,0 +1,653 @@ +import 'package:fluffychat/utils/date_time_extension.dart'; +import 'package:flutter/material.dart'; +import 'package:flutter_test/flutter_test.dart'; +import 'package:flutter_gen/gen_l10n/l10n.dart'; + +void main() { + TestWidgetsFlutterBinding.ensureInitialized(); + + group( + '[localizedTimeShort TEST]\n' + 'GIVEN a Text widget\n' + 'USING localizedTimeShort\n', () { + const textWidgetKey = ValueKey('textWidget'); + + testWidgets( + 'GIVEN the date time to display is today\n' + 'THEN should display the time in the format HH:mm\n', + (WidgetTester tester) async { + const expectedDisplayText = '12:05'; + final currentTime = DateTime(2022, 1, 1); + final timeToTest = DateTime(2022, 1, 1, 12, 5); + + final textWidgetBuilder = Builder( + builder: (BuildContext context) { + final displayText = timeToTest.localizedTimeShort( + context, + currentTime: currentTime, + ); + + return Text( + displayText, + key: textWidgetKey, + ); + }, + ); + + await tester.binding.setLocale('en', 'US'); + await tester.pumpWidget( + MaterialApp( + localizationsDelegates: const [L10n.delegate], + home: textWidgetBuilder, + ), + ); + + final textWidgetFinder = find.byKey(textWidgetKey); + + expect(textWidgetFinder, findsOneWidget); + + final Text textWidget = tester.widget(textWidgetFinder) as Text; + + expect(textWidget.data, isNotNull); + + expect(textWidget.data, equals(expectedDisplayText)); + }); + + testWidgets( + 'GIVEN the date time to display is Monday of current week\n' + 'THEN should display the Monday\n', (WidgetTester tester) async { + const expectedDisplayText = 'Monday'; + final currentTime = DateTime(2022, 1, 1); + final timeToTest = DateTime(2021, 12, 27, 12, 5); + + final textWidgetBuilder = Builder( + builder: (BuildContext context) { + final displayText = timeToTest.localizedTimeShort( + context, + currentTime: currentTime, + ); + + return Text( + displayText, + key: textWidgetKey, + ); + }, + ); + + await tester.binding.setLocale('en', 'US'); + await tester.pumpWidget( + MaterialApp( + localizationsDelegates: const [L10n.delegate], + home: textWidgetBuilder, + ), + ); + + final textWidgetFinder = find.byKey(textWidgetKey); + + expect(textWidgetFinder, findsOneWidget); + + final Text textWidget = tester.widget(textWidgetFinder) as Text; + + expect(textWidget.data, isNotNull); + + expect(textWidget.data, equals(expectedDisplayText)); + }); + + testWidgets( + 'GIVEN the date time to display is Tuesday of current week\n' + 'THEN should display Tuesday\n', (WidgetTester tester) async { + const expectedDisplayText = 'Tuesday'; + final currentTime = DateTime(2022, 1, 1); + final timeToTest = DateTime(2021, 12, 28, 12, 5); + + final textWidgetBuilder = Builder( + builder: (BuildContext context) { + final displayText = timeToTest.localizedTimeShort( + context, + currentTime: currentTime, + ); + + return Text( + displayText, + key: textWidgetKey, + ); + }, + ); + + await tester.binding.setLocale('en', 'US'); + await tester.pumpWidget( + MaterialApp( + localizationsDelegates: const [L10n.delegate], + home: textWidgetBuilder, + ), + ); + + final textWidgetFinder = find.byKey(textWidgetKey); + + expect(textWidgetFinder, findsOneWidget); + + final Text textWidget = tester.widget(textWidgetFinder) as Text; + + expect(textWidget.data, isNotNull); + + expect(textWidget.data, equals(expectedDisplayText)); + }); + + testWidgets( + 'GIVEN the date time to display is Wednesday of current week\n' + 'THEN should display Wednesday\n', (WidgetTester tester) async { + const expectedDisplayText = 'Wednesday'; + final currentTime = DateTime(2022, 1, 1); + final timeToTest = DateTime(2021, 12, 29, 12, 5); + + final textWidgetBuilder = Builder( + builder: (BuildContext context) { + final displayText = timeToTest.localizedTimeShort( + context, + currentTime: currentTime, + ); + + return Text( + displayText, + key: textWidgetKey, + ); + }, + ); + + await tester.binding.setLocale('en', 'US'); + await tester.pumpWidget( + MaterialApp( + localizationsDelegates: const [L10n.delegate], + home: textWidgetBuilder, + ), + ); + + final textWidgetFinder = find.byKey(textWidgetKey); + + expect(textWidgetFinder, findsOneWidget); + + final Text textWidget = tester.widget(textWidgetFinder) as Text; + + expect(textWidget.data, isNotNull); + + expect(textWidget.data, equals(expectedDisplayText)); + }); + + testWidgets( + 'GIVEN the date time to display is Thursday of current week\n' + 'THEN should display Thursday\n', (WidgetTester tester) async { + const expectedDisplayText = 'Thursday'; + final currentTime = DateTime(2022, 1, 1); + final timeToTest = DateTime(2021, 12, 30, 12, 5); + + final textWidgetBuilder = Builder( + builder: (BuildContext context) { + final displayText = timeToTest.localizedTimeShort( + context, + currentTime: currentTime, + ); + + return Text( + displayText, + key: textWidgetKey, + ); + }, + ); + + await tester.binding.setLocale('en', 'US'); + await tester.pumpWidget( + MaterialApp( + localizationsDelegates: const [L10n.delegate], + home: textWidgetBuilder, + ), + ); + + final textWidgetFinder = find.byKey(textWidgetKey); + + expect(textWidgetFinder, findsOneWidget); + + final Text textWidget = tester.widget(textWidgetFinder) as Text; + + expect(textWidget.data, isNotNull); + + expect(textWidget.data, equals(expectedDisplayText)); + }); + + testWidgets( + 'GIVEN the date time to display is Friday of current week\n' + 'THEN should display Friday\n', (WidgetTester tester) async { + const expectedDisplayText = 'Friday'; + final currentTime = DateTime(2022, 1, 1); + final timeToTest = DateTime(2021, 12, 31, 12, 5); + + final textWidgetBuilder = Builder( + builder: (BuildContext context) { + final displayText = timeToTest.localizedTimeShort( + context, + currentTime: currentTime, + ); + + return Text( + displayText, + key: textWidgetKey, + ); + }, + ); + + await tester.binding.setLocale('en', 'US'); + await tester.pumpWidget( + MaterialApp( + localizationsDelegates: const [L10n.delegate], + home: textWidgetBuilder, + ), + ); + + final textWidgetFinder = find.byKey(textWidgetKey); + + expect(textWidgetFinder, findsOneWidget); + + final Text textWidget = tester.widget(textWidgetFinder) as Text; + + expect(textWidget.data, isNotNull); + + expect(textWidget.data, equals(expectedDisplayText)); + }); + + testWidgets( + 'GIVEN the date time to display is Saturday of current week\n' + 'THEN should display Saturday\n', (WidgetTester tester) async { + const expectedDisplayText = 'Saturday'; + final currentTime = DateTime(2024, 2, 25); + final timeToTest = DateTime(2024, 2, 24, 12, 5); + + final textWidgetBuilder = Builder( + builder: (BuildContext context) { + final displayText = timeToTest.localizedTimeShort( + context, + currentTime: currentTime, + ); + + return Text( + displayText, + key: textWidgetKey, + ); + }, + ); + + await tester.binding.setLocale('en', 'US'); + await tester.pumpWidget( + MaterialApp( + localizationsDelegates: const [L10n.delegate], + home: textWidgetBuilder, + ), + ); + + final textWidgetFinder = find.byKey(textWidgetKey); + + expect(textWidgetFinder, findsOneWidget); + + final Text textWidget = tester.widget(textWidgetFinder) as Text; + + expect(textWidget.data, isNotNull); + + expect(textWidget.data, equals(expectedDisplayText)); + }); + + testWidgets( + 'GIVEN the date time to display is Sunday of current week\n' + 'THEN should display Sunday\n', (WidgetTester tester) async { + const expectedDisplayText = 'Sunday'; + final currentTime = DateTime(2022, 1, 1); + final timeToTest = DateTime(2022, 1, 2, 12, 5); + + final textWidgetBuilder = Builder( + builder: (BuildContext context) { + final displayText = timeToTest.localizedTimeShort( + context, + currentTime: currentTime, + ); + + return Text( + displayText, + key: textWidgetKey, + ); + }, + ); + + await tester.binding.setLocale('en', 'US'); + await tester.pumpWidget( + MaterialApp( + localizationsDelegates: const [L10n.delegate], + home: textWidgetBuilder, + ), + ); + + final textWidgetFinder = find.byKey(textWidgetKey); + + expect(textWidgetFinder, findsOneWidget); + + final Text textWidget = tester.widget(textWidgetFinder) as Text; + + expect(textWidget.data, isNotNull); + + expect(textWidget.data, equals(expectedDisplayText)); + }); + + testWidgets( + 'GIVEN the date time to display is not in the same week\n' + 'AND in the same year\n' + 'THEN should display the date in the format MMM d\n', + (WidgetTester tester) async { + const expectedDisplayText = 'Feb 22'; + final currentTime = DateTime(2024, 2, 28); + final timeToTest = DateTime(2024, 2, 22, 12, 5); + + final textWidgetBuilder = Builder( + builder: (BuildContext context) { + final displayText = timeToTest.localizedTimeShort( + context, + currentTime: currentTime, + ); + + return Text( + displayText, + key: textWidgetKey, + ); + }, + ); + + await tester.binding.setLocale('en', 'US'); + await tester.pumpWidget( + MaterialApp( + localizationsDelegates: const [L10n.delegate], + home: textWidgetBuilder, + ), + ); + + final textWidgetFinder = find.byKey(textWidgetKey); + + expect(textWidgetFinder, findsOneWidget); + + final Text textWidget = tester.widget(textWidgetFinder) as Text; + + expect(textWidget.data, isNotNull); + + expect(textWidget.data, equals(expectedDisplayText)); + }); + + testWidgets( + 'GIVEN the date time to display is not in the same week\n' + 'AND in the same year\n' + 'THEN should display the date in the format MMM d\n', + (WidgetTester tester) async { + const expectedDisplayText = 'Feb 25'; + final currentTime = DateTime(2024, 2, 28); + final timeToTest = DateTime(2024, 2, 25, 12, 5); + + final textWidgetBuilder = Builder( + builder: (BuildContext context) { + final displayText = timeToTest.localizedTimeShort( + context, + currentTime: currentTime, + ); + + return Text( + displayText, + key: textWidgetKey, + ); + }, + ); + + await tester.binding.setLocale('en', 'US'); + await tester.pumpWidget( + MaterialApp( + localizationsDelegates: const [L10n.delegate], + home: textWidgetBuilder, + ), + ); + + final textWidgetFinder = find.byKey(textWidgetKey); + + expect(textWidgetFinder, findsOneWidget); + + final Text textWidget = tester.widget(textWidgetFinder) as Text; + + expect(textWidget.data, isNotNull); + + expect(textWidget.data, equals(expectedDisplayText)); + }); + + testWidgets( + 'GIVEN the date time to display is not in the same week\n' + 'AND in the same year\n' + 'THEN should display the date in the format MMM d\n', + (WidgetTester tester) async { + const expectedDisplayText = 'Feb 24'; + final currentTime = DateTime(2024, 2, 28); + final timeToTest = DateTime(2024, 2, 24, 12, 5); + + final textWidgetBuilder = Builder( + builder: (BuildContext context) { + final displayText = timeToTest.localizedTimeShort( + context, + currentTime: currentTime, + ); + + return Text( + displayText, + key: textWidgetKey, + ); + }, + ); + + await tester.binding.setLocale('en', 'US'); + await tester.pumpWidget( + MaterialApp( + localizationsDelegates: const [L10n.delegate], + home: textWidgetBuilder, + ), + ); + + final textWidgetFinder = find.byKey(textWidgetKey); + + expect(textWidgetFinder, findsOneWidget); + + final Text textWidget = tester.widget(textWidgetFinder) as Text; + + expect(textWidget.data, isNotNull); + + expect(textWidget.data, equals(expectedDisplayText)); + }); + + testWidgets( + 'GIVEN the date time to display is not in the same week\n' + 'AND in the same year\n' + 'THEN should display the date in the format MMM d\n', + (WidgetTester tester) async { + const expectedDisplayText = 'Feb 25'; + final currentTime = DateTime(2024, 2, 26); + final timeToTest = DateTime(2024, 2, 25, 12, 5); + + final textWidgetBuilder = Builder( + builder: (BuildContext context) { + final displayText = timeToTest.localizedTimeShort( + context, + currentTime: currentTime, + ); + + return Text( + displayText, + key: textWidgetKey, + ); + }, + ); + + await tester.binding.setLocale('en', 'US'); + await tester.pumpWidget( + MaterialApp( + localizationsDelegates: const [L10n.delegate], + home: textWidgetBuilder, + ), + ); + + final textWidgetFinder = find.byKey(textWidgetKey); + + expect(textWidgetFinder, findsOneWidget); + + final Text textWidget = tester.widget(textWidgetFinder) as Text; + + expect(textWidget.data, isNotNull); + + expect(textWidget.data, equals(expectedDisplayText)); + }); + + testWidgets( + 'GIVEN the date time to display is not in the same week\n' + 'AND in the same year\n' + 'THEN should display the date in the format MMM d\n', + (WidgetTester tester) async { + const expectedDisplayText = 'Feb 24'; + final currentTime = DateTime(2024, 2, 26); + final timeToTest = DateTime(2024, 2, 24, 12, 5); + + final textWidgetBuilder = Builder( + builder: (BuildContext context) { + final displayText = timeToTest.localizedTimeShort( + context, + currentTime: currentTime, + ); + + return Text( + displayText, + key: textWidgetKey, + ); + }, + ); + + await tester.binding.setLocale('en', 'US'); + await tester.pumpWidget( + MaterialApp( + localizationsDelegates: const [L10n.delegate], + home: textWidgetBuilder, + ), + ); + + final textWidgetFinder = find.byKey(textWidgetKey); + + expect(textWidgetFinder, findsOneWidget); + + final Text textWidget = tester.widget(textWidgetFinder) as Text; + + expect(textWidget.data, isNotNull); + + expect(textWidget.data, equals(expectedDisplayText)); + }); + + testWidgets( + 'GIVEN the date time to display is not in the same week\n' + 'AND in the same year\n' + 'THEN should display the date in the format MMM d\n', + (WidgetTester tester) async { + const expectedDisplayText = 'Feb 23'; + final currentTime = DateTime(2024, 2, 26); + final timeToTest = DateTime(2024, 2, 23, 12, 5); + + final textWidgetBuilder = Builder( + builder: (BuildContext context) { + final displayText = timeToTest.localizedTimeShort( + context, + currentTime: currentTime, + ); + + return Text( + displayText, + key: textWidgetKey, + ); + }, + ); + + await tester.binding.setLocale('en', 'US'); + await tester.pumpWidget( + MaterialApp( + localizationsDelegates: const [L10n.delegate], + home: textWidgetBuilder, + ), + ); + + final textWidgetFinder = find.byKey(textWidgetKey); + + expect(textWidgetFinder, findsOneWidget); + + final Text textWidget = tester.widget(textWidgetFinder) as Text; + + expect(textWidget.data, isNotNull); + + expect(textWidget.data, equals(expectedDisplayText)); + }); + + testWidgets( + 'GIVEN the date time to display is not in the same week\n' + 'AND not in the same year\n' + 'THEN should display the date in the format dd/MM/yy\n', + (WidgetTester tester) async { + const expectedDisplayText = '22/02/23'; + final currentTime = DateTime(2024, 2, 28); + final timeToTest = DateTime(2023, 2, 22, 12, 5); + + final textWidgetBuilder = Builder( + builder: (BuildContext context) { + final displayText = timeToTest.localizedTimeShort( + context, + currentTime: currentTime, + ); + + return Text( + displayText, + key: textWidgetKey, + ); + }, + ); + + await tester.binding.setLocale('en', 'US'); + await tester.pumpWidget( + MaterialApp( + localizationsDelegates: const [L10n.delegate], + home: textWidgetBuilder, + ), + ); + + final textWidgetFinder = find.byKey(textWidgetKey); + + expect(textWidgetFinder, findsOneWidget); + + final Text textWidget = tester.widget(textWidgetFinder) as Text; + + expect(textWidget.data, isNotNull); + + expect(textWidget.data, equals(expectedDisplayText)); + }); + }); + + group('[isInCurrentWeek TEST]', () { + final currentTime = DateTime(2022, 1, 1); + test( + 'GIVEN time to check is in current week\n' + 'THEN return true', () { + final timeToTest = DateTime(2021, 12, 27, 12, 5); + + final result = timeToTest.isInCurrentWeek(currentTime: currentTime); + + expect(result, isTrue); + }); + + test( + 'GIVEN time to check is not in current week\n' + 'THEN return false', () { + final timeToTest = DateTime(2021, 12, 20, 12, 5); + + final result = timeToTest.isInCurrentWeek(currentTime: currentTime); + + expect(result, isFalse); + }); + }); +}