test: use tmpDir instead of fixtures in readdir
This patch - makes the test use tmp directory instead of the fixtures directory, - simplifies the code - moves the test to `parallel`. PR-URL: https://github.com/nodejs/node/pull/2587 Reviewed-By: Rich Trott <rtrott@gmail.com>
This commit is contained in:
parent
229a03f1bb
commit
61d48b45b5
0
test/fixtures/readdir/are
vendored
0
test/fixtures/readdir/are
vendored
0
test/fixtures/readdir/dir/empty
vendored
0
test/fixtures/readdir/dir/empty
vendored
0
test/fixtures/readdir/empty
vendored
0
test/fixtures/readdir/empty
vendored
0
test/fixtures/readdir/files
vendored
0
test/fixtures/readdir/files
vendored
0
test/fixtures/readdir/for
vendored
0
test/fixtures/readdir/for
vendored
0
test/fixtures/readdir/just
vendored
0
test/fixtures/readdir/just
vendored
0
test/fixtures/readdir/testing.js
vendored
0
test/fixtures/readdir/testing.js
vendored
0
test/fixtures/readdir/these
vendored
0
test/fixtures/readdir/these
vendored
36
test/parallel/test-fs-readdir.js
Normal file
36
test/parallel/test-fs-readdir.js
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
const common = require('../common');
|
||||||
|
const assert = require('assert');
|
||||||
|
const path = require('path');
|
||||||
|
const fs = require('fs');
|
||||||
|
|
||||||
|
const readdirDir = common.tmpDir;
|
||||||
|
const files = ['empty', 'files', 'for', 'just', 'testing'];
|
||||||
|
|
||||||
|
// Make sure tmp directory is clean
|
||||||
|
common.refreshTmpDir();
|
||||||
|
|
||||||
|
// Create the necessary files
|
||||||
|
files.forEach(function(currentFile) {
|
||||||
|
fs.closeSync(fs.openSync(readdirDir + '/' + currentFile, 'w'));
|
||||||
|
});
|
||||||
|
|
||||||
|
// Check the readdir Sync version
|
||||||
|
assert.deepEqual(files, fs.readdirSync(readdirDir).sort());
|
||||||
|
|
||||||
|
// Check the readdir async version
|
||||||
|
fs.readdir(readdirDir, common.mustCall(function(err, f) {
|
||||||
|
assert.ifError(err);
|
||||||
|
assert.deepEqual(files, f.sort());
|
||||||
|
}));
|
||||||
|
|
||||||
|
// readdir() on file should throw ENOTDIR
|
||||||
|
// https://github.com/joyent/node/issues/1869
|
||||||
|
assert.throws(function() {
|
||||||
|
fs.readdirSync(__filename);
|
||||||
|
}, /Error: ENOTDIR: not a directory/);
|
||||||
|
|
||||||
|
fs.readdir(__filename, common.mustCall(function(e) {
|
||||||
|
assert.equal(e.code, 'ENOTDIR');
|
||||||
|
}));
|
@ -1,71 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
var common = require('../common');
|
|
||||||
var assert = require('assert');
|
|
||||||
var path = require('path');
|
|
||||||
var fs = require('fs');
|
|
||||||
|
|
||||||
var got_error = false,
|
|
||||||
readdirDir = path.join(common.fixturesDir, 'readdir');
|
|
||||||
|
|
||||||
var files = ['are',
|
|
||||||
'dir',
|
|
||||||
'empty',
|
|
||||||
'files',
|
|
||||||
'for',
|
|
||||||
'just',
|
|
||||||
'testing.js',
|
|
||||||
'these'];
|
|
||||||
|
|
||||||
|
|
||||||
console.log('readdirSync ' + readdirDir);
|
|
||||||
var f = fs.readdirSync(readdirDir);
|
|
||||||
console.dir(f);
|
|
||||||
assert.deepEqual(files, f.sort());
|
|
||||||
|
|
||||||
|
|
||||||
console.log('readdir ' + readdirDir);
|
|
||||||
fs.readdir(readdirDir, function(err, f) {
|
|
||||||
if (err) {
|
|
||||||
console.log('error');
|
|
||||||
got_error = true;
|
|
||||||
} else {
|
|
||||||
console.dir(f);
|
|
||||||
assert.deepEqual(files, f.sort());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
process.on('exit', function() {
|
|
||||||
assert.equal(false, got_error);
|
|
||||||
console.log('exit');
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
// readdir() on file should throw ENOTDIR
|
|
||||||
// https://github.com/joyent/node/issues/1869
|
|
||||||
(function() {
|
|
||||||
var has_caught = false;
|
|
||||||
|
|
||||||
try {
|
|
||||||
fs.readdirSync(__filename);
|
|
||||||
}
|
|
||||||
catch (e) {
|
|
||||||
has_caught = true;
|
|
||||||
assert.equal(e.code, 'ENOTDIR');
|
|
||||||
}
|
|
||||||
|
|
||||||
assert(has_caught);
|
|
||||||
})();
|
|
||||||
|
|
||||||
|
|
||||||
(function() {
|
|
||||||
var readdir_cb_called = false;
|
|
||||||
|
|
||||||
fs.readdir(__filename, function(e) {
|
|
||||||
readdir_cb_called = true;
|
|
||||||
assert.equal(e.code, 'ENOTDIR');
|
|
||||||
});
|
|
||||||
|
|
||||||
process.on('exit', function() {
|
|
||||||
assert(readdir_cb_called);
|
|
||||||
});
|
|
||||||
})();
|
|
Loading…
x
Reference in New Issue
Block a user