Files
flipper/desktop/app/src/utils/processCleanup.tsx
Pascal Hartig fc9ed65762 prettier 2
Summary:
Quick notes:

- This looks worse than it is. It adds mandatory parentheses to single argument lambdas. Lots of outrage on Twitter about it, personally I'm {emoji:1f937_200d_2642} about it.
- Space before function, e.g. `a = function ()` is now enforced. I like this because both were fine before.
- I added `eslint-config-prettier` to the config because otherwise a ton of rules conflict with eslint itself.

Close https://github.com/facebook/flipper/pull/915

Reviewed By: jknoxville

Differential Revision: D20594929

fbshipit-source-id: ca1c65376b90e009550dd6d1f4e0831d32cbff03
2020-03-24 09:38:11 -07:00

42 lines
1.4 KiB
TypeScript

/**
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
* @format
*/
import {exec} from 'promisify-child-process';
import {notNull} from '../utils/typeUtils';
import {kill} from 'process';
// Kills any orphaned Instruments processes belonging to the user.
//
// In some cases, we've seen interactions between Instruments and the iOS
// simulator that cause hung instruments and DTServiceHub processes. If
// enough instances pile up, the host machine eventually becomes
// unresponsive. Until the underlying issue is resolved, manually kill any
// orphaned instances (where the parent process has died and PPID is 1)
// before launching another instruments run.
export async function killOrphanedInstrumentsProcesses() {
const result = await exec('ps -e -o user,ppid,pid,comm');
result.stdout
?.toString()
.split('\n')
.filter(notNull)
.map((a) => /^(\S+)\s+1\s+(\d+)\s+(.+)$/.exec(a))
.filter(notNull)
.filter((m) => m[1] === process.env.USER)
.filter(
(m) =>
m[3] &&
['/instruments', '/DTServiceHub'].some((name) => m[3].endsWith(name)),
)
.forEach((m) => {
const pid = m[2];
console.debug(`Killing orphaned Instruments process: ${pid}`);
kill(parseInt(pid, 10), 'SIGKILL');
});
}