Unverified Commit 729ba11b authored by Tong Mu's avatar Tong Mu Committed by GitHub

Add doc and test for Container's hitTest behavior (#57522)

parent 0bda6335
...@@ -184,6 +184,11 @@ class DecoratedBox extends SingleChildRenderObjectWidget { ...@@ -184,6 +184,11 @@ class DecoratedBox extends SingleChildRenderObjectWidget {
/// `width`, `height`, and [constraints] arguments to the constructor override /// `width`, `height`, and [constraints] arguments to the constructor override
/// this. /// this.
/// ///
/// By default, containers return false for all hit tests. If the [color]
/// property is specified, the hit testing is handled by [ColoredBox], which
/// always returns true. If the [decoration] or [foregroundDecoration] properties
/// are specified, hit testing is handled by [Decoration.hitTest].
///
/// ## Layout behavior /// ## Layout behavior
/// ///
/// _See [BoxConstraints] for an introduction to box layout models._ /// _See [BoxConstraints] for an introduction to box layout models._
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
// Use of this source code is governed by a BSD-style license that can be // Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file. // found in the LICENSE file.
import 'package:flutter/material.dart';
import 'package:flutter_test/flutter_test.dart'; import 'package:flutter_test/flutter_test.dart';
import 'package:flutter/widgets.dart'; import 'package:flutter/widgets.dart';
import 'package:mockito/mockito.dart'; import 'package:mockito/mockito.dart';
...@@ -502,6 +503,60 @@ void main() { ...@@ -502,6 +503,60 @@ void main() {
findsOneWidget, findsOneWidget,
); );
}); });
testWidgets('Container is hittable only when having decorations', (WidgetTester tester) async {
bool tapped = false;
await tester.pumpWidget(GestureDetector(
onTap: () { tapped = true; },
child: Container(
decoration: const BoxDecoration(color: Colors.black),
),
));
await tester.tap(find.byType(Container));
expect(tapped, true);
tapped = false;
await tester.pumpWidget(GestureDetector(
onTap: () { tapped = true; },
child: Container(
foregroundDecoration: const BoxDecoration(color: Colors.black),
),
));
await tester.tap(find.byType(Container));
expect(tapped, true);
tapped = false;
await tester.pumpWidget(GestureDetector(
onTap: () { tapped = true; },
child: Container(
color: Colors.black,
),
));
await tester.tap(find.byType(Container));
expect(tapped, true);
tapped = false;
// Everything but color or decorations
await tester.pumpWidget(GestureDetector(
onTap: () { tapped = true; },
child: Center(
child: Container(
alignment: Alignment.bottomRight,
padding: const EdgeInsets.all(2),
width: 50,
height: 50,
margin: const EdgeInsets.all(2),
transform: Matrix4.rotationZ(1),
),
),
));
await tester.tap(find.byType(Container));
expect(tapped, false);
});
} }
class _MockPaintingContext extends Mock implements PaintingContext {} class _MockPaintingContext extends Mock implements PaintingContext {}
......
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