From a45f06b9b973c8489f01fbcf28dda2a226073a99 Mon Sep 17 00:00:00 2001 From: Sergey Chernyshev Date: Thu, 25 Apr 2024 00:14:02 +0200 Subject: [PATCH] fs: fix readdir recursive sync & callback Refs: https://github.com/nodejs/node/issues/48640 PR-URL: https://github.com/nodejs/node/pull/48698 Fixes: https://github.com/nodejs/node/issues/48858 Reviewed-By: Ruben Bridgewater Reviewed-By: Benjamin Gruenbaum Reviewed-By: Moshe Atlow Reviewed-By: Yagiz Nizipli --- graal-nodejs/lib/fs.js | 13 ++++++++++--- .../test/sequential/test-fs-readdir-recursive.js | 2 ++ 2 files changed, 12 insertions(+), 3 deletions(-) diff --git a/graal-nodejs/lib/fs.js b/graal-nodejs/lib/fs.js index 1f695f6b085..fd99fef03c5 100644 --- a/graal-nodejs/lib/fs.js +++ b/graal-nodejs/lib/fs.js @@ -1430,14 +1430,21 @@ function readdirSyncRecursive(basePath, options) { ); handleErrorFromBinding(ctx); - for (let i = 0; i < readdirResult.length; i++) { - if (withFileTypes) { + if (withFileTypes) { + // Calling `readdir` with `withFileTypes=true`, the result is an array of arrays. + // The first array is the names, and the second array is the types. + // They are guaranteed to be the same length; hence, setting `length` to the length + // of the first array within the result. + const length = readdirResult[0].length; + for (let i = 0; i < length; i++) { const dirent = getDirent(path, readdirResult[0][i], readdirResult[1][i]); ArrayPrototypePush(readdirResults, dirent); if (dirent.isDirectory()) { ArrayPrototypePush(pathsQueue, pathModule.join(dirent.path, dirent.name)); } - } else { + } + } else { + for (let i = 0; i < readdirResult.length; i++) { const resultPath = pathModule.join(path, readdirResult[i]); const relativeResultPath = pathModule.relative(basePath, resultPath); const stat = binding.internalModuleStat(resultPath); diff --git a/graal-nodejs/test/sequential/test-fs-readdir-recursive.js b/graal-nodejs/test/sequential/test-fs-readdir-recursive.js index 3ced1434f30..1bb69f203ea 100644 --- a/graal-nodejs/test/sequential/test-fs-readdir-recursive.js +++ b/graal-nodejs/test/sequential/test-fs-readdir-recursive.js @@ -131,9 +131,11 @@ function getDirentPath(dirent) { } function assertDirents(dirents) { + assert.strictEqual(dirents.length, expected.length); dirents.sort((a, b) => (getDirentPath(a) < getDirentPath(b) ? -1 : 1)); for (const [i, dirent] of dirents.entries()) { assert(dirent instanceof fs.Dirent); + assert.notStrictEqual(dirent.name, undefined); assert.strictEqual(getDirentPath(dirent), expected[i]); } }