blob: 630dd02187f31c0d586c00d3fc21cd13f498d2c6 [file] [log] [blame]
// Copyright (c) 2021, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
import 'dart:developer';
import 'dart:isolate' as I;
import 'package:vm_service/vm_service.dart';
import 'package:vm_service/vm_service_io.dart';
int fib(int n) {
if (n <= 1) return n;
return fib(n - 1) + fib(n - 2);
}
Future<void> main() async {
// Do some work.
fib(20);
ServiceProtocolInfo serviceInfo = await Service.getInfo();
while (serviceInfo.serverUri == null) {
await Future.delayed(const Duration(milliseconds: 200));
serviceInfo = await Service.getInfo();
}
final isolateId = Service.getIsolateID(I.Isolate.current)!;
final uri = serviceInfo.serverUri!.replace(scheme: 'ws', pathSegments: [
...serviceInfo.serverUri!.pathSegments.where((e) => e != ''),
'ws'
]);
final service = await vmServiceConnectUri(uri.toString());
final timeExtent = Duration(minutes: 5).inMicroseconds;
final samples = await service.getCpuSamples(isolateId, 0, timeExtent);
// Cleanup VM service connection as it's no longer needed.
await service.dispose();
final functions = samples.functions!.where((f) => f.kind! == 'Dart').toList();
if (functions.isEmpty) {
print('FAILED: could not find a profiled Dart function');
return;
}
functions.retainWhere((f) => f.resolvedUrl!.isNotEmpty);
if (functions.isNotEmpty) {
print('SUCCESS');
} else {
print('FAILED');
}
}