From dfaec11ba519421ccc6869226dd8930bb5689fb6 Mon Sep 17 00:00:00 2001 From: Jonah Williams Date: Tue, 21 Jun 2022 11:19:09 -0700 Subject: [PATCH] migrate web integration tests to null safety (#106231) --- .../web.shard/debugger_stepping_web_test.dart | 12 ++++----- .../expression_evaluation_web_test.dart | 26 +++++++++---------- .../test/web.shard/hot_reload_web_test.dart | 10 +++---- .../test/web.shard/output_web_test.dart | 8 ++---- .../test/web.shard/vm_service_web_test.dart | 12 ++++----- .../web.shard/web_driver_service_test.dart | 2 -- .../test/web.shard/web_run_test.dart | 6 ++--- 7 files changed, 30 insertions(+), 46 deletions(-) diff --git a/packages/flutter_tools/test/web.shard/debugger_stepping_web_test.dart b/packages/flutter_tools/test/web.shard/debugger_stepping_web_test.dart index c2656ad53808..0663bb6da380 100644 --- a/packages/flutter_tools/test/web.shard/debugger_stepping_web_test.dart +++ b/packages/flutter_tools/test/web.shard/debugger_stepping_web_test.dart @@ -2,8 +2,6 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -// @dart = 2.8 - import 'package:file/file.dart'; import '../integration.shard/test_data/stepping_project.dart'; @@ -12,8 +10,8 @@ import '../integration.shard/test_utils.dart'; import '../src/common.dart'; void main() { - Directory tempDirectory; - FlutterRunTestDriver flutter; + late Directory tempDirectory; + late FlutterRunTestDriver flutter; setUp(() { tempDirectory = createResolvedTempDirectorySync('debugger_stepping_test.'); @@ -30,13 +28,13 @@ void main() { additionalCommandArgs: ['--verbose', '--web-renderer=html']); await flutter.addBreakpoint(project.breakpointUri, project.breakpointLine); await flutter.resume(waitForNextPause: true); // Now we should be on the breakpoint. - expect((await flutter.getSourceLocation()).line, equals(project.breakpointLine)); + expect((await flutter.getSourceLocation())!.line, equals(project.breakpointLine)); // Issue 5 steps, ensuring that we end up on the annotated lines each time. for (int i = 1; i <= project.numberOfSteps; i += 1) { await flutter.stepOverOrOverAsyncSuspension(); - final SourcePosition location = await flutter.getSourceLocation(); - final int actualLine = location.line; + final SourcePosition? location = await flutter.getSourceLocation(); + final int actualLine = location!.line; // Get the line we're expected to stop at by searching for the comment // within the source code. diff --git a/packages/flutter_tools/test/web.shard/expression_evaluation_web_test.dart b/packages/flutter_tools/test/web.shard/expression_evaluation_web_test.dart index 5c1cbe971f62..3f4564f9f218 100644 --- a/packages/flutter_tools/test/web.shard/expression_evaluation_web_test.dart +++ b/packages/flutter_tools/test/web.shard/expression_evaluation_web_test.dart @@ -2,8 +2,6 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -// @dart = 2.8 - import 'package:file/file.dart'; import 'package:vm_service/vm_service.dart'; @@ -16,8 +14,8 @@ import '../src/common.dart'; void main() { group('Flutter run for web', () { final BasicProject project = BasicProject(); - Directory tempDir; - FlutterRunTestDriver flutter; + late Directory tempDir; + late FlutterRunTestDriver flutter; setUp(() async { tempDir = createResolvedTempDirectorySync('run_expression_eval_test.'); @@ -33,7 +31,7 @@ void main() { tryToDelete(tempDir); }); - Future start({bool expressionEvaluation}) async { + Future start({required bool expressionEvaluation}) async { // The non-test project has a loop around its breakpoints. // No need to start paused as all breakpoint would be eventually reached. await flutter.run( @@ -116,8 +114,8 @@ void main() { group('Flutter test for web', () { final TestsProject project = TestsProject(); - Directory tempDir; - FlutterRunTestDriver flutter; + late Directory tempDir; + late FlutterRunTestDriver flutter; setUp(() async { tempDir = createResolvedTempDirectorySync('run_expression_eval_test.'); @@ -130,7 +128,7 @@ void main() { tryToDelete(tempDir); }); - Future breakInMethod(FlutterTestDriver flutter) async { + Future breakInMethod(FlutterTestDriver flutter) async { await flutter.addBreakpoint( project.breakpointAppUri, project.breakpointLine, @@ -138,7 +136,7 @@ void main() { return flutter.resume(waitForNextPause: true); } - Future startPaused({bool expressionEvaluation}) { + Future startPaused({required bool expressionEvaluation}) { // The test project does not have a loop around its breakpoints. // Start paused so we can set a breakpoint before passing it // in the execution. @@ -224,19 +222,19 @@ Future evaluateComplexExpressions(FlutterTestDriver flutter) async { Future evaluateTrivialExpressionsInLibrary(FlutterTestDriver flutter) async { final LibraryRef library = await getRootLibrary(flutter); - final ObjRef res = await flutter.evaluate(library.id, '"test"'); + final ObjRef res = await flutter.evaluate(library.id!, '"test"'); expectInstance(res, InstanceKind.kString, 'test'); } Future evaluateComplexExpressionsInLibrary(FlutterTestDriver flutter) async { final LibraryRef library = await getRootLibrary(flutter); - final ObjRef res = await flutter.evaluate(library.id, 'new DateTime.now().year'); + final ObjRef res = await flutter.evaluate(library.id!, 'new DateTime.now().year'); expectInstance(res, InstanceKind.kDouble, DateTime.now().year.toString()); } Future evaluateWebLibraryBooleanFromEnvironmentInLibrary(FlutterTestDriver flutter) async { final LibraryRef library = await getRootLibrary(flutter); - final ObjRef res = await flutter.evaluate(library.id, 'const bool.fromEnvironment("dart.library.html")'); + final ObjRef res = await flutter.evaluate(library.id!, 'const bool.fromEnvironment("dart.library.html")'); expectInstance(res, InstanceKind.kBool, true.toString()); } @@ -246,8 +244,8 @@ Future getRootLibrary(FlutterTestDriver flutter) async { // // Issue: https://github.com/dart-lang/sdk/issues/44760 final Isolate isolate = await flutter.getFlutterIsolate(); - return isolate.libraries - .firstWhere((LibraryRef l) => l.uri.contains('org-dartlang-app')); + return isolate.libraries! + .firstWhere((LibraryRef l) => l.uri!.contains('org-dartlang-app')); } void expectInstance(ObjRef result, String kind, String message) { diff --git a/packages/flutter_tools/test/web.shard/hot_reload_web_test.dart b/packages/flutter_tools/test/web.shard/hot_reload_web_test.dart index 57732e3515e9..ba26e119b7f3 100644 --- a/packages/flutter_tools/test/web.shard/hot_reload_web_test.dart +++ b/packages/flutter_tools/test/web.shard/hot_reload_web_test.dart @@ -2,8 +2,6 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -// @dart = 2.8 - import 'dart:async'; import 'package:file/file.dart'; @@ -14,9 +12,9 @@ import '../integration.shard/test_utils.dart'; import '../src/common.dart'; void main() { - Directory tempDir; + late Directory tempDir; final HotReloadProject project = HotReloadProject(); - FlutterRunTestDriver flutter; + late FlutterRunTestDriver flutter; setUp(() async { tempDir = createResolvedTempDirectorySync('hot_reload_test.'); @@ -25,8 +23,8 @@ void main() { }); tearDown(() async { - await flutter?.stop(); - await flutter?.done; + await flutter.stop(); + await flutter.done; tryToDelete(tempDir); }); diff --git a/packages/flutter_tools/test/web.shard/output_web_test.dart b/packages/flutter_tools/test/web.shard/output_web_test.dart index cc38b873c934..62526667149b 100644 --- a/packages/flutter_tools/test/web.shard/output_web_test.dart +++ b/packages/flutter_tools/test/web.shard/output_web_test.dart @@ -2,8 +2,6 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -// @dart = 2.8 - import 'package:file/file.dart'; import 'package:flutter_tools/src/base/file_system.dart'; import 'package:vm_service/vm_service.dart'; @@ -15,15 +13,14 @@ import '../integration.shard/test_utils.dart'; import '../src/common.dart'; void main() { - Directory tempDir; + late Directory tempDir; final BasicProjectWithUnaryMain project = BasicProjectWithUnaryMain(); - FlutterRunTestDriver flutter; + late FlutterRunTestDriver flutter; setUp(() async { tempDir = createResolvedTempDirectorySync('run_test.'); await project.setUpIn(tempDir); flutter = FlutterRunTestDriver(tempDir); - //flutter.stdout.listen(print); }); tearDown(() async { @@ -37,7 +34,6 @@ void main() { await flutter.run( withDebugger: true, chrome: true, - expressionEvaluation: true, additionalCommandArgs: [ if (verbose) '--verbose', '--web-renderer=html', diff --git a/packages/flutter_tools/test/web.shard/vm_service_web_test.dart b/packages/flutter_tools/test/web.shard/vm_service_web_test.dart index 6c81d04bcacf..78636bb7f506 100644 --- a/packages/flutter_tools/test/web.shard/vm_service_web_test.dart +++ b/packages/flutter_tools/test/web.shard/vm_service_web_test.dart @@ -2,8 +2,6 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -// @dart = 2.8 - import 'dart:async'; import 'package:file/file.dart'; @@ -17,9 +15,9 @@ import '../integration.shard/test_utils.dart'; import '../src/common.dart'; void main() { - Directory tempDir; + late Directory tempDir; final BasicProjectWithUnaryMain project = BasicProjectWithUnaryMain(); - FlutterRunTestDriver flutter; + late FlutterRunTestDriver flutter; group('Clients of flutter run on web with DDS enabled', () { setUp(() async { @@ -92,7 +90,7 @@ void main() { } Future validateFlutterVersion(VmService client) async { - String method; + String? method; final Future registration = expectLater( client.onEvent('Service'), @@ -110,10 +108,10 @@ Future validateFlutterVersion(VmService client) async { await registration; await client.streamCancel('Service'); - final dynamic version1 = await client.callServiceExtension(method); + final dynamic version1 = await client.callServiceExtension(method!); expect(version1, const TypeMatcher() .having((Success r) => r.type, 'type', 'Success') - .having((Success r) => r.json['frameworkVersion'], 'frameworkVersion', isNotNull)); + .having((Success r) => r.json!['frameworkVersion'], 'frameworkVersion', isNotNull)); await client.dispose(); } diff --git a/packages/flutter_tools/test/web.shard/web_driver_service_test.dart b/packages/flutter_tools/test/web.shard/web_driver_service_test.dart index 4d1201ee177e..1caea4c48fce 100644 --- a/packages/flutter_tools/test/web.shard/web_driver_service_test.dart +++ b/packages/flutter_tools/test/web.shard/web_driver_service_test.dart @@ -2,8 +2,6 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -// @dart = 2.8 - import 'package:flutter_tools/src/base/common.dart'; import 'package:flutter_tools/src/base/logger.dart'; import 'package:flutter_tools/src/base/process.dart'; diff --git a/packages/flutter_tools/test/web.shard/web_run_test.dart b/packages/flutter_tools/test/web.shard/web_run_test.dart index 32f6e1e913d5..c9c8227051d8 100644 --- a/packages/flutter_tools/test/web.shard/web_run_test.dart +++ b/packages/flutter_tools/test/web.shard/web_run_test.dart @@ -2,8 +2,6 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -// @dart = 2.8 - import 'package:file/file.dart'; import 'package:flutter_tools/src/base/file_system.dart'; @@ -13,9 +11,9 @@ import '../integration.shard/test_utils.dart'; import '../src/common.dart'; void main() { - Directory tempDir; + late Directory tempDir; final BasicProjectWithUnaryMain project = BasicProjectWithUnaryMain(); - FlutterRunTestDriver flutter; + late FlutterRunTestDriver flutter; setUp(() async { tempDir = createResolvedTempDirectorySync('run_test.');