Unverified Commit e537661a authored by Lasse R.H. Nielsen's avatar Lasse R.H. Nielsen Committed by GitHub

Change test to not implement ByteData (#80049)

parent d1187487
...@@ -14,12 +14,10 @@ import 'package:flutter_test/flutter_test.dart'; ...@@ -14,12 +14,10 @@ import 'package:flutter_test/flutter_test.dart';
import '../image_data.dart'; import '../image_data.dart';
class TestByteData implements ByteData { ByteData testByteData(double scale) => ByteData(8)..setFloat64(0, scale);
TestByteData(this.scale);
final double scale;
@override extension on ByteData {
dynamic noSuchMethod(Invocation invocation) => null; double get scale => getFloat64(0);
} }
const String testManifest = ''' const String testManifest = '''
...@@ -44,22 +42,22 @@ class TestAssetBundle extends CachingAssetBundle { ...@@ -44,22 +42,22 @@ class TestAssetBundle extends CachingAssetBundle {
late ByteData data; late ByteData data;
switch (key) { switch (key) {
case 'assets/image.png': case 'assets/image.png':
data = TestByteData(1.0); data = testByteData(1.0);
break; break;
case 'assets/1.0x/image.png': case 'assets/1.0x/image.png':
data = TestByteData(10.0); // see "...with a main asset and a 1.0x asset" data = testByteData(10.0); // see "...with a main asset and a 1.0x asset"
break; break;
case 'assets/1.5x/image.png': case 'assets/1.5x/image.png':
data = TestByteData(1.5); data = testByteData(1.5);
break; break;
case 'assets/2.0x/image.png': case 'assets/2.0x/image.png':
data = TestByteData(2.0); data = testByteData(2.0);
break; break;
case 'assets/3.0x/image.png': case 'assets/3.0x/image.png':
data = TestByteData(3.0); data = testByteData(3.0);
break; break;
case 'assets/4.0x/image.png': case 'assets/4.0x/image.png':
data = TestByteData(4.0); data = testByteData(4.0);
break; break;
} }
return SynchronousFuture<ByteData>(data); return SynchronousFuture<ByteData>(data);
...@@ -91,7 +89,7 @@ class TestAssetImage extends AssetImage { ...@@ -91,7 +89,7 @@ class TestAssetImage extends AssetImage {
ImageStreamCompleter load(AssetBundleImageKey key, DecoderCallback decode) { ImageStreamCompleter load(AssetBundleImageKey key, DecoderCallback decode) {
late ImageInfo imageInfo; late ImageInfo imageInfo;
key.bundle.load(key.name).then<void>((ByteData data) { key.bundle.load(key.name).then<void>((ByteData data) {
final TestByteData testData = data as TestByteData; final ByteData testData = data;
final ui.Image image = images[testData.scale]!; final ui.Image image = images[testData.scale]!;
assert(image != null, 'Expected ${testData.scale} to have a key in $images'); assert(image != null, 'Expected ${testData.scale} to have a key in $images');
imageInfo = ImageInfo(image: image, scale: key.scale); imageInfo = ImageInfo(image: image, scale: key.scale);
...@@ -312,12 +310,12 @@ void main() { ...@@ -312,12 +310,12 @@ void main() {
Key key = GlobalKey(); Key key = GlobalKey();
await pumpTreeToLayout(tester, buildImageAtRatio(image, key, ratio, false, images, bundle)); await pumpTreeToLayout(tester, buildImageAtRatio(image, key, ratio, false, images, bundle));
expect(getRenderImage(tester, key).size, const Size(200.0, 200.0)); expect(getRenderImage(tester, key).size, const Size(200.0, 200.0));
// Verify we got the 10x scaled image, since the TestByteData said it should be 10x. // Verify we got the 10x scaled image, since the test ByteData said it should be 10x.
expect(getRenderImage(tester, key).image!.height, 480); expect(getRenderImage(tester, key).image!.height, 480);
key = GlobalKey(); key = GlobalKey();
await pumpTreeToLayout(tester, buildImageAtRatio(image, key, ratio, true, images, bundle)); await pumpTreeToLayout(tester, buildImageAtRatio(image, key, ratio, true, images, bundle));
expect(getRenderImage(tester, key).size, const Size(480.0, 480.0)); expect(getRenderImage(tester, key).size, const Size(480.0, 480.0));
// Verify we got the 10x scaled image, since the TestByteData said it should be 10x. // Verify we got the 10x scaled image, since the test ByteData said it should be 10x.
expect(getRenderImage(tester, key).image!.height, 480); expect(getRenderImage(tester, key).image!.height, 480);
}); });
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment