mirror of
https://github.com/foss42/apidash.git
synced 2025-06-10 15:24:32 +08:00
Update popup_menu_uri_test.dart
This commit is contained in:
@ -1,36 +1,35 @@
|
|||||||
|
import 'package:apidash_core/apidash_core.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_test/flutter_test.dart';
|
import 'package:flutter_test/flutter_test.dart';
|
||||||
import 'package:apidash/widgets/popup_menu_uri.dart';
|
import 'package:apidash/widgets/popup_menu_uri.dart';
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
testWidgets('URIPopupMenu displays initial value',
|
testWidgets('DefaultUriSchemePopupMenu displays initial value',
|
||||||
(WidgetTester tester) async {
|
(WidgetTester tester) async {
|
||||||
const uriScheme = 'https';
|
const uriScheme = SupportedUriSchemes.https;
|
||||||
|
|
||||||
await tester.pumpWidget(
|
await tester.pumpWidget(
|
||||||
const MaterialApp(
|
const MaterialApp(
|
||||||
home: Scaffold(
|
home: Scaffold(
|
||||||
body: URIPopupMenu(
|
body: DefaultUriSchemePopupMenu(
|
||||||
value: uriScheme,
|
value: uriScheme,
|
||||||
items: [uriScheme],
|
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
expect(find.text(uriScheme), findsOneWidget);
|
expect(find.text(uriScheme.name), findsOneWidget);
|
||||||
});
|
});
|
||||||
|
|
||||||
testWidgets('URIPopupMenu displays popup menu items',
|
testWidgets('DefaultUriSchemePopupMenu displays popup menu items',
|
||||||
(WidgetTester tester) async {
|
(WidgetTester tester) async {
|
||||||
const uriScheme1 = 'https';
|
const uriScheme1 = SupportedUriSchemes.https;
|
||||||
const uriScheme2 = 'http';
|
const uriScheme2 = SupportedUriSchemes.http;
|
||||||
|
|
||||||
await tester.pumpWidget(
|
await tester.pumpWidget(
|
||||||
const MaterialApp(
|
const MaterialApp(
|
||||||
home: Scaffold(
|
home: Scaffold(
|
||||||
body: URIPopupMenu(
|
body: DefaultUriSchemePopupMenu(
|
||||||
items: [uriScheme1, uriScheme2],
|
|
||||||
value: uriScheme1,
|
value: uriScheme1,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
@ -40,22 +39,22 @@ void main() {
|
|||||||
await tester.tap(find.byIcon(Icons.unfold_more));
|
await tester.tap(find.byIcon(Icons.unfold_more));
|
||||||
await tester.pumpAndSettle();
|
await tester.pumpAndSettle();
|
||||||
|
|
||||||
expect(find.text(uriScheme1), findsExactly(2));
|
expect(find.text(uriScheme1.name), findsExactly(2));
|
||||||
expect(find.text(uriScheme2), findsOneWidget);
|
expect(find.text(uriScheme2.name), findsOneWidget);
|
||||||
});
|
});
|
||||||
|
|
||||||
testWidgets('URIPopupMenu calls onChanged when an item is selected',
|
testWidgets(
|
||||||
|
'DefaultUriSchemePopupMenu calls onChanged when an item is selected',
|
||||||
(WidgetTester tester) async {
|
(WidgetTester tester) async {
|
||||||
const uriScheme1 = 'https';
|
const uriScheme1 = SupportedUriSchemes.https;
|
||||||
const uriScheme2 = 'http';
|
const uriScheme2 = SupportedUriSchemes.http;
|
||||||
String? selectedScheme;
|
SupportedUriSchemes? selectedScheme;
|
||||||
|
|
||||||
await tester.pumpWidget(
|
await tester.pumpWidget(
|
||||||
MaterialApp(
|
MaterialApp(
|
||||||
home: Scaffold(
|
home: Scaffold(
|
||||||
body: URIPopupMenu(
|
body: DefaultUriSchemePopupMenu(
|
||||||
value: uriScheme1,
|
value: uriScheme1,
|
||||||
items: const [uriScheme1, uriScheme2],
|
|
||||||
onChanged: (value) {
|
onChanged: (value) {
|
||||||
selectedScheme = value;
|
selectedScheme = value;
|
||||||
},
|
},
|
||||||
@ -67,7 +66,7 @@ void main() {
|
|||||||
await tester.tap(find.byIcon(Icons.unfold_more));
|
await tester.tap(find.byIcon(Icons.unfold_more));
|
||||||
await tester.pumpAndSettle();
|
await tester.pumpAndSettle();
|
||||||
|
|
||||||
await tester.tap(find.text(uriScheme2).last);
|
await tester.tap(find.text(uriScheme2.name).last);
|
||||||
await tester.pumpAndSettle();
|
await tester.pumpAndSettle();
|
||||||
|
|
||||||
expect(selectedScheme, uriScheme2);
|
expect(selectedScheme, uriScheme2);
|
||||||
|
Reference in New Issue
Block a user