Unverified Commit ee86e61f authored by Kate Lovett's avatar Kate Lovett Committed by GitHub

Assert golden files use the right extension (#99016)

parent 0eae276e
...@@ -167,6 +167,12 @@ abstract class FlutterGoldenFileComparator extends GoldenFileComparator { ...@@ -167,6 +167,12 @@ abstract class FlutterGoldenFileComparator extends GoldenFileComparator {
/// Prepends the golden URL with the library name that encloses the current /// Prepends the golden URL with the library name that encloses the current
/// test. /// test.
Uri _addPrefix(Uri golden) { Uri _addPrefix(Uri golden) {
// Ensure the Uri ends in .png as the SkiaClient expects
assert(
golden.toString().split('.').last == 'png',
'Golden files in the Flutter framework must end with the file extension '
'.png.'
);
final String prefix = basedir.pathSegments[basedir.pathSegments.length - 2]; final String prefix = basedir.pathSegments[basedir.pathSegments.length - 2];
return Uri.parse('$prefix.$golden'); return Uri.parse('$prefix.$golden');
} }
......
...@@ -481,6 +481,26 @@ void main() { ...@@ -481,6 +481,26 @@ void main() {
); );
}); });
test('asserts .png format', () async {
await expectLater(
() async {
return comparator.compare(
Uint8List.fromList(_kTestPngBytes),
Uri.parse('flutter.golden_test.1'),
);
},
throwsA(
isA<AssertionError>().having((AssertionError error) => error.toString(),
'description',
contains(
'Golden files in the Flutter framework must end with the file '
'extension .png.'
),
),
),
);
});
test('calls init during compare', () { test('calls init during compare', () {
expect(fakeSkiaClient.initCalls, 0); expect(fakeSkiaClient.initCalls, 0);
comparator.compare( comparator.compare(
...@@ -579,6 +599,26 @@ void main() { ...@@ -579,6 +599,26 @@ void main() {
); );
}); });
test('asserts .png format', () async {
await expectLater(
() async {
return comparator.compare(
Uint8List.fromList(_kTestPngBytes),
Uri.parse('flutter.golden_test.1'),
);
},
throwsA(
isA<AssertionError>().having((AssertionError error) => error.toString(),
'description',
contains(
'Golden files in the Flutter framework must end with the file '
'extension .png.'
),
),
),
);
});
test('calls init during compare', () { test('calls init during compare', () {
expect(fakeSkiaClient.tryInitCalls, 0); expect(fakeSkiaClient.tryInitCalls, 0);
comparator.compare( comparator.compare(
...@@ -745,6 +785,26 @@ void main() { ...@@ -745,6 +785,26 @@ void main() {
fakeSkiaClient.cleanTestNameValues['library.flutter.golden_test.1.png'] = 'flutter.golden_test.1'; fakeSkiaClient.cleanTestNameValues['library.flutter.golden_test.1.png'] = 'flutter.golden_test.1';
}); });
test('asserts .png format', () async {
await expectLater(
() async {
return comparator.compare(
Uint8List.fromList(_kTestPngBytes),
Uri.parse('flutter.golden_test.1'),
);
},
throwsA(
isA<AssertionError>().having((AssertionError error) => error.toString(),
'description',
contains(
'Golden files in the Flutter framework must end with the file '
'extension .png.'
),
),
),
);
});
test('passes when bytes match', () async { test('passes when bytes match', () async {
expect( expect(
await comparator.compare( await comparator.compare(
......
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