blob: c1e4310491485f5b1f2d39f97452015f05b60dc9 [file] [log] [blame]
// Copyright 2017 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 'dart:math' as math show pi;
import 'package:flutter/material.dart';
import 'package:flutter_test/flutter_test.dart';
import 'package:mockito/mockito.dart';
import '../widgets/semantics_tester.dart';
class MockCanvas extends Mock implements Canvas {}
void main() {
testWidgets('IconTheme color', (WidgetTester tester) async {
await tester.pumpWidget(
const Directionality(
textDirection: TextDirection.ltr,
child: const IconTheme(
data: const IconThemeData(
color: const Color(0xFF666666),
),
child: const AnimatedIcon(
progress: const AlwaysStoppedAnimation<double>(0.0),
icon: AnimatedIcons.arrow_menu,
)
),
),
);
final CustomPaint customPaint = tester.widget(find.byType(CustomPaint));
final MockCanvas canvas = new MockCanvas();
customPaint.painter.paint(canvas, const Size(48.0, 48.0));
verify(canvas.drawPath(any, argThat(hasColor(0xFF666666))));
});
testWidgets('IconTheme opacity', (WidgetTester tester) async {
await tester.pumpWidget(
const Directionality(
textDirection: TextDirection.ltr,
child: const IconTheme(
data: const IconThemeData(
color: const Color(0xFF666666),
opacity: 0.5,
),
child: const AnimatedIcon(
progress: const AlwaysStoppedAnimation<double>(0.0),
icon: AnimatedIcons.arrow_menu,
)
),
),
);
final CustomPaint customPaint = tester.widget(find.byType(CustomPaint));
final MockCanvas canvas = new MockCanvas();
customPaint.painter.paint(canvas, const Size(48.0, 48.0));
verify(canvas.drawPath(any, argThat(hasColor(0x80666666))));
});
testWidgets('color overrides IconTheme color', (WidgetTester tester) async {
await tester.pumpWidget(
const Directionality(
textDirection: TextDirection.ltr,
child: const IconTheme(
data: const IconThemeData(
color: const Color(0xFF666666),
),
child: const AnimatedIcon(
progress: const AlwaysStoppedAnimation<double>(0.0),
icon: AnimatedIcons.arrow_menu,
color: const Color(0xFF0000FF),
)
),
),
);
final CustomPaint customPaint = tester.widget(find.byType(CustomPaint));
final MockCanvas canvas = new MockCanvas();
customPaint.painter.paint(canvas, const Size(48.0, 48.0));
verify(canvas.drawPath(any, argThat(hasColor(0xFF0000FF))));
});
testWidgets('IconTheme size', (WidgetTester tester) async {
await tester.pumpWidget(
const Directionality(
textDirection: TextDirection.ltr,
child: const IconTheme(
data: const IconThemeData(
color: const Color(0xFF666666),
size: 12.0,
),
child: const AnimatedIcon(
progress: const AlwaysStoppedAnimation<double>(0.0),
icon: AnimatedIcons.arrow_menu,
)
),
),
);
final CustomPaint customPaint = tester.widget(find.byType(CustomPaint));
final MockCanvas canvas = new MockCanvas();
customPaint.painter.paint(canvas, const Size(12.0, 12.0));
// arrow_menu default size is 48x48 so we expect it to be scaled by 0.25.
verify(canvas.scale(0.25, 0.25));
});
testWidgets('size overridesIconTheme size', (WidgetTester tester) async {
await tester.pumpWidget(
const Directionality(
textDirection: TextDirection.ltr,
child: const IconTheme(
data: const IconThemeData(
color: const Color(0xFF666666),
size: 12.0,
),
child: const AnimatedIcon(
progress: const AlwaysStoppedAnimation<double>(0.0),
icon: AnimatedIcons.arrow_menu,
size: 96.0,
)
),
),
);
final CustomPaint customPaint = tester.widget(find.byType(CustomPaint));
final MockCanvas canvas = new MockCanvas();
customPaint.painter.paint(canvas, const Size(12.0, 12.0));
// arrow_menu default size is 48x48 so we expect it to be scaled by 2.
verify(canvas.scale(2.0, 2.0));
});
testWidgets('Semantic label', (WidgetTester tester) async {
final SemanticsTester semantics = new SemanticsTester(tester);
await tester.pumpWidget(
const Directionality(
textDirection: TextDirection.ltr,
child: const AnimatedIcon(
progress: const AlwaysStoppedAnimation<double>(0.0),
icon: AnimatedIcons.arrow_menu,
size: 96.0,
semanticLabel: 'a label',
),
),
);
expect(semantics, includesNodeWith(label: 'a label'));
semantics.dispose();
});
testWidgets('Inherited text direction rtl', (WidgetTester tester) async {
await tester.pumpWidget(
const Directionality(
textDirection: TextDirection.rtl,
child: const IconTheme(
data: const IconThemeData(
color: const Color(0xFF666666),
),
child: const AnimatedIcon(
progress: const AlwaysStoppedAnimation<double>(0.0),
icon: AnimatedIcons.arrow_menu,
)
),
),
);
final CustomPaint customPaint = tester.widget(find.byType(CustomPaint));
final MockCanvas canvas = new MockCanvas();
customPaint.painter.paint(canvas, const Size(48.0, 48.0));
verifyInOrder(<void>[
canvas.rotate(math.pi),
canvas.translate(-48.0, -48.0)
]);
});
testWidgets('Inherited text direction ltr', (WidgetTester tester) async {
await tester.pumpWidget(
const Directionality(
textDirection: TextDirection.ltr,
child: const IconTheme(
data: const IconThemeData(
color: const Color(0xFF666666),
),
child: const AnimatedIcon(
progress: const AlwaysStoppedAnimation<double>(0.0),
icon: AnimatedIcons.arrow_menu,
)
),
),
);
final CustomPaint customPaint = tester.widget(find.byType(CustomPaint));
final MockCanvas canvas = new MockCanvas();
customPaint.painter.paint(canvas, const Size(48.0, 48.0));
verifyNever(canvas.rotate(any));
verifyNever(canvas.translate(any, any));
});
testWidgets('Inherited text direction overridden', (WidgetTester tester) async {
await tester.pumpWidget(
const Directionality(
textDirection: TextDirection.ltr,
child: const IconTheme(
data: const IconThemeData(
color: const Color(0xFF666666),
),
child: const AnimatedIcon(
progress: const AlwaysStoppedAnimation<double>(0.0),
icon: AnimatedIcons.arrow_menu,
textDirection: TextDirection.rtl,
)
),
),
);
final CustomPaint customPaint = tester.widget(find.byType(CustomPaint));
final MockCanvas canvas = new MockCanvas();
customPaint.painter.paint(canvas, const Size(48.0, 48.0));
verifyInOrder(<void>[
canvas.rotate(math.pi),
canvas.translate(-48.0, -48.0)
]);
});
}
PaintColorMatcher hasColor(int color) {
return new PaintColorMatcher(color);
}
class PaintColorMatcher extends Matcher {
const PaintColorMatcher(this.expectedColor);
final int expectedColor;
@override
Description describe(Description description) =>
description.add('color was not $expectedColor');
@override
bool matches(dynamic item, Map<dynamic, dynamic> matchState) {
final Paint actualPaint = item;
return actualPaint.color == new Color(expectedColor);
}
}