// 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. import 'package:flutter/material.dart'; import 'package:flutter_api_samples/material/segmented_button/segmented_button.1.dart' as example; import 'package:flutter_test/flutter_test.dart'; void main() { testWidgets('Can use SegmentedButton.styleFrom to customize SegmentedButton', ( WidgetTester tester, ) async { await tester.pumpWidget(const example.SegmentedButtonApp()); final Color unselectedBackgroundColor = Colors.grey[200]!; const Color unselectedForegroundColor = Colors.red; const Color selectedBackgroundColor = Colors.green; const Color selectedForegroundColor = Colors.white; Material getMaterial(String text) { return tester.widget( find.ancestor(of: find.text(text), matching: find.byType(Material)).first, ); } // Verify the unselected button style. expect(getMaterial('Day').textStyle?.color, unselectedForegroundColor); expect(getMaterial('Day').color, unselectedBackgroundColor); // Verify the selected button style. expect(getMaterial('Week').textStyle?.color, selectedForegroundColor); expect(getMaterial('Week').color, selectedBackgroundColor); }); }