aboutsummaryrefslogtreecommitdiff
path: root/node_modules/pstree.remy/tests/index.test.js
diff options
context:
space:
mode:
authorMinteck <contact@minteck.org>2022-06-04 08:51:01 +0200
committerMinteck <contact@minteck.org>2022-06-04 08:51:01 +0200
commit383285ecd5292bf9a825e05904955b937de84cc9 (patch)
tree0a53b6f02c1604b078044567c03dc1b6c944c8c2 /node_modules/pstree.remy/tests/index.test.js
downloadequestriadb-383285ecd5292bf9a825e05904955b937de84cc9.tar.gz
equestriadb-383285ecd5292bf9a825e05904955b937de84cc9.tar.bz2
equestriadb-383285ecd5292bf9a825e05904955b937de84cc9.zip
Initial commit
Diffstat (limited to 'node_modules/pstree.remy/tests/index.test.js')
-rw-r--r--node_modules/pstree.remy/tests/index.test.js51
1 files changed, 51 insertions, 0 deletions
diff --git a/node_modules/pstree.remy/tests/index.test.js b/node_modules/pstree.remy/tests/index.test.js
new file mode 100644
index 0000000..50096b9
--- /dev/null
+++ b/node_modules/pstree.remy/tests/index.test.js
@@ -0,0 +1,51 @@
+const tap = require('tap');
+const test = tap.test;
+const readFile = require('fs').readFileSync;
+const spawn = require('child_process').spawn;
+const pstree = require('../');
+const { tree, pidsForTree, getStat } = require('../lib/utils');
+
+if (process.platform !== 'darwin') {
+ test('reads from /proc', async (t) => {
+ const ps = await getStat();
+ t.ok(ps.split('\n').length > 1);
+ });
+}
+
+test('tree for live env', async (t) => {
+ const pid = 4079;
+ const fixture = readFile(__dirname + '/fixtures/out2', 'utf8');
+ const ps = await tree(fixture);
+ t.deepEqual(
+ pidsForTree(ps, pid).map((_) => _.PID),
+ ['4080']
+ );
+});
+
+function testTree(t, runCallCount) {
+ const sub = spawn('node', [`${__dirname}/fixtures/index.js`, runCallCount], {
+ stdio: 'pipe',
+ });
+ setTimeout(() => {
+ const pid = sub.pid;
+
+ pstree(pid, (error, pids) => {
+ pids.concat([pid]).forEach((p) => {
+ spawn('kill', ['-s', 'SIGTERM', p]);
+ });
+
+ // the fixture launches `sh` which launches node which is why we
+ // are looking for two processes.
+ // Important: IDKW but MacOS seems to skip the `sh` process. no idea.
+ t.equal(pids.length, runCallCount * 2);
+ t.end();
+ });
+ }, 1000);
+}
+
+test('can read full process tree', (t) => {
+ testTree(t, 1);
+});
+test('can read full process tree with multiple processes', (t) => {
+ testTree(t, 2);
+});