mirror of
https://github.com/flutter/flutter.git
synced 2026-02-20 02:29:02 +08:00
Bumps the Dart version to 3.8 across the repo (excluding engine/src/flutter/third_party) and applies formatting updates from Dart 3.8. ## Pre-launch Checklist - [x] I read the [Contributor Guide] and followed the process outlined there for submitting PRs. - [x] I read the [Tree Hygiene] wiki page, which explains my responsibilities. - [x] I read and followed the [Flutter Style Guide], including [Features we expect every widget to implement]. - [x] I signed the [CLA]. - [ ] I listed at least one issue that this PR fixes in the description above. - [ ] I updated/added relevant documentation (doc comments with `///`). - [x] I added new tests to check the change I am making, or this PR is [test-exempt]. - [x] I followed the [breaking change policy] and added [Data Driven Fixes] where supported. - [x] All existing and new tests are passing. If you need help, consider asking for advice on the #hackers-new channel on [Discord]. <!-- Links --> [Contributor Guide]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md#overview [Tree Hygiene]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md [test-exempt]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md#tests [Flutter Style Guide]: https://github.com/flutter/flutter/blob/main/docs/contributing/Style-guide-for-Flutter-repo.md [Features we expect every widget to implement]: https://github.com/flutter/flutter/blob/main/docs/contributing/Style-guide-for-Flutter-repo.md#features-we-expect-every-widget-to-implement [CLA]: https://cla.developers.google.com/ [flutter/tests]: https://github.com/flutter/tests [breaking change policy]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md#handling-breaking-changes [Discord]: https://github.com/flutter/flutter/blob/main/docs/contributing/Chat.md [Data Driven Fixes]: https://github.com/flutter/flutter/blob/main/docs/contributing/Data-driven-Fixes.md
85 lines
2.9 KiB
Dart
85 lines
2.9 KiB
Dart
// Copyright 2014 The Flutter Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter/rendering.dart';
|
|
import 'package:flutter_test/flutter_test.dart';
|
|
import 'package:leak_tracker_flutter_testing/leak_tracker_flutter_testing.dart';
|
|
|
|
void main() {
|
|
testWidgets('runApp uses deprecated pipelineOwner and renderView', (WidgetTester tester) async {
|
|
runApp(const SizedBox());
|
|
final RenderObject renderObject = tester.renderObject(find.byType(SizedBox));
|
|
|
|
RenderObject parent = renderObject;
|
|
while (parent.parent != null) {
|
|
parent = parent.parent!;
|
|
}
|
|
expect(parent, isA<RenderView>());
|
|
expect(parent, equals(tester.binding.renderView));
|
|
|
|
expect(renderObject.owner, equals(tester.binding.pipelineOwner));
|
|
});
|
|
|
|
testWidgets('can manually attach RootWidget to build owner', (WidgetTester tester) async {
|
|
expect(find.byType(ColoredBox), findsNothing);
|
|
|
|
final RootWidget rootWidget = RootWidget(
|
|
child: View(
|
|
view: FakeFlutterView(tester.view),
|
|
child: const ColoredBox(color: Colors.orange),
|
|
),
|
|
);
|
|
tester.binding.attachToBuildOwner(rootWidget);
|
|
await tester.pump();
|
|
expect(find.byType(ColoredBox), findsOneWidget);
|
|
expect(tester.binding.rootElement!.widget, equals(rootWidget));
|
|
expect(tester.element(find.byType(ColoredBox)).owner, equals(tester.binding.buildOwner));
|
|
});
|
|
|
|
testWidgets(
|
|
'runApp throws if given a View',
|
|
experimentalLeakTesting: LeakTesting.settings
|
|
.withIgnoredAll(), // The test leaks by design because of exception.
|
|
(WidgetTester tester) async {
|
|
runApp(View(view: FakeFlutterView(tester.view), child: const SizedBox.shrink()));
|
|
expect(
|
|
tester.takeException(),
|
|
isFlutterError.having(
|
|
(FlutterError e) => e.message,
|
|
'message',
|
|
contains('passing it to "runWidget" instead of "runApp"'),
|
|
),
|
|
);
|
|
},
|
|
);
|
|
|
|
testWidgets('runWidget throws if not given a View', (WidgetTester tester) async {
|
|
runWidget(const SizedBox.shrink());
|
|
expect(
|
|
tester.takeException(),
|
|
isFlutterError.having(
|
|
(FlutterError e) => e.message,
|
|
'message',
|
|
contains('Try wrapping your widget in a View widget'),
|
|
),
|
|
);
|
|
});
|
|
|
|
testWidgets('runWidget does not throw if given a View', (WidgetTester tester) async {
|
|
runWidget(View(view: FakeFlutterView(tester.view), child: const SizedBox.shrink()));
|
|
expect(find.byType(View), findsOne);
|
|
});
|
|
|
|
testWidgets('can call runWidget with an empty ViewCollection', (WidgetTester tester) async {
|
|
runWidget(const ViewCollection(views: <Widget>[]));
|
|
expect(find.byType(ViewCollection), findsOne);
|
|
});
|
|
}
|
|
|
|
class FakeFlutterView extends TestFlutterView {
|
|
FakeFlutterView(TestFlutterView view)
|
|
: super(view: view, display: view.display, platformDispatcher: view.platformDispatcher);
|
|
}
|