segmented_button.1_test.dart 1.32 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
// 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);
  });
}