Skip to content

Commit

Permalink
fs: pass correct path to DirentFromStats during glob
Browse files Browse the repository at this point in the history
  • Loading branch information
avivkeller committed Sep 22, 2024
1 parent 2cec716 commit 375f877
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 10 deletions.
6 changes: 3 additions & 3 deletions lib/internal/fs/glob.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ const {

const { lstatSync, readdirSync } = require('fs');
const { lstat, readdir } = require('fs/promises');
const { join, resolve, basename, isAbsolute } = require('path');
const { join, resolve, basename, isAbsolute, dirname } = require('path');

const {
kEmptyObject,
Expand Down Expand Up @@ -48,7 +48,7 @@ async function getDirent(path) {
} catch {
return null;
}
return new DirentFromStats(basename(path), stat, path);
return new DirentFromStats(basename(path), stat, dirname(path));
}

/**
Expand All @@ -60,7 +60,7 @@ function getDirentSync(path) {
if (stat === undefined) {
return null;
}
return new DirentFromStats(basename(path), stat, path);
return new DirentFromStats(basename(path), stat, dirname(path));
}

class Cache {
Expand Down
20 changes: 13 additions & 7 deletions test/parallel/test-fs-glob.mjs
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import * as common from '../common/index.mjs';
import tmpdir from '../common/tmpdir.js';
import { resolve, dirname, sep, basename } from 'node:path';
import { resolve, dirname, sep, basename, relative, join, isAbsolute } from 'node:path';

Check failure on line 3 in test/parallel/test-fs-glob.mjs

View workflow job for this annotation

GitHub Actions / lint-js-and-md

'basename' is defined but never used
import { mkdir, writeFile, symlink, glob as asyncGlob } from 'node:fs/promises';
import { glob, globSync, Dirent } from 'node:fs';
import { test, describe } from 'node:test';
Expand Down Expand Up @@ -348,8 +348,10 @@ describe('glob - withFileTypes', function() {
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());
assert.deepStrictEqual(
actual.map((dirent) => relative(fixtureDir, join(dirent.parentPath, dirent.name))).sort(),
expected.map(path => isAbsolute(path) ? relative(fixtureDir, path) : path).sort()

Check failure on line 353 in test/parallel/test-fs-glob.mjs

View workflow job for this annotation

GitHub Actions / lint-js-and-md

Arrow function used ambiguously with a conditional expression

Check failure on line 353 in test/parallel/test-fs-glob.mjs

View workflow job for this annotation

GitHub Actions / lint-js-and-md

Expected parentheses around arrow function argument
);
});
}
});
Expand All @@ -363,8 +365,10 @@ describe('globSync - withFileTypes', function() {
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());
assert.deepStrictEqual(
actual.map((dirent) => relative(fixtureDir, join(dirent.parentPath, dirent.name))).sort(),
expected.map(path => isAbsolute(path) ? relative(fixtureDir, path) : path).sort()

Check failure on line 370 in test/parallel/test-fs-glob.mjs

View workflow job for this annotation

GitHub Actions / lint-js-and-md

Arrow function used ambiguously with a conditional expression

Check failure on line 370 in test/parallel/test-fs-glob.mjs

View workflow job for this annotation

GitHub Actions / lint-js-and-md

Expected parentheses around arrow function argument
);
});
}
});
Expand All @@ -379,8 +383,10 @@ describe('fsPromises glob - withFileTypes', function() {
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());
assert.deepStrictEqual(
actual.map((dirent) => relative(fixtureDir, join(dirent.parentPath, dirent.name))).sort(),
expected.map(path => isAbsolute(path) ? relative(fixtureDir, path) : path).sort()

Check failure on line 388 in test/parallel/test-fs-glob.mjs

View workflow job for this annotation

GitHub Actions / lint-js-and-md

Arrow function used ambiguously with a conditional expression

Check failure on line 388 in test/parallel/test-fs-glob.mjs

View workflow job for this annotation

GitHub Actions / lint-js-and-md

Expected parentheses around arrow function argument
);
});
}
});

0 comments on commit 375f877

Please sign in to comment.