blob: 885bf0e722f4a0a9011093aafa53fb92fdac67e1 [file] [log] [blame]
// 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<Material>(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);
});
}