| // 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. |
| |
| // This file is run as part of a reduced test set in CI on Mac and Windows |
| // machines. |
| @Tags(<String>['reduced-test-set']) |
| library; |
| |
| import 'package:flutter/material.dart'; |
| import 'package:flutter/rendering.dart'; |
| import 'package:flutter_test/flutter_test.dart'; |
| |
| void main() { |
| testWidgets('PhysicalModel updates clipBehavior in updateRenderObject', (WidgetTester tester) async { |
| await tester.pumpWidget( |
| const MaterialApp(home: PhysicalModel(color: Colors.red)), |
| ); |
| |
| final RenderPhysicalModel renderPhysicalModel = tester.allRenderObjects.whereType<RenderPhysicalModel>().first; |
| |
| expect(renderPhysicalModel.clipBehavior, equals(Clip.none)); |
| |
| await tester.pumpWidget( |
| const MaterialApp(home: PhysicalModel(clipBehavior: Clip.antiAlias, color: Colors.red)), |
| ); |
| |
| expect(renderPhysicalModel.clipBehavior, equals(Clip.antiAlias)); |
| }); |
| |
| testWidgets('PhysicalShape updates clipBehavior in updateRenderObject', (WidgetTester tester) async { |
| await tester.pumpWidget( |
| const MaterialApp(home: PhysicalShape(color: Colors.red, clipper: ShapeBorderClipper(shape: CircleBorder()))), |
| ); |
| |
| final RenderPhysicalShape renderPhysicalShape = tester.allRenderObjects.whereType<RenderPhysicalShape>().first; |
| |
| expect(renderPhysicalShape.clipBehavior, equals(Clip.none)); |
| |
| await tester.pumpWidget( |
| const MaterialApp(home: PhysicalShape(clipBehavior: Clip.antiAlias, color: Colors.red, clipper: ShapeBorderClipper(shape: CircleBorder()))), |
| ); |
| |
| expect(renderPhysicalShape.clipBehavior, equals(Clip.antiAlias)); |
| }); |
| |
| testWidgets('PhysicalModel - clips when overflows and elevation is 0', (WidgetTester tester) async { |
| const Key key = Key('test'); |
| await tester.pumpWidget( |
| Theme( |
| data: ThemeData(useMaterial3: false), |
| child: const MediaQuery( |
| key: key, |
| data: MediaQueryData(), |
| child: Directionality( |
| textDirection: TextDirection.ltr, |
| child: Padding( |
| padding: EdgeInsets.all(50), |
| child: Row( |
| children: <Widget>[ |
| Material(child: Text('A long long long long long long long string')), |
| Material(child: Text('A long long long long long long long string')), |
| Material(child: Text('A long long long long long long long string')), |
| Material(child: Text('A long long long long long long long string')), |
| ], |
| ), |
| ), |
| ), |
| ), |
| ), |
| ); |
| |
| final dynamic exception = tester.takeException(); |
| expect(exception, isFlutterError); |
| // ignore: avoid_dynamic_calls |
| expect(exception.diagnostics.first.level, DiagnosticLevel.summary); |
| // ignore: avoid_dynamic_calls |
| expect(exception.diagnostics.first.toString(), startsWith('A RenderFlex overflowed by ')); |
| await expectLater( |
| find.byKey(key), |
| matchesGoldenFile('physical_model_overflow.png'), |
| ); |
| }); |
| } |