Unverified Commit 50ea6f32 authored by Jonah Williams's avatar Jonah Williams Committed by GitHub

add benchmarks to track web size (#33892)

parent a6e77377
// Copyright 2019 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 'package:flutter_devicelab/framework/framework.dart';
import 'package:flutter_devicelab/tasks/perf_tests.dart';
Future<void> main() async {
await task(createWebCompileTest());
}
...@@ -74,6 +74,10 @@ TaskFunction createHelloWorldCompileTest() { ...@@ -74,6 +74,10 @@ TaskFunction createHelloWorldCompileTest() {
return CompileTest('${flutterDirectory.path}/examples/hello_world', reportPackageContentSizes: true).run; return CompileTest('${flutterDirectory.path}/examples/hello_world', reportPackageContentSizes: true).run;
} }
TaskFunction createWebCompileTest() {
return const WebCompileTest().run;
}
TaskFunction createComplexLayoutCompileTest() { TaskFunction createComplexLayoutCompileTest() {
return CompileTest('${flutterDirectory.path}/dev/benchmarks/complex_layout').run; return CompileTest('${flutterDirectory.path}/dev/benchmarks/complex_layout').run;
} }
...@@ -198,6 +202,71 @@ class PerfTest { ...@@ -198,6 +202,71 @@ class PerfTest {
} }
} }
/// Measures how long it takes to compile a Flutter app to JavaScript and how
/// big the compiled code is.
class WebCompileTest {
const WebCompileTest();
Future<TaskResult> run() async {
final Map<String, Object> metrics = <String, Object>{};
await inDirectory<TaskResult>('${flutterDirectory.path}/examples/hello_world', () async {
await flutter('packages', options: <String>['get']);
await evalFlutter('build', options: <String>[
'web',
'-v',
'--release',
'--no-pub',
]);
final String output = '${flutterDirectory.path}/examples/hello_world/build/web/main.dart.js';
await _measureSize('hello_world', output, metrics);
return null;
});
await inDirectory<TaskResult>('${flutterDirectory.path}/examples/flutter_gallery', () async {
await flutter('packages', options: <String>['get']);
await evalFlutter('build', options: <String>[
'web',
'-v',
'--release',
'--no-pub',
]);
final String output = '${flutterDirectory.path}/examples/flutter_gallery/build/web/main.dart.js';
await _measureSize('flutter_gallery', output, metrics);
return null;
});
const String sampleAppName = 'sample_flutter_app';
final Directory sampleDir = dir('${Directory.systemTemp.path}/$sampleAppName');
rmTree(sampleDir);
await inDirectory<void>(Directory.systemTemp, () async {
await flutter('create', options: <String>['--template=app', sampleAppName]);
await inDirectory(sampleDir, () async {
await flutter('packages', options: <String>['get']);
await evalFlutter('build', options: <String>[
'web',
'-v',
'--release',
'--no-pub',
]);
await _measureSize('basic_material_app', path.join(sampleDir.path, 'build/web/main.dart.js'), metrics);
});
});
return TaskResult.success(metrics, benchmarkScoreKeys: metrics.keys.toList());
}
static Future<void> _measureSize(String metric, String output, Map<String, Object> metrics) async {
final ProcessResult result = await Process.run('du', <String>['-k', output]);
await Process.run('gzip',<String>['-k', '9', output]);
final ProcessResult resultGzip = await Process.run('du', <String>['-k', output + '.gz']);
metrics['${metric}_dart2js_size'] = _parseDu(result.stdout);
metrics['${metric}_dart2js_size_gzip'] = _parseDu(resultGzip.stdout);
}
static int _parseDu(String source) {
return int.parse(source.split(RegExp(r'\s+')).first.trim());
}
}
/// Measures how long it takes to compile a Flutter app and how big the compiled /// Measures how long it takes to compile a Flutter app and how big the compiled
/// code is. /// code is.
class CompileTest { class CompileTest {
......
...@@ -338,6 +338,14 @@ tasks: ...@@ -338,6 +338,14 @@ tasks:
required_agent_capabilities: ["linux/android"] required_agent_capabilities: ["linux/android"]
flaky: true flaky: true
web_size__compile_test:
description: >
Measures the size of a dart2js bundle.
stage: devicelab
required_agent_capabilities: ["linux/android"]
flaky: true
# iOS on-device tests # iOS on-device tests
flavors_test_ios: flavors_test_ios:
......
...@@ -58,6 +58,7 @@ class WebCompiler { ...@@ -58,6 +58,7 @@ class WebCompiler {
target, target,
'-o', '-o',
'$outputPath', '$outputPath',
'-O4',
'--libraries-spec=$librariesPath', '--libraries-spec=$librariesPath',
]; ];
if (minify) { if (minify) {
......
...@@ -38,6 +38,7 @@ void main() { ...@@ -38,6 +38,7 @@ void main() {
'lib/main.dart', 'lib/main.dart',
'-o', '-o',
'build/web/main.dart.js', 'build/web/main.dart.js',
'-O4',
'--libraries-spec=bin/cache/flutter_web_sdk/libraries.json', '--libraries-spec=bin/cache/flutter_web_sdk/libraries.json',
'-m', '-m',
])).called(1); ])).called(1);
......
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