diff --git a/lib/internal/fs/glob.js b/lib/internal/fs/glob.js index 215257e1951ae9..be3c48da755520 100644 --- a/lib/internal/fs/glob.js +++ b/lib/internal/fs/glob.js @@ -542,7 +542,7 @@ class Glob { const fromSymlink = pattern.symlinks.has(index); if (current === lazyMinimatch().GLOBSTAR) { - if (entry.name[0] === '.' || (this.#exclude && this.#exclude(entry.name))) { + if (entry.name[0] === '.' || (this.#exclude && this.#exclude(this.#withFileTypes ? entry : entry.name))) { continue; } if (!fromSymlink && entry.isDirectory()) { diff --git a/test/parallel/test-fs-glob.mjs b/test/parallel/test-fs-glob.mjs index 7dcb8ecc8373a3..4038c0e165eb69 100644 --- a/test/parallel/test-fs-glob.mjs +++ b/test/parallel/test-fs-glob.mjs @@ -342,7 +342,11 @@ describe('glob - withFileTypes', function() { const promisified = promisify(glob); for (const [pattern, expected] of Object.entries(patterns)) { test(pattern, async () => { - const actual = await promisified(pattern, { cwd: fixtureDir, withFileTypes: true }); + const actual = await promisified(pattern, { + cwd: fixtureDir, + withFileTypes: true, + exclude: (dirent) => assert.ok(dirent instanceof Dirent), + }); assertDirents(actual); const normalized = expected.filter(Boolean).map((item) => basename(item)).sort(); assert.deepStrictEqual(actual.map((dirent) => dirent.name).sort(), normalized.sort()); @@ -353,7 +357,11 @@ describe('glob - withFileTypes', function() { describe('globSync - withFileTypes', function() { for (const [pattern, expected] of Object.entries(patterns)) { test(pattern, () => { - const actual = globSync(pattern, { cwd: fixtureDir, withFileTypes: true }); + const actual = globSync(pattern, { + cwd: fixtureDir, + withFileTypes: true, + exclude: (dirent) => assert.ok(dirent instanceof Dirent), + }); assertDirents(actual); const normalized = expected.filter(Boolean).map((item) => basename(item)).sort(); assert.deepStrictEqual(actual.map((dirent) => dirent.name).sort(), normalized.sort()); @@ -365,7 +373,11 @@ describe('fsPromises glob - withFileTypes', function() { for (const [pattern, expected] of Object.entries(patterns)) { test(pattern, async () => { const actual = []; - for await (const item of asyncGlob(pattern, { cwd: fixtureDir, withFileTypes: true })) actual.push(item); + for await (const item of asyncGlob(pattern, { + cwd: fixtureDir, + withFileTypes: true, + exclude: (dirent) => assert.ok(dirent instanceof Dirent), + })) actual.push(item); assertDirents(actual); const normalized = expected.filter(Boolean).map((item) => basename(item)).sort(); assert.deepStrictEqual(actual.map((dirent) => dirent.name).sort(), normalized.sort());