icon_test.dart 6.17 KB
Newer Older
Ian Hickson's avatar
Ian Hickson committed
1
// Copyright 2014 The Flutter Authors. All rights reserved.
2 3 4
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

5
import 'package:flutter/material.dart';
6 7
import 'package:flutter_test/flutter_test.dart';

8 9
import 'semantics_tester.dart';

10
void main() {
11 12
  testWidgets('Can set opacity for an Icon', (WidgetTester tester) async {
    await tester.pumpWidget(
Ian Hickson's avatar
Ian Hickson committed
13 14
      const Directionality(
        textDirection: TextDirection.ltr,
15 16 17
        child: IconTheme(
          data: IconThemeData(
            color: Color(0xFF666666),
18
            opacity: 0.5,
Ian Hickson's avatar
Ian Hickson committed
19
          ),
20
          child: Icon(IconData(0xd0a0, fontFamily: 'Arial')),
21
        ),
Ian Hickson's avatar
Ian Hickson committed
22
      ),
23
    );
24
    final RichText text = tester.widget(find.byType(RichText));
25
    expect(text.text.style!.color, const Color(0xFF666666).withOpacity(0.5));
26 27 28 29
  });

  testWidgets('Icon sizing - no theme, default size', (WidgetTester tester) async {
    await tester.pumpWidget(
Ian Hickson's avatar
Ian Hickson committed
30 31
      const Directionality(
        textDirection: TextDirection.ltr,
32 33
        child: Center(
          child: Icon(null),
Ian Hickson's avatar
Ian Hickson committed
34
        ),
35 36 37 38 39 40 41 42 43
      ),
    );

    final RenderBox renderObject = tester.renderObject(find.byType(Icon));
    expect(renderObject.size, equals(const Size.square(24.0)));
  });

  testWidgets('Icon sizing - no theme, explicit size', (WidgetTester tester) async {
    await tester.pumpWidget(
Ian Hickson's avatar
Ian Hickson committed
44 45
      const Directionality(
        textDirection: TextDirection.ltr,
46 47
        child: Center(
          child: Icon(
Ian Hickson's avatar
Ian Hickson committed
48 49 50
            null,
            size: 96.0,
          ),
51 52 53 54 55 56 57 58 59 60
        ),
      ),
    );

    final RenderBox renderObject = tester.renderObject(find.byType(Icon));
    expect(renderObject.size, equals(const Size.square(96.0)));
  });

  testWidgets('Icon sizing - sized theme', (WidgetTester tester) async {
    await tester.pumpWidget(
Ian Hickson's avatar
Ian Hickson committed
61 62
      const Directionality(
        textDirection: TextDirection.ltr,
63 64 65 66
        child: Center(
          child: IconTheme(
            data: IconThemeData(size: 36.0),
            child: Icon(null),
Ian Hickson's avatar
Ian Hickson committed
67
          ),
68 69 70 71 72 73 74 75 76 77
        ),
      ),
    );

    final RenderBox renderObject = tester.renderObject(find.byType(Icon));
    expect(renderObject.size, equals(const Size.square(36.0)));
  });

  testWidgets('Icon sizing - sized theme, explicit size', (WidgetTester tester) async {
    await tester.pumpWidget(
Ian Hickson's avatar
Ian Hickson committed
78 79
      const Directionality(
        textDirection: TextDirection.ltr,
80 81 82 83
        child: Center(
          child: IconTheme(
            data: IconThemeData(size: 36.0),
            child: Icon(
Ian Hickson's avatar
Ian Hickson committed
84 85 86
              null,
              size: 48.0,
            ),
87 88
          ),
        ),
89
      ),
90 91 92 93 94 95 96 97
    );

    final RenderBox renderObject = tester.renderObject(find.byType(Icon));
    expect(renderObject.size, equals(const Size.square(48.0)));
  });

  testWidgets('Icon sizing - sizeless theme, default size', (WidgetTester tester) async {
    await tester.pumpWidget(
Ian Hickson's avatar
Ian Hickson committed
98 99
      const Directionality(
        textDirection: TextDirection.ltr,
100 101 102 103
        child: Center(
          child: IconTheme(
            data: IconThemeData(),
            child: Icon(null),
Ian Hickson's avatar
Ian Hickson committed
104
          ),
105 106 107 108 109 110 111 112 113 114 115
        ),
      ),
    );

    final RenderBox renderObject = tester.renderObject(find.byType(Icon));
    expect(renderObject.size, equals(const Size.square(24.0)));
  });


  testWidgets('Icon with custom font', (WidgetTester tester) async {
    await tester.pumpWidget(
Ian Hickson's avatar
Ian Hickson committed
116 117
      const Directionality(
        textDirection: TextDirection.ltr,
118 119
        child: Center(
          child: Icon(IconData(0x41, fontFamily: 'Roboto')),
Ian Hickson's avatar
Ian Hickson committed
120
        ),
121 122 123 124
      ),
    );

    final RichText richText = tester.firstWidget(find.byType(RichText));
125
    expect(richText.text.style!.fontFamily, equals('Roboto'));
126
  });
127 128

  testWidgets('Icon with semantic label', (WidgetTester tester) async {
129
    final SemanticsTester semantics = SemanticsTester(tester);
130 131 132 133

    await tester.pumpWidget(
      const Directionality(
        textDirection: TextDirection.ltr,
134 135
        child: Center(
          child: Icon(
136 137 138 139 140 141 142
            Icons.title,
            semanticLabel: 'a label',
          ),
        ),
      ),
    );

143
    expect(semantics, includesNodeWith(label: 'a label'));
144 145

    semantics.dispose();
146 147 148
  });

  testWidgets('Null icon with semantic label', (WidgetTester tester) async {
149
    final SemanticsTester semantics = SemanticsTester(tester);
150 151 152 153

    await tester.pumpWidget(
      const Directionality(
        textDirection: TextDirection.ltr,
154 155
        child: Center(
          child: Icon(
156 157 158 159 160 161 162
            null,
            semanticLabel: 'a label',
          ),
        ),
      ),
    );

163
    expect(semantics, includesNodeWith(label: 'a label'));
164 165

    semantics.dispose();
166
  });
167

168
  testWidgets("Changing semantic label from null doesn't rebuild tree ", (WidgetTester tester) async {
169 170 171
    await tester.pumpWidget(
      const Directionality(
        textDirection: TextDirection.ltr,
172 173
        child: Center(
          child: Icon(Icons.time_to_leave),
174 175 176 177 178 179 180 181 182
        ),
      ),
    );

    final Element richText1 = tester.element(find.byType(RichText));

    await tester.pumpWidget(
      const Directionality(
        textDirection: TextDirection.ltr,
183 184
        child: Center(
          child: Icon(
185 186 187 188 189 190 191 192 193 194 195 196 197
            Icons.time_to_leave,
            semanticLabel: 'a label',
          ),
        ),
      ),
    );

    final Element richText2 = tester.element(find.byType(RichText));

    // Compare a leaf Element in the Icon subtree before and after changing the
    // semanticLabel to make sure the subtree was not rebuilt.
    expect(richText2, same(richText1));
  });
198 199 200 201 202 203 204 205 206 207 208 209

  testWidgets('IconData comparison', (WidgetTester tester) async {
    expect(const IconData(123), const IconData(123));
    expect(const IconData(123), isNot(const IconData(123, matchTextDirection: true)));
    expect(const IconData(123), isNot(const IconData(123, fontFamily: 'f')));
    expect(const IconData(123), isNot(const IconData(123, fontPackage: 'p')));
    expect(const IconData(123).hashCode, const IconData(123).hashCode);
    expect(const IconData(123).hashCode, isNot(const IconData(123, matchTextDirection: true).hashCode));
    expect(const IconData(123).hashCode, isNot(const IconData(123, fontFamily: 'f').hashCode));
    expect(const IconData(123).hashCode, isNot(const IconData(123, fontPackage: 'p').hashCode));
    expect(const IconData(123).toString(), 'IconData(U+0007B)');
  });
210
}