Skip to content
This repository has been archived by the owner on Dec 12, 2024. It is now read-only.

Add UI Tests for CurrencyDropdown Widget #312

Merged
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 0 additions & 1 deletion lib/features/currency/currency_dropdown.dart
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@ class CurrencyDropdown extends HookConsumerWidget {
Widget build(BuildContext context, WidgetRef ref) => Directionality(
textDirection: TextDirection.rtl,
child: ElevatedButton.icon(
key: const Key('currencyDropdownButton'),
icon: const Icon(Icons.keyboard_arrow_down),
label: _buildCurrencyLabel(context),
style: ElevatedButton.styleFrom(
Expand Down
51 changes: 19 additions & 32 deletions test/features/currency/currency_dropdown_test.dart
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import 'package:didpay/features/currency/currency_dropdown.dart';
import 'package:didpay/features/payment/payment_amount_state.dart';
import 'package:flutter/material.dart';
import 'package:flutter_test/flutter_test.dart';

import '../../helpers/test_data.dart';
import '../../helpers/widget_helpers.dart';

Expand All @@ -13,67 +13,54 @@ void main() async {
const testCurrency = 'USD';

setUp(() {
// Initialize mockState with a non-null offeringsMap
mockState = ValueNotifier<PaymentAmountState?>(
PaymentAmountState(
offeringsMap: TestData.getOfferingsMap(),
), // Use TestData as suggested
),
);
});

Widget createWidgetUnderTest() {
return WidgetHelpers.testableWidget(
// Use WidgetHelpers for consistent test setup
child: CurrencyDropdown(
paymentCurrency: testCurrency,
state: mockState,
),
);
}
Widget currencyDropdownTestWidget() => WidgetHelpers.testableWidget(
child: CurrencyDropdown(
paymentCurrency: testCurrency,
state: mockState,
),
);

testWidgets('CurrencyDropdown shows the correct initial currency',
testWidgets('should display the initial currency in CurrencyDropdown',
(tester) async {
await tester.pumpWidget(createWidgetUnderTest());
await tester.pumpWidget(currencyDropdownTestWidget());

// Check if the currency label displays the initial currency
expect(find.text(testCurrency), findsOneWidget);
});

testWidgets('CurrencyDropdown opens the Select Currency modal when tapped',
testWidgets('should open Select Currency modal on tap in CurrencyDropdown',
(tester) async {
await tester.pumpWidget(createWidgetUnderTest());
await tester.pumpWidget(currencyDropdownTestWidget());

// Tap on the currency dropdown button
await tester.tap(find.text(testCurrency));
await tester.pumpAndSettle(); // Wait for the modal to open

// Verify if the modal is displayed
await tester.pumpAndSettle();
expect(
find.text('Select currency'),
findsOneWidget,
); // Look for modal text or widget
);
});

testWidgets('CurrencyDropdown updates state when a currency is selected',
testWidgets(
'should update PaymentAmountState when a new offering is selected in CurrencyDropdown',
(tester) async {
await tester.pumpWidget(createWidgetUnderTest());
await tester.pumpWidget(currencyDropdownTestWidget());

// Open the modal by tapping on the currency dropdown button
await tester.tap(
find.text(testCurrency),
); // Using the 'USD' label text to find the button
);
await tester.pumpAndSettle();

// Simulate selecting a currency by updating the mockState directly
const selectedCurrency = 'EUR';
mockState.value = PaymentAmountState(
filterCurrency:
selectedCurrency, // Assuming 'filterCurrency' is the correct field for currency selection
);
await tester.tap(find.text(selectedCurrency));

await tester.pumpAndSettle();

// Verify the state reflects the selected currency
expect(mockState.value?.filterCurrency, selectedCurrency);
});
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hey @ethan-tbd check out this test case. It keeps on failing . How should I tackle it?

}
Loading