mirror of
https://github.com/flutter/flutter.git
synced 2025-06-03 00:51:18 +00:00

This change removes references to Observatory, including: - Deprecated flags - Deprecated embedder APIs - Outdated documentation - Documentation instances where "VM service" should have been used - Incorrectly named tests / directories As a part of this change, `--serve-observatory` is no longer a valid flag. Observatory is still available for now via the `_serveObservatory` RPC, but will be removed in a follow up PR once we've prepared for breakages in G3. Work towards https://github.com/dart-lang/sdk/issues/50233 FYI @a-siva
155 lines
5.1 KiB
Dart
155 lines
5.1 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 'package:file/file.dart';
|
|
import 'package:flutter_tools/src/base/io.dart';
|
|
import 'package:vm_service/vm_service.dart';
|
|
|
|
import '../src/common.dart';
|
|
import 'test_data/basic_project.dart';
|
|
import 'test_driver.dart';
|
|
import 'test_utils.dart';
|
|
|
|
Future<int> getFreePort() async {
|
|
int port = 0;
|
|
final ServerSocket serverSocket = await ServerSocket.bind(InternetAddress.loopbackIPv4, 0);
|
|
port = serverSocket.port;
|
|
await serverSocket.close();
|
|
return port;
|
|
}
|
|
|
|
void main() {
|
|
final BasicProject project = BasicProject();
|
|
late Directory tempDir;
|
|
|
|
setUp(() async {
|
|
tempDir = createResolvedTempDirectorySync('attach_test.');
|
|
await project.setUpIn(tempDir);
|
|
});
|
|
|
|
tearDown(() {
|
|
tryToDelete(tempDir);
|
|
});
|
|
|
|
group('DDS in flutter run', () {
|
|
late FlutterRunTestDriver flutterRun, flutterAttach;
|
|
setUp(() {
|
|
flutterRun = FlutterRunTestDriver(tempDir, logPrefix: ' RUN ');
|
|
flutterAttach = FlutterRunTestDriver(
|
|
tempDir,
|
|
logPrefix: 'ATTACH ',
|
|
// Only one DDS instance can be connected to the VM service at a time.
|
|
// DDS can also only initialize if the VM service doesn't have any existing
|
|
// clients, so we'll just let _flutterRun be responsible for spawning DDS.
|
|
spawnDdsInstance: false,
|
|
);
|
|
});
|
|
|
|
tearDown(() async {
|
|
await flutterAttach.detach();
|
|
await flutterRun.stop();
|
|
});
|
|
|
|
testWithoutContext('can hot reload', () async {
|
|
await flutterRun.run(withDebugger: true);
|
|
await flutterAttach.attach(flutterRun.vmServicePort!);
|
|
await flutterAttach.hotReload();
|
|
});
|
|
|
|
testWithoutContext('can detach, reattach, hot reload', () async {
|
|
await flutterRun.run(withDebugger: true);
|
|
await flutterAttach.attach(flutterRun.vmServicePort!);
|
|
await flutterAttach.detach();
|
|
await flutterAttach.attach(flutterRun.vmServicePort!);
|
|
await flutterAttach.hotReload();
|
|
});
|
|
|
|
testWithoutContext('killing process behaves the same as detach ', () async {
|
|
await flutterRun.run(withDebugger: true);
|
|
await flutterAttach.attach(flutterRun.vmServicePort!);
|
|
await flutterAttach.quit();
|
|
flutterAttach = FlutterRunTestDriver(tempDir, logPrefix: 'ATTACH-2', spawnDdsInstance: false);
|
|
await flutterAttach.attach(flutterRun.vmServicePort!);
|
|
await flutterAttach.hotReload();
|
|
});
|
|
|
|
testWithoutContext('sets activeDevToolsServerAddress extension', () async {
|
|
await flutterRun.run(
|
|
startPaused: true,
|
|
withDebugger: true,
|
|
additionalCommandArgs: <String>['--devtools-server-address', 'http://127.0.0.1:9105'],
|
|
);
|
|
await flutterRun.resume();
|
|
await pollForServiceExtensionValue<String>(
|
|
testDriver: flutterRun,
|
|
extension: 'ext.flutter.activeDevToolsServerAddress',
|
|
continuePollingValue: '',
|
|
matches: equals('http://127.0.0.1:9105'),
|
|
);
|
|
await pollForServiceExtensionValue<String>(
|
|
testDriver: flutterRun,
|
|
extension: 'ext.flutter.connectedVmServiceUri',
|
|
continuePollingValue: '',
|
|
matches: isNotEmpty,
|
|
);
|
|
|
|
final Response response = await flutterRun.callServiceExtension(
|
|
'ext.flutter.connectedVmServiceUri',
|
|
);
|
|
final String vmServiceUri = response.json!['value'] as String;
|
|
|
|
// Attach with a different DevTools server address.
|
|
await flutterAttach.attach(
|
|
flutterRun.vmServicePort!,
|
|
additionalCommandArgs: <String>['--devtools-server-address', 'http://127.0.0.1:9110'],
|
|
);
|
|
await pollForServiceExtensionValue<String>(
|
|
testDriver: flutterAttach,
|
|
extension: 'ext.flutter.activeDevToolsServerAddress',
|
|
continuePollingValue: '',
|
|
matches: equals('http://127.0.0.1:9110'),
|
|
);
|
|
await pollForServiceExtensionValue<String>(
|
|
testDriver: flutterRun,
|
|
extension: 'ext.flutter.connectedVmServiceUri',
|
|
continuePollingValue: '',
|
|
matches: equals(vmServiceUri),
|
|
);
|
|
});
|
|
});
|
|
|
|
group('DDS in flutter attach', () {
|
|
late FlutterRunTestDriver flutterRun, flutterAttach;
|
|
setUp(() {
|
|
flutterRun = FlutterRunTestDriver(tempDir, logPrefix: ' RUN ', spawnDdsInstance: false);
|
|
flutterAttach = FlutterRunTestDriver(tempDir, logPrefix: 'ATTACH ');
|
|
});
|
|
|
|
tearDown(() async {
|
|
await flutterAttach.detach();
|
|
await flutterRun.stop();
|
|
});
|
|
|
|
testWithoutContext('uses the designated dds port', () async {
|
|
final int ddsPort = await getFreePort();
|
|
|
|
await flutterRun.run(withDebugger: true);
|
|
await flutterAttach.attach(
|
|
flutterRun.vmServicePort!,
|
|
additionalCommandArgs: <String>['--dds-port=$ddsPort'],
|
|
);
|
|
|
|
final Response response = await flutterAttach.callServiceExtension(
|
|
'ext.flutter.connectedVmServiceUri',
|
|
);
|
|
final String vmServiceUriString = response.json!['value'] as String;
|
|
final Uri vmServiceUri = Uri.parse(vmServiceUriString);
|
|
expect(vmServiceUri.port, equals(ddsPort));
|
|
});
|
|
});
|
|
}
|