// Copyright 2018 The Chromium 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_test/flutter_test.dart'; const ShapeBorder defaultButtonShape = RoundedRectangleBorder(borderRadius: BorderRadius.all(Radius.circular(2.0))); const EdgeInsets defaultButtonPadding = EdgeInsets.only(left: 16.0, right: 16.0); const BoxConstraints defaultButtonConstraints = BoxConstraints(minWidth: 88.0, minHeight: 36.0); const Duration defaultButtonDuration = Duration(milliseconds: 200); void main() { group('RaisedButton', () { testWidgets('theme: ThemeData.light(), enabled: true', (WidgetTester tester) async { await tester.pumpWidget( MaterialApp( theme: ThemeData.light(), home: Center( child: RaisedButton( onPressed: () { }, // button.enabled == true child: const Text('button'), ) ), ), ); final RawMaterialButton raw = tester.widget<RawMaterialButton>(find.byType(RawMaterialButton)); expect(raw.textStyle.color, const Color(0xdd000000)); expect(raw.fillColor, const Color(0xffe0e0e0)); expect(raw.highlightColor, const Color(0x29000000)); // Was Color(0x66bcbcbc) expect(raw.splashColor, const Color(0x1f000000)); // Was Color(0x66c8c8c8) expect(raw.elevation, 2.0); expect(raw.highlightElevation, 8.0); expect(raw.disabledElevation, 0.0); expect(raw.constraints, defaultButtonConstraints); expect(raw.padding, defaultButtonPadding); expect(raw.shape, defaultButtonShape); expect(raw.animationDuration, defaultButtonDuration); expect(raw.materialTapTargetSize, MaterialTapTargetSize.padded); }); testWidgets('theme: ThemeData.light(), enabled: false', (WidgetTester tester) async { await tester.pumpWidget( MaterialApp( theme: ThemeData.light(), home: const Center( child: RaisedButton( onPressed: null, // button.enabled == false child: Text('button'), ) ), ), ); final RawMaterialButton raw = tester.widget<RawMaterialButton>(find.byType(RawMaterialButton)); expect(raw.textStyle.color, const Color(0x61000000)); expect(raw.fillColor, const Color(0x61000000)); // highlightColor, disabled button can't be pressed // splashColor, disabled button doesn't splash expect(raw.elevation, 2.0); expect(raw.highlightElevation, 8.0); expect(raw.disabledElevation, 0.0); expect(raw.constraints, defaultButtonConstraints); expect(raw.padding, defaultButtonPadding); expect(raw.shape, defaultButtonShape); expect(raw.animationDuration, defaultButtonDuration); expect(raw.materialTapTargetSize, MaterialTapTargetSize.padded); }); }); group('FlatButton', () { testWidgets('theme: ThemeData.light(), enabled: true', (WidgetTester tester) async { await tester.pumpWidget( MaterialApp( theme: ThemeData.light(), home: Center( child: FlatButton( onPressed: () { }, // button.enabled == true child: const Text('button'), ) ), ), ); final RawMaterialButton raw = tester.widget<RawMaterialButton>(find.byType(RawMaterialButton)); expect(raw.textStyle.color, const Color(0xdd000000)); expect(raw.fillColor, null); expect(raw.highlightColor, const Color(0x29000000)); // Was Color(0x66bcbcbc) expect(raw.splashColor, const Color(0x1f000000)); // Was Color(0x66c8c8c8) expect(raw.elevation, 0.0); expect(raw.highlightElevation, 0.0); expect(raw.disabledElevation, 0.0); expect(raw.constraints, defaultButtonConstraints); expect(raw.padding, defaultButtonPadding); expect(raw.shape, defaultButtonShape); expect(raw.animationDuration, defaultButtonDuration); expect(raw.materialTapTargetSize, MaterialTapTargetSize.padded); }); testWidgets('theme: ThemeData.light(), enabled: false', (WidgetTester tester) async { await tester.pumpWidget( MaterialApp( theme: ThemeData.light(), home: const Center( child: FlatButton( onPressed: null, // button.enabled == false child: Text('button'), ) ), ), ); final RawMaterialButton raw = tester.widget<RawMaterialButton>(find.byType(RawMaterialButton)); expect(raw.textStyle.color, const Color(0x61000000)); expect(raw.fillColor, null); // highlightColor, disabled button can't be pressed // splashColor, disabled button doesn't splash expect(raw.elevation, 0.0); expect(raw.highlightElevation, 0.0); expect(raw.disabledElevation, 0.0); expect(raw.constraints, defaultButtonConstraints); expect(raw.padding, defaultButtonPadding); expect(raw.shape, defaultButtonShape); expect(raw.animationDuration, const Duration(milliseconds: 200)); expect(raw.materialTapTargetSize, MaterialTapTargetSize.padded); }); }); group('OutlineButton', () { testWidgets('theme: ThemeData.light(), enabled: true', (WidgetTester tester) async { await tester.pumpWidget( MaterialApp( theme: ThemeData.light(), home: Center( child: OutlineButton( onPressed: () { }, // button.enabled == true child: const Text('button'), ) ), ), ); final RawMaterialButton raw = tester.widget<RawMaterialButton>(find.byType(RawMaterialButton)); expect(raw.textStyle.color, const Color(0xdd000000)); expect(raw.fillColor, const Color(0x00ffffff)); expect(raw.highlightColor, const Color(0x29000000)); // Was Color(0x66bcbcbc) expect(raw.splashColor, const Color(0x1f000000)); // Was Color(0x66c8c8c8) expect(raw.elevation, 0.0); expect(raw.highlightElevation, 0.0); expect(raw.disabledElevation, 0.0); expect(raw.constraints, defaultButtonConstraints); expect(raw.padding, defaultButtonPadding); // animationDuration can't be configed by the theme/constructor expect(raw.materialTapTargetSize, MaterialTapTargetSize.padded); }); testWidgets('theme: ThemeData.light(), enabled: false', (WidgetTester tester) async { await tester.pumpWidget( MaterialApp( theme: ThemeData.light(), home: const Center( child: OutlineButton( onPressed: null, // button.enabled == false child: Text('button'), ) ), ), ); final RawMaterialButton raw = tester.widget<RawMaterialButton>(find.byType(RawMaterialButton)); expect(raw.textStyle.color, const Color(0x61000000)); expect(raw.fillColor, const Color(0x00000000)); // highlightColor, disabled button can't be pressed // splashColor, disabled button doesn't splash expect(raw.elevation, 0.0); expect(raw.highlightElevation, 0.0); expect(raw.disabledElevation, 0.0); expect(raw.constraints, defaultButtonConstraints); expect(raw.padding, defaultButtonPadding); // animationDuration can't be configed by the theme/constructor expect(raw.materialTapTargetSize, MaterialTapTargetSize.padded); }); }); }