/* * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one * or more contributor license agreements. Licensed under the Elastic License * 2.0 and the Server Side Public License, v 1; you may not use this file except * in compliance with, at your election, the Elastic License 2.0 or the Server * Side Public License, v 1. */ import { Session } from './session'; interface StartProfilingArgs { interval: number; } // Start a new profile, resolves to a function to stop the profile and resolve // the profile data. export async function startProfiling( session: Session, args: StartProfilingArgs ): Promise<() => any> { session.logger.info(`starting cpu profile with args: ${JSON.stringify(args)}`); await session.post('Profiler.enable'); // microseconds, v8 default is 1000 await session.post('Profiler.setSamplingInterval', args); await session.post('Profiler.start'); // returned function which stops the profile and resolves to the profile data return async function stopProfiling() { session.logger.info('stopping cpu profile'); const result: any = await session.post('Profiler.stop'); return result.profile; }; }