Unverified Commit 6157c0e8 authored by Callum Moffat's avatar Callum Moffat Committed by GitHub

Remove controller listener on CupertinoPicker dispose (#111977)

parent 30ebb0d9
...@@ -513,4 +513,10 @@ class _RenderCupertinoPickerSemantics extends RenderProxyBox { ...@@ -513,4 +513,10 @@ class _RenderCupertinoPickerSemantics extends RenderProxyBox {
} }
node.updateWith(config: config); node.updateWith(config: config);
} }
@override
void dispose() {
super.dispose();
controller.removeListener(_handleScrollUpdate);
}
} }
...@@ -11,6 +11,12 @@ import 'package:flutter_test/flutter_test.dart'; ...@@ -11,6 +11,12 @@ import 'package:flutter_test/flutter_test.dart';
import '../rendering/mock_canvas.dart'; import '../rendering/mock_canvas.dart';
class SpyFixedExtentScrollController extends FixedExtentScrollController {
/// Override for test visibility only.
@override
bool get hasListeners => super.hasListeners;
}
void main() { void main() {
testWidgets('Picker respects theme styling', (WidgetTester tester) async { testWidgets('Picker respects theme styling', (WidgetTester tester) async {
await tester.pumpWidget( await tester.pumpWidget(
...@@ -490,4 +496,36 @@ void main() { ...@@ -490,4 +496,36 @@ void main() {
expect(borderRadius, isA<BorderRadiusDirectional>()); expect(borderRadius, isA<BorderRadiusDirectional>());
}); });
}); });
testWidgets('Scroll controller is detached upon dispose', (WidgetTester tester) async {
final SpyFixedExtentScrollController controller = SpyFixedExtentScrollController();
expect(controller.hasListeners, false);
expect(controller.positions.length, 0);
await tester.pumpWidget(CupertinoApp(
home: Align(
alignment: Alignment.topLeft,
child: Center(
child: CupertinoPicker(
scrollController: controller,
itemExtent: 50.0,
onSelectedItemChanged: (_) { },
children: List<Widget>.generate(3, (int index) {
return SizedBox(
width: 300.0,
child: Text(index.toString()),
);
}),
),
),
),
));
expect(controller.hasListeners, true);
expect(controller.positions.length, 1);
await tester.pumpWidget(const SizedBox.expand());
expect(controller.hasListeners, false);
expect(controller.positions.length, 0);
});
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment