mirror of
https://github.com/flutter/flutter.git
synced 2026-02-20 02:29:02 +08:00
Bumps the Dart version to 3.8 across the repo (excluding engine/src/flutter/third_party) and applies formatting updates from Dart 3.8. ## Pre-launch Checklist - [x] I read the [Contributor Guide] and followed the process outlined there for submitting PRs. - [x] I read the [Tree Hygiene] wiki page, which explains my responsibilities. - [x] I read and followed the [Flutter Style Guide], including [Features we expect every widget to implement]. - [x] I signed the [CLA]. - [ ] I listed at least one issue that this PR fixes in the description above. - [ ] I updated/added relevant documentation (doc comments with `///`). - [x] I added new tests to check the change I am making, or this PR is [test-exempt]. - [x] I followed the [breaking change policy] and added [Data Driven Fixes] where supported. - [x] All existing and new tests are passing. If you need help, consider asking for advice on the #hackers-new channel on [Discord]. <!-- Links --> [Contributor Guide]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md#overview [Tree Hygiene]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md [test-exempt]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md#tests [Flutter Style Guide]: https://github.com/flutter/flutter/blob/main/docs/contributing/Style-guide-for-Flutter-repo.md [Features we expect every widget to implement]: https://github.com/flutter/flutter/blob/main/docs/contributing/Style-guide-for-Flutter-repo.md#features-we-expect-every-widget-to-implement [CLA]: https://cla.developers.google.com/ [flutter/tests]: https://github.com/flutter/tests [breaking change policy]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md#handling-breaking-changes [Discord]: https://github.com/flutter/flutter/blob/main/docs/contributing/Chat.md [Data Driven Fixes]: https://github.com/flutter/flutter/blob/main/docs/contributing/Data-driven-Fixes.md
103 lines
3.2 KiB
Dart
103 lines
3.2 KiB
Dart
// 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.
|
|
|
|
// This file is run as part of a reduced test set in CI on Mac and Windows
|
|
// machines.
|
|
@Tags(<String>['reduced-test-set'])
|
|
library;
|
|
|
|
import 'package:flutter/widgets.dart';
|
|
import 'package:flutter_test/flutter_test.dart';
|
|
|
|
Shader createShader(Rect bounds) {
|
|
return const LinearGradient(
|
|
begin: Alignment.topCenter,
|
|
end: Alignment.bottomCenter,
|
|
colors: <Color>[Color(0x00FFFFFF), Color(0xFFFFFFFF)],
|
|
stops: <double>[0.1, 0.35],
|
|
).createShader(bounds);
|
|
}
|
|
|
|
void main() {
|
|
testWidgets('Can be constructed', (WidgetTester tester) async {
|
|
const Widget child = SizedBox(width: 100.0, height: 100.0);
|
|
await tester.pumpWidget(const ShaderMask(shaderCallback: createShader, child: child));
|
|
});
|
|
|
|
testWidgets('Bounds rect includes offset', (WidgetTester tester) async {
|
|
late Rect shaderBounds;
|
|
Shader recordShaderBounds(Rect bounds) {
|
|
shaderBounds = bounds;
|
|
return createShader(bounds);
|
|
}
|
|
|
|
final Widget widget = Align(
|
|
child: SizedBox(
|
|
width: 400.0,
|
|
height: 400.0,
|
|
child: ShaderMask(
|
|
shaderCallback: recordShaderBounds,
|
|
child: const SizedBox(width: 100.0, height: 100.0),
|
|
),
|
|
),
|
|
);
|
|
await tester.pumpWidget(widget);
|
|
|
|
// The shader bounds rectangle should reflect the position of the centered SizedBox.
|
|
expect(shaderBounds, equals(const Rect.fromLTWH(0.0, 0.0, 400.0, 400.0)));
|
|
});
|
|
|
|
testWidgets('Bounds rect includes offset visual inspection', (WidgetTester tester) async {
|
|
final Widget widgetBottomRight = Container(
|
|
width: 400,
|
|
height: 400,
|
|
color: const Color(0xFFFFFFFF),
|
|
child: RepaintBoundary(
|
|
child: Align(
|
|
alignment: Alignment.bottomRight,
|
|
child: ShaderMask(
|
|
shaderCallback: (Rect bounds) => const RadialGradient(
|
|
radius: 0.05,
|
|
colors: <Color>[Color(0xFFFF0000), Color(0xFF00FF00)],
|
|
tileMode: TileMode.mirror,
|
|
).createShader(bounds),
|
|
child: Container(width: 100, height: 100, color: const Color(0xFFFFFFFF)),
|
|
),
|
|
),
|
|
),
|
|
);
|
|
await tester.pumpWidget(widgetBottomRight);
|
|
|
|
await expectLater(
|
|
find.byType(RepaintBoundary),
|
|
matchesGoldenFile('shader_mask.bounds.matches_bottom_right.png'),
|
|
);
|
|
|
|
final Widget widgetTopLeft = Container(
|
|
width: 400,
|
|
height: 400,
|
|
color: const Color(0xFFFFFFFF),
|
|
child: RepaintBoundary(
|
|
child: Align(
|
|
alignment: Alignment.topLeft,
|
|
child: ShaderMask(
|
|
shaderCallback: (Rect bounds) => const RadialGradient(
|
|
radius: 0.05,
|
|
colors: <Color>[Color(0xFFFF0000), Color(0xFF00FF00)],
|
|
tileMode: TileMode.mirror,
|
|
).createShader(bounds),
|
|
child: Container(width: 100, height: 100, color: const Color(0xFFFFFFFF)),
|
|
),
|
|
),
|
|
),
|
|
);
|
|
await tester.pumpWidget(widgetTopLeft);
|
|
|
|
await expectLater(
|
|
find.byType(RepaintBoundary),
|
|
matchesGoldenFile('shader_mask.bounds.matches_top_left.png'),
|
|
);
|
|
});
|
|
}
|