mirror of
https://github.com/flutter/samples.git
synced 2025-11-08 13:58:47 +00:00
* Update `simplistic_editor` for Flutter 3.4 beta * Re-enable beta and master CI * Disable on master * Added sample code for using plugins and channels from background isolates. * goderbauer feedback 1 * goderbauer feedback2 * goderbauer feedback 3 * Add `background_isolate_channels` to CI * Enable beta CI * Enable all `stable` CI projects * `dart fix --apply` * `print` -> `denugPrint` * Make deps min version not pinned * Drop `_isDebug` * Remove unused import * `dart format` * Fixup `linting_tool` * Fixup `form_app` * Enable all `master` CI * Basic fixes * Patch `simplistic_editor` * Fix nl at eol * Comment out `simplistic_editor` * Incorporating @bleroux's latest changes * Clean up CI scripts * Copy `experimental/material_3_demo` to top level * Update `game_template` * Update `animations` * Update `desktop_photo_search` * Update `flutter_maps_firestore` * Update `form_app` * Update `infinite_list` * Update `isolate_example` * Update `jsonexample` * Update `navigation_and_routing` * Update `place_tracker` * Update `platform_channels` * Update `platform_design` * Update `provider_shopper` * Fixup `context_menus` * `dart format` * Update the main `material_3_demo` * Make `tool/flutter_ci_script_stable.sh` executable again Co-authored-by: Bruno Leroux <bruno.leroux@gmail.com> Co-authored-by: Aaron Clarke <aaclarke@google.com>
87 lines
3.6 KiB
Dart
87 lines
3.6 KiB
Dart
// Copyright 2021 The Flutter team. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
// ignore_for_file: avoid_types_on_closure_parameters
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter_test/flutter_test.dart';
|
|
import 'package:material_3_demo/main.dart';
|
|
import 'package:material_3_demo/typography_screen.dart';
|
|
|
|
import 'component_screen_test.dart';
|
|
|
|
void main() {
|
|
testWidgets(
|
|
'Typography screen shows correctly when the corresponding icon is '
|
|
'selected on NavigationBar', (tester) async {
|
|
widgetSetup(tester, 449);
|
|
addTearDown(tester.binding.window.clearPhysicalSizeTestValue);
|
|
await tester.pumpWidget(const MaterialApp(home: Material3Demo()));
|
|
|
|
expect(find.text('Display Large'), findsNothing);
|
|
expect(find.byType(NavigationBar), findsOneWidget);
|
|
Finder textIconOnBar = find.descendant(
|
|
of: find.byType(NavigationBar),
|
|
matching: find.byIcon(Icons.text_snippet_outlined));
|
|
expect(textIconOnBar, findsOneWidget);
|
|
await tester.tap(textIconOnBar);
|
|
await tester.pumpAndSettle(const Duration(microseconds: 500));
|
|
expect(textIconOnBar, findsNothing);
|
|
Finder selectedTextIconOnBar = find.descendant(
|
|
of: find.byType(NavigationBar),
|
|
matching: find.byIcon(Icons.text_snippet));
|
|
expect(selectedTextIconOnBar, findsOneWidget);
|
|
expect(find.text('Display Large'), findsOneWidget);
|
|
});
|
|
|
|
testWidgets(
|
|
'Typography screen shows correctly when the corresponding icon is '
|
|
'selected on NavigationRail', (tester) async {
|
|
widgetSetup(
|
|
tester, 1200); // NavigationRail shows only when width is > 1000.
|
|
addTearDown(tester.binding.window.clearPhysicalSizeTestValue);
|
|
await tester.pumpWidget(const MaterialApp(home: Material3Demo()));
|
|
expect(find.text('Display Large'), findsNothing);
|
|
expect(find.byType(NavigationRail), findsOneWidget);
|
|
Finder textIconOnRail = find.descendant(
|
|
of: find.byType(NavigationRail),
|
|
matching: find.byIcon(Icons.text_snippet_outlined));
|
|
expect(textIconOnRail, findsOneWidget);
|
|
await tester.tap(textIconOnRail);
|
|
await tester.pumpAndSettle(const Duration(microseconds: 500));
|
|
expect(textIconOnRail, findsNothing);
|
|
Finder selectedTextIconOnRail = find.descendant(
|
|
of: find.byType(NavigationRail),
|
|
matching: find.byIcon(Icons.text_snippet));
|
|
expect(selectedTextIconOnRail, findsOneWidget);
|
|
expect(find.text('Display Large'), findsOneWidget);
|
|
});
|
|
|
|
testWidgets('Typography screen shows correct content', (tester) async {
|
|
await tester.pumpWidget(MaterialApp(
|
|
home: Scaffold(body: Row(children: const [TypographyScreen()])),
|
|
));
|
|
expect(find.text('Display Large'), findsOneWidget);
|
|
expect(find.text('Display Medium'), findsOneWidget);
|
|
expect(find.text('Display Small'), findsOneWidget);
|
|
expect(find.text('Headline Large'), findsOneWidget);
|
|
expect(find.text('Headline Medium'), findsOneWidget);
|
|
expect(find.text('Headline Small'), findsOneWidget);
|
|
expect(find.text('Title Large'), findsOneWidget);
|
|
expect(find.text('Title Medium'), findsOneWidget);
|
|
expect(find.text('Title Small'), findsOneWidget);
|
|
await tester.scrollUntilVisible(
|
|
find.text('Body Small'),
|
|
500.0,
|
|
);
|
|
expect(find.text('Label Large'), findsOneWidget);
|
|
expect(find.text('Label Medium'), findsOneWidget);
|
|
expect(find.text('Label Small'), findsOneWidget);
|
|
expect(find.text('Body Large'), findsOneWidget);
|
|
expect(find.text('Body Medium'), findsOneWidget);
|
|
expect(find.text('Body Small'), findsOneWidget);
|
|
|
|
expect(find.byType(TextStyleExample), findsNWidgets(15));
|
|
});
|
|
}
|