mirror of
https://github.com/nodejs/node.git
synced 2024-12-01 16:10:02 +01:00
b5569dbe8d
The shell in /etc/passwd can be blank, in which case the user is given the default shell. Handle this by only checking the shell contains a path separator if the string isn't empty. PR-URL: https://github.com/nodejs/node/pull/16287 Fixes: https://github.com/nodejs/node/issues/15684 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Tobias Nießen <tniessen@tnie.de>
243 lines
7.3 KiB
JavaScript
243 lines
7.3 KiB
JavaScript
// Copyright Joyent, Inc. and other Node contributors.
|
|
//
|
|
// Permission is hereby granted, free of charge, to any person obtaining a
|
|
// copy of this software and associated documentation files (the
|
|
// "Software"), to deal in the Software without restriction, including
|
|
// without limitation the rights to use, copy, modify, merge, publish,
|
|
// distribute, sublicense, and/or sell copies of the Software, and to permit
|
|
// persons to whom the Software is furnished to do so, subject to the
|
|
// following conditions:
|
|
//
|
|
// The above copyright notice and this permission notice shall be included
|
|
// in all copies or substantial portions of the Software.
|
|
//
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
|
|
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
|
|
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
|
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
|
|
// USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
'use strict';
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
const os = require('os');
|
|
const path = require('path');
|
|
const { inspect } = require('util');
|
|
|
|
const is = {
|
|
number: (value, key) => {
|
|
assert(!isNaN(value), `${key} should not be NaN`);
|
|
assert.strictEqual(typeof value, 'number');
|
|
},
|
|
string: (value) => { assert.strictEqual(typeof value, 'string'); },
|
|
array: (value) => { assert.ok(Array.isArray(value)); },
|
|
object: (value) => {
|
|
assert.strictEqual(typeof value, 'object');
|
|
assert.notStrictEqual(value, null);
|
|
}
|
|
};
|
|
|
|
const flatten = (arr) =>
|
|
arr.reduce((acc, c) =>
|
|
acc.concat(Array.isArray(c) ? flatten(c) : c), []);
|
|
|
|
process.env.TMPDIR = '/tmpdir';
|
|
process.env.TMP = '/tmp';
|
|
process.env.TEMP = '/temp';
|
|
if (common.isWindows) {
|
|
assert.strictEqual(os.tmpdir(), '/temp');
|
|
process.env.TEMP = '';
|
|
assert.strictEqual(os.tmpdir(), '/tmp');
|
|
process.env.TMP = '';
|
|
const expected = `${process.env.SystemRoot || process.env.windir}\\temp`;
|
|
assert.strictEqual(os.tmpdir(), expected);
|
|
process.env.TEMP = '\\temp\\';
|
|
assert.strictEqual(os.tmpdir(), '\\temp');
|
|
process.env.TEMP = '\\tmpdir/';
|
|
assert.strictEqual(os.tmpdir(), '\\tmpdir/');
|
|
process.env.TEMP = '\\';
|
|
assert.strictEqual(os.tmpdir(), '\\');
|
|
process.env.TEMP = 'C:\\';
|
|
assert.strictEqual(os.tmpdir(), 'C:\\');
|
|
} else {
|
|
assert.strictEqual(os.tmpdir(), '/tmpdir');
|
|
process.env.TMPDIR = '';
|
|
assert.strictEqual(os.tmpdir(), '/tmp');
|
|
process.env.TMP = '';
|
|
assert.strictEqual(os.tmpdir(), '/temp');
|
|
process.env.TEMP = '';
|
|
assert.strictEqual(os.tmpdir(), '/tmp');
|
|
process.env.TMPDIR = '/tmpdir/';
|
|
assert.strictEqual(os.tmpdir(), '/tmpdir');
|
|
process.env.TMPDIR = '/tmpdir\\';
|
|
assert.strictEqual(os.tmpdir(), '/tmpdir\\');
|
|
process.env.TMPDIR = '/';
|
|
assert.strictEqual(os.tmpdir(), '/');
|
|
}
|
|
|
|
const endianness = os.endianness();
|
|
is.string(endianness);
|
|
assert.ok(/[BL]E/.test(endianness));
|
|
|
|
const hostname = os.hostname();
|
|
is.string(hostname);
|
|
assert.ok(hostname.length > 0);
|
|
|
|
const uptime = os.uptime();
|
|
is.number(uptime);
|
|
assert.ok(uptime > 0);
|
|
|
|
const cpus = os.cpus();
|
|
is.array(cpus);
|
|
assert.ok(cpus.length > 0);
|
|
|
|
const type = os.type();
|
|
is.string(type);
|
|
assert.ok(type.length > 0);
|
|
|
|
const release = os.release();
|
|
is.string(release);
|
|
assert.ok(release.length > 0);
|
|
//TODO: Check format on more than just AIX
|
|
if (common.isAIX)
|
|
assert.ok(/^\d+\.\d+$/.test(release));
|
|
|
|
const platform = os.platform();
|
|
is.string(platform);
|
|
assert.ok(platform.length > 0);
|
|
|
|
const arch = os.arch();
|
|
is.string(arch);
|
|
assert.ok(arch.length > 0);
|
|
|
|
if (!common.isSunOS) {
|
|
// not implemeneted yet
|
|
assert.ok(os.loadavg().length > 0);
|
|
assert.ok(os.freemem() > 0);
|
|
assert.ok(os.totalmem() > 0);
|
|
}
|
|
|
|
const interfaces = os.networkInterfaces();
|
|
switch (platform) {
|
|
case 'linux': {
|
|
const filter = (e) =>
|
|
e.address === '127.0.0.1' &&
|
|
e.netmask === '255.0.0.0';
|
|
|
|
const actual = interfaces.lo.filter(filter);
|
|
const expected = [{
|
|
address: '127.0.0.1',
|
|
netmask: '255.0.0.0',
|
|
mac: '00:00:00:00:00:00',
|
|
family: 'IPv4',
|
|
internal: true,
|
|
cidr: '127.0.0.1/8'
|
|
}];
|
|
assert.deepStrictEqual(actual, expected);
|
|
break;
|
|
}
|
|
case 'win32': {
|
|
const filter = (e) =>
|
|
e.address === '127.0.0.1';
|
|
|
|
const actual = interfaces['Loopback Pseudo-Interface 1'].filter(filter);
|
|
const expected = [{
|
|
address: '127.0.0.1',
|
|
netmask: '255.0.0.0',
|
|
mac: '00:00:00:00:00:00',
|
|
family: 'IPv4',
|
|
internal: true,
|
|
cidr: '127.0.0.1/8'
|
|
}];
|
|
assert.deepStrictEqual(actual, expected);
|
|
break;
|
|
}
|
|
}
|
|
const netmaskToCIDRSuffixMap = new Map(Object.entries({
|
|
'255.0.0.0': 8,
|
|
'255.255.255.0': 24,
|
|
'ffff:ffff:ffff:ffff::': 64,
|
|
'ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff': 128
|
|
}));
|
|
|
|
flatten(Object.values(interfaces))
|
|
.map((v) => ({ v, mask: netmaskToCIDRSuffixMap.get(v.netmask) }))
|
|
.forEach(({ v, mask }) => {
|
|
assert.ok('cidr' in v, `"cidr" prop not found in ${inspect(v)}`);
|
|
if (mask) {
|
|
assert.strictEqual(v.cidr, `${v.address}/${mask}`);
|
|
}
|
|
});
|
|
|
|
const EOL = os.EOL;
|
|
if (common.isWindows) {
|
|
assert.strictEqual(EOL, '\r\n');
|
|
} else {
|
|
assert.strictEqual(EOL, '\n');
|
|
}
|
|
|
|
const home = os.homedir();
|
|
is.string(home);
|
|
assert.ok(home.includes(path.sep));
|
|
|
|
if (common.isWindows && process.env.USERPROFILE) {
|
|
assert.strictEqual(home, process.env.USERPROFILE);
|
|
delete process.env.USERPROFILE;
|
|
assert.ok(os.homedir().includes(path.sep));
|
|
process.env.USERPROFILE = home;
|
|
} else if (!common.isWindows && process.env.HOME) {
|
|
assert.strictEqual(home, process.env.HOME);
|
|
delete process.env.HOME;
|
|
assert.ok(os.homedir().includes(path.sep));
|
|
process.env.HOME = home;
|
|
}
|
|
|
|
const pwd = os.userInfo();
|
|
is.object(pwd);
|
|
const pwdBuf = os.userInfo({ encoding: 'buffer' });
|
|
|
|
if (common.isWindows) {
|
|
assert.strictEqual(pwd.uid, -1);
|
|
assert.strictEqual(pwd.gid, -1);
|
|
assert.strictEqual(pwd.shell, null);
|
|
assert.strictEqual(pwdBuf.uid, -1);
|
|
assert.strictEqual(pwdBuf.gid, -1);
|
|
assert.strictEqual(pwdBuf.shell, null);
|
|
} else {
|
|
is.number(pwd.uid);
|
|
is.number(pwd.gid);
|
|
assert.strictEqual(typeof pwd.shell, 'string');
|
|
// It's possible for /etc/passwd to leave the user's shell blank.
|
|
if (pwd.shell.length > 0) {
|
|
assert(pwd.shell.includes(path.sep));
|
|
}
|
|
assert.strictEqual(pwd.uid, pwdBuf.uid);
|
|
assert.strictEqual(pwd.gid, pwdBuf.gid);
|
|
assert.strictEqual(pwd.shell, pwdBuf.shell.toString('utf8'));
|
|
}
|
|
|
|
is.string(pwd.username);
|
|
assert.ok(pwd.homedir.includes(path.sep));
|
|
assert.strictEqual(pwd.username, pwdBuf.username.toString('utf8'));
|
|
assert.strictEqual(pwd.homedir, pwdBuf.homedir.toString('utf8'));
|
|
|
|
assert.strictEqual(`${os.hostname}`, os.hostname());
|
|
assert.strictEqual(`${os.homedir}`, os.homedir());
|
|
assert.strictEqual(`${os.release}`, os.release());
|
|
assert.strictEqual(`${os.type}`, os.type());
|
|
assert.strictEqual(`${os.endianness}`, os.endianness());
|
|
assert.strictEqual(`${os.tmpdir}`, os.tmpdir());
|
|
assert.strictEqual(`${os.arch}`, os.arch());
|
|
assert.strictEqual(`${os.platform}`, os.platform());
|
|
|
|
assert.strictEqual(+os.totalmem, os.totalmem());
|
|
|
|
// Assert that the following values are coercible to numbers.
|
|
is.number(+os.uptime, 'uptime');
|
|
is.number(os.uptime(), 'uptime');
|
|
|
|
is.number(+os.freemem, 'freemem');
|
|
is.number(os.freemem(), 'freemem');
|