flutter/packages/flutter_tools/test/web.shard/vm_service_web_test.dart
Jessy Yameogo 8e8671bca5
Updated execution path to silently include --start-paused and updated tests (#168400)
This PR makes the following improvements to web hot reload support and
related tests:

- The `--start-paused` flag is now silently added when running with `-d
web-server --web-experimental-hot-reload` if it is not already present.
- Refactored test infrastructure to allow specifying the device
parameter (e.g., `'chrome'`, `'web-server'`) when running integration
tests.
- Added a new `web_run_web_server_test` to run flows on the web-server
device.
- Updated existing tests to explicitly pass the correct device parameter
where needed.
- We are currently not able to test hot reload on the web-server device
as this is not yet supported.

Fixes https://github.com/dart-lang/sdk/issues/60289
2025-05-13 16:47:49 +00:00

129 lines
3.8 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.
@Tags(<String>['flutter-test-driver'])
library;
import 'dart:async';
import 'package:file/file.dart';
import 'package:flutter_tools/src/base/file_system.dart';
import 'package:flutter_tools/src/vmservice.dart';
import 'package:flutter_tools/src/web/web_device.dart';
import 'package:vm_service/vm_service.dart';
import 'package:vm_service/vm_service_io.dart';
import '../integration.shard/test_data/basic_project.dart';
import '../integration.shard/test_driver.dart';
import '../integration.shard/test_utils.dart';
import '../src/common.dart';
void main() {
late Directory tempDir;
final BasicProjectWithUnaryMain project = BasicProjectWithUnaryMain();
late FlutterRunTestDriver flutter;
group('Clients of flutter run on web with DDS enabled', () {
setUp(() async {
tempDir = createResolvedTempDirectorySync('run_test.');
await project.setUpIn(tempDir);
flutter = FlutterRunTestDriver(tempDir);
});
tearDown(() async {
await flutter.stop();
tryToDelete(tempDir);
});
testWithoutContext('can validate flutter version', () async {
await flutter.run(
withDebugger: true,
device: GoogleChromeDevice.kChromeDeviceId,
additionalCommandArgs: <String>['--verbose'],
);
expect(flutter.vmServiceWsUri, isNotNull);
final VmService client = await vmServiceConnectUri('${flutter.vmServiceWsUri}');
await validateFlutterVersion(client);
});
testWithoutContext('can validate flutter version in parallel', () async {
await flutter.run(
withDebugger: true,
device: GoogleChromeDevice.kChromeDeviceId,
additionalCommandArgs: <String>['--verbose'],
);
expect(flutter.vmServiceWsUri, isNotNull);
final VmService client1 = await vmServiceConnectUri('${flutter.vmServiceWsUri}');
final VmService client2 = await vmServiceConnectUri('${flutter.vmServiceWsUri}');
await Future.wait(<Future<void>>[
validateFlutterVersion(client1),
validateFlutterVersion(client2),
]);
}, skip: true); // https://github.com/flutter/flutter/issues/99003
});
group('Clients of flutter run on web with DDS disabled', () {
setUp(() async {
tempDir = createResolvedTempDirectorySync('run_test.');
await project.setUpIn(tempDir);
flutter = FlutterRunTestDriver(tempDir, spawnDdsInstance: false);
});
tearDown(() async {
await flutter.stop();
tryToDelete(tempDir);
});
testWithoutContext('can validate flutter version', () async {
await flutter.run(
withDebugger: true,
device: GoogleChromeDevice.kChromeDeviceId,
additionalCommandArgs: <String>['--verbose'],
);
expect(flutter.vmServiceWsUri, isNotNull);
final VmService client = await vmServiceConnectUri('${flutter.vmServiceWsUri}');
await validateFlutterVersion(client);
});
});
}
Future<void> validateFlutterVersion(VmService client) async {
String? method;
final Future<dynamic> registration = expectLater(
client.onEvent('Service'),
emitsThrough(
predicate((Event e) {
if (e.kind == EventKind.kServiceRegistered && e.service == kFlutterVersionServiceName) {
method = e.method;
return true;
}
return false;
}),
),
);
await client.streamListen('Service');
await registration;
await client.streamCancel('Service');
final dynamic version1 = await client.callServiceExtension(method!);
expect(
version1,
const TypeMatcher<Success>()
.having((Success r) => r.type, 'type', 'Success')
.having((Success r) => r.json!['frameworkVersion'], 'frameworkVersion', isNotNull),
);
await client.dispose();
}