From dd99c3bdb6aeccc8a19a14ce238dd17a4d94c30a Mon Sep 17 00:00:00 2001 From: Sergey Chernyshev Date: Wed, 24 Apr 2024 23:39:13 +0200 Subject: [PATCH] test: disambiguate AIX and IBM i When built with Python 3.9 on IBM i, `process.platform` will return `os400` instead of `aix`. In preparation for this, make `common.isAIX` only return true for AIX and update the tests to add checks for `common.isIBMi` where they were missing. PR-URL: https://github.com/nodejs/node/pull/48056 Refs: https://github.com/nodejs/node/pull/46739 Refs: https://github.com/nodejs/build/pull/3358 Reviewed-By: Moshe Atlow Reviewed-By: Michael Dawson Reviewed-By: Luigi Pinca --- .../test/abort/test-addon-uv-handle-leak.js | 1 + graal-nodejs/test/common/index.js | 9 ++++++--- .../test/known_issues/test-cwd-enoent-file.js | 2 +- .../test/parallel/test-cwd-enoent-preload.js | 2 +- graal-nodejs/test/parallel/test-cwd-enoent-repl.js | 2 +- graal-nodejs/test/parallel/test-cwd-enoent.js | 2 +- .../test/parallel/test-fs-readfile-pipe-large.js | 2 +- graal-nodejs/test/parallel/test-fs-readfile-pipe.js | 2 +- .../parallel/test-fs-readfilesync-pipe-large.js | 2 +- graal-nodejs/test/parallel/test-fs-realpath-pipe.js | 2 +- graal-nodejs/test/parallel/test-fs-utimes.js | 2 +- graal-nodejs/test/parallel/test-os.js | 13 ++++++++----- .../test-process-dlopen-error-message-crash.js | 2 +- 13 files changed, 25 insertions(+), 18 deletions(-) diff --git a/graal-nodejs/test/abort/test-addon-uv-handle-leak.js b/graal-nodejs/test/abort/test-addon-uv-handle-leak.js index e494b12f2de..d2c4f8e646f 100644 --- a/graal-nodejs/test/abort/test-addon-uv-handle-leak.js +++ b/graal-nodejs/test/abort/test-addon-uv-handle-leak.js @@ -78,6 +78,7 @@ if (process.argv[2] === 'child') { if (!(common.isFreeBSD || common.isAIX || + common.isIBMi || (common.isLinux && !isGlibc()) || common.isWindows)) { assert(stderr.includes('ExampleOwnerClass'), stderr); diff --git a/graal-nodejs/test/common/index.js b/graal-nodejs/test/common/index.js index e0c6e7aa0c9..b3a7a9d09bc 100644 --- a/graal-nodejs/test/common/index.js +++ b/graal-nodejs/test/common/index.js @@ -119,7 +119,6 @@ if (process.argv.length === 2 && } const isWindows = process.platform === 'win32'; -const isAIX = process.platform === 'aix'; const isSunOS = process.platform === 'sunos'; const isFreeBSD = process.platform === 'freebsd'; const isOpenBSD = process.platform === 'openbsd'; @@ -262,7 +261,7 @@ function platformTimeout(ms) { if (process.features.debug) ms = multipliers.two * ms; - if (isAIX) + if (exports.isAIX || exports.isIBMi) return multipliers.two * ms; // Default localhost speed is slower on AIX if (isPi) @@ -902,7 +901,6 @@ const common = { hasQuic, hasMultiLocalhost, invalidArgTypeHelper, - isAIX, isAlive, isAsan, isDumbTerminal, @@ -966,7 +964,12 @@ const common = { }, // On IBMi, process.platform and os.platform() both return 'aix', + // when built with Python versions earlier than 3.9. // It is not enough to differentiate between IBMi and real AIX system. + get isAIX() { + return require('os').type() === 'AIX'; + }, + get isIBMi() { return require('os').type() === 'OS400'; }, diff --git a/graal-nodejs/test/known_issues/test-cwd-enoent-file.js b/graal-nodejs/test/known_issues/test-cwd-enoent-file.js index 0f75896134f..6d99987895b 100644 --- a/graal-nodejs/test/known_issues/test-cwd-enoent-file.js +++ b/graal-nodejs/test/known_issues/test-cwd-enoent-file.js @@ -5,7 +5,7 @@ const common = require('../common'); const assert = require('assert'); -if (common.isSunOS || common.isWindows || common.isAIX) { +if (common.isSunOS || common.isWindows || common.isAIX || common.isIBMi) { // The current working directory cannot be removed on these platforms. // Change this to common.skip() when this is no longer a known issue test. assert.fail('cannot rmdir current working directory'); diff --git a/graal-nodejs/test/parallel/test-cwd-enoent-preload.js b/graal-nodejs/test/parallel/test-cwd-enoent-preload.js index 2077d9c1478..21b20d6d035 100644 --- a/graal-nodejs/test/parallel/test-cwd-enoent-preload.js +++ b/graal-nodejs/test/parallel/test-cwd-enoent-preload.js @@ -1,7 +1,7 @@ 'use strict'; const common = require('../common'); // Fails with EINVAL on SmartOS, EBUSY on Windows, EBUSY on AIX. -if (common.isSunOS || common.isWindows || common.isAIX) +if (common.isSunOS || common.isWindows || common.isAIX || common.isIBMi) common.skip('cannot rmdir current working directory'); if (!common.isMainThread) common.skip('process.chdir is not available in Workers'); diff --git a/graal-nodejs/test/parallel/test-cwd-enoent-repl.js b/graal-nodejs/test/parallel/test-cwd-enoent-repl.js index 5ea8abc7e42..0a61cbfbced 100644 --- a/graal-nodejs/test/parallel/test-cwd-enoent-repl.js +++ b/graal-nodejs/test/parallel/test-cwd-enoent-repl.js @@ -1,7 +1,7 @@ 'use strict'; const common = require('../common'); // Fails with EINVAL on SmartOS, EBUSY on Windows, EBUSY on AIX. -if (common.isSunOS || common.isWindows || common.isAIX) +if (common.isSunOS || common.isWindows || common.isAIX || common.isIBMi) common.skip('cannot rmdir current working directory'); if (!common.isMainThread) common.skip('process.chdir is not available in Workers'); diff --git a/graal-nodejs/test/parallel/test-cwd-enoent.js b/graal-nodejs/test/parallel/test-cwd-enoent.js index 8beb1e3fbe0..876888bc2be 100644 --- a/graal-nodejs/test/parallel/test-cwd-enoent.js +++ b/graal-nodejs/test/parallel/test-cwd-enoent.js @@ -1,7 +1,7 @@ 'use strict'; const common = require('../common'); // Fails with EINVAL on SmartOS, EBUSY on Windows, EBUSY on AIX. -if (common.isSunOS || common.isWindows || common.isAIX) +if (common.isSunOS || common.isWindows || common.isAIX || common.isIBMi) common.skip('cannot rmdir current working directory'); if (!common.isMainThread) common.skip('process.chdir is not available in Workers'); diff --git a/graal-nodejs/test/parallel/test-fs-readfile-pipe-large.js b/graal-nodejs/test/parallel/test-fs-readfile-pipe-large.js index 14a0793620b..3e8ca1ecab6 100644 --- a/graal-nodejs/test/parallel/test-fs-readfile-pipe-large.js +++ b/graal-nodejs/test/parallel/test-fs-readfile-pipe-large.js @@ -3,7 +3,7 @@ const common = require('../common'); // Simulate `cat readfile.js | node readfile.js` -if (common.isWindows || common.isAIX) +if (common.isWindows || common.isAIX || common.isIBMi) common.skip(`No /dev/stdin on ${process.platform}.`); const assert = require('assert'); diff --git a/graal-nodejs/test/parallel/test-fs-readfile-pipe.js b/graal-nodejs/test/parallel/test-fs-readfile-pipe.js index 0cffbd0f5aa..79d5699fef6 100644 --- a/graal-nodejs/test/parallel/test-fs-readfile-pipe.js +++ b/graal-nodejs/test/parallel/test-fs-readfile-pipe.js @@ -24,7 +24,7 @@ const common = require('../common'); // Simulate `cat readfile.js | node readfile.js` -if (common.isWindows || common.isAIX) +if (common.isWindows || common.isAIX || common.isIBMi) common.skip(`No /dev/stdin on ${process.platform}.`); const assert = require('assert'); diff --git a/graal-nodejs/test/parallel/test-fs-readfilesync-pipe-large.js b/graal-nodejs/test/parallel/test-fs-readfilesync-pipe-large.js index 7c2a5e7fd01..722689aeac7 100644 --- a/graal-nodejs/test/parallel/test-fs-readfilesync-pipe-large.js +++ b/graal-nodejs/test/parallel/test-fs-readfilesync-pipe-large.js @@ -3,7 +3,7 @@ const common = require('../common'); // Simulate `cat readfile.js | node readfile.js` -if (common.isWindows || common.isAIX) +if (common.isWindows || common.isAIX || common.isIBMi) common.skip(`No /dev/stdin on ${process.platform}.`); const assert = require('assert'); diff --git a/graal-nodejs/test/parallel/test-fs-realpath-pipe.js b/graal-nodejs/test/parallel/test-fs-realpath-pipe.js index 29fe1d3b7d2..f637642ca21 100644 --- a/graal-nodejs/test/parallel/test-fs-realpath-pipe.js +++ b/graal-nodejs/test/parallel/test-fs-realpath-pipe.js @@ -2,7 +2,7 @@ const common = require('../common'); -if (common.isWindows || common.isAIX) +if (common.isWindows || common.isAIX || common.isIBMi) common.skip(`No /dev/stdin on ${process.platform}.`); const assert = require('assert'); diff --git a/graal-nodejs/test/parallel/test-fs-utimes.js b/graal-nodejs/test/parallel/test-fs-utimes.js index 8f8286f8a33..e6ae75d4e33 100644 --- a/graal-nodejs/test/parallel/test-fs-utimes.js +++ b/graal-nodejs/test/parallel/test-fs-utimes.js @@ -39,7 +39,7 @@ function stat_resource(resource, statSync = fs.statSync) { const stats = fs.fstatSync(resource); // Ensure mtime has been written to disk // except for directories on AIX where it cannot be synced - if (common.isAIX && stats.isDirectory()) + if ((common.isAIX || common.isIBMi) && stats.isDirectory()) return stats; fs.fsyncSync(resource); return fs.fstatSync(resource); diff --git a/graal-nodejs/test/parallel/test-os.js b/graal-nodejs/test/parallel/test-os.js index d82f2ece315..f7059260ce5 100644 --- a/graal-nodejs/test/parallel/test-os.js +++ b/graal-nodejs/test/parallel/test-os.js @@ -81,11 +81,14 @@ const hostname = os.hostname(); is.string(hostname); assert.ok(hostname.length > 0); -const DUMMY_PRIORITY = 10; -os.setPriority(DUMMY_PRIORITY); -const priority = os.getPriority(); -is.number(priority); -assert.strictEqual(priority, DUMMY_PRIORITY); +// IBMi process priority is different. +if (!common.isIBMi) { + const DUMMY_PRIORITY = 10; + os.setPriority(DUMMY_PRIORITY); + const priority = os.getPriority(); + is.number(priority); + assert.strictEqual(priority, DUMMY_PRIORITY); +} // On IBMi, os.uptime() returns 'undefined' if (!common.isIBMi) { diff --git a/graal-nodejs/test/parallel/test-process-dlopen-error-message-crash.js b/graal-nodejs/test/parallel/test-process-dlopen-error-message-crash.js index d678021764e..de8b3033195 100644 --- a/graal-nodejs/test/parallel/test-process-dlopen-error-message-crash.js +++ b/graal-nodejs/test/parallel/test-process-dlopen-error-message-crash.js @@ -17,7 +17,7 @@ assert.throws(() => { }, ({ name, code, message }) => { assert.strictEqual(name, 'Error'); assert.strictEqual(code, 'ERR_DLOPEN_FAILED'); - if (!common.isAIX) { + if (!common.isAIX && !common.isIBMi) { assert.match(message, /foo-%s\.node/); } return true;