File: test-setproctitle.js

package info (click to toggle)
nodejs 4.8.2~dfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 62,476 kB
  • ctags: 111,183
  • sloc: cpp: 661,544; ansic: 31,406; python: 23,073; makefile: 1,418; sh: 1,384; perl: 255; lisp: 222; ruby: 76; xml: 50
file content (34 lines) | stat: -rw-r--r-- 1,117 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
'use strict';
// Original test written by Jakub Lekstan <kuebzky@gmail.com>
const common = require('../common');

// FIXME add sunos support
if ('linux freebsd darwin'.indexOf(process.platform) === -1) {
  common.skip(`Unsupported platform [${process.platform}]`);
  return;
}

const assert = require('assert');
const exec = require('child_process').exec;
const path = require('path');

// The title shouldn't be too long; libuv's uv_set_process_title() out of
// security considerations no longer overwrites envp, only argv, so the
// maximum title length is possibly quite short.
let title = 'testme';

assert.notStrictEqual(process.title, title);
process.title = title;
assert.strictEqual(process.title, title);

exec(`ps -p ${process.pid} -o args=`, function callback(error, stdout, stderr) {
  assert.ifError(error);
  assert.strictEqual(stderr, '');

  // freebsd always add ' (procname)' to the process title
  // if (process.platform === 'freebsd')
  //   title += ` (${path.basename(process.execPath)})`;

  // omitting trailing whitespace and \n
  assert.strictEqual(stdout.replace(/\s+$/, ''), title);
});