From 96dd1984ecc57311dc6c31b5c4ab0cbc0443b4aa Mon Sep 17 00:00:00 2001 From: Valentin Vignal <32538273+ValentinVignal@users.noreply.github.com> Date: Thu, 7 Mar 2024 09:51:54 +0800 Subject: [PATCH] Fix memory leak in `editable_gesture_test.dart` (#144691) --- .../test/rendering/editable_gesture_test.dart | 22 ++++++++++--------- 1 file changed, 12 insertions(+), 10 deletions(-) diff --git a/packages/flutter/test/rendering/editable_gesture_test.dart b/packages/flutter/test/rendering/editable_gesture_test.dart index b829380b853..67de99f3273 100644 --- a/packages/flutter/test/rendering/editable_gesture_test.dart +++ b/packages/flutter/test/rendering/editable_gesture_test.dart @@ -6,23 +6,21 @@ import 'package:flutter/gestures.dart'; 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() { final TestWidgetsFlutterBinding binding = _GestureBindingSpy(); - testWidgets('attach and detach correctly handle gesture', - // TODO(polina-c): clean up leaks, https://github.com/flutter/flutter/issues/134787 - experimentalLeakTesting: LeakTesting.settings.withIgnoredAll(), - (_) async { + testWidgets('attach and detach correctly handle gesture', (_) async { expect(WidgetsBinding.instance, binding); final TextSelectionDelegate delegate = FakeEditableTextState(); + final ViewportOffset offset = ViewportOffset.zero(); + addTearDown(offset.dispose); final RenderEditable editable = RenderEditable( backgroundCursorColor: Colors.grey, selectionColor: Colors.black, textDirection: TextDirection.ltr, cursorColor: Colors.red, - offset: ViewportOffset.zero(), + offset: offset, textSelectionDelegate: delegate, text: const TextSpan( text: 'test', @@ -36,13 +34,17 @@ void main() { affinity: TextAffinity.upstream, ), ); + addTearDown(editable.dispose); editable.layout(BoxConstraints.loose(const Size(1000.0, 1000.0))); - final PipelineOwner owner = PipelineOwner(onNeedVisualUpdate: () { }); - final _PointerRouterSpy spy = GestureBinding.instance.pointerRouter as _PointerRouterSpy; + final PipelineOwner owner = PipelineOwner(onNeedVisualUpdate: () {}); + addTearDown(owner.dispose); + final _PointerRouterSpy spy = + GestureBinding.instance.pointerRouter as _PointerRouterSpy; editable.attach(owner); // This should register pointer into GestureBinding.instance.pointerRouter. - editable.handleEvent(const PointerDownEvent(), BoxHitTestEntry(editable, const Offset(10,10))); + editable.handleEvent(const PointerDownEvent(), + BoxHitTestEntry(editable, const Offset(10, 10))); GestureBinding.instance.pointerRouter.route(const PointerDownEvent()); expect(spy.routeCount, greaterThan(0)); editable.detach(); @@ -57,7 +59,7 @@ class _GestureBindingSpy extends AutomatedTestWidgetsFlutterBinding { PointerRouter get pointerRouter => _testPointerRouter; } -class FakeEditableTextState extends Fake implements TextSelectionDelegate { } +class FakeEditableTextState extends Fake implements TextSelectionDelegate {} class _PointerRouterSpy extends PointerRouter { int routeCount = 0;