Skip to content

Commit

Permalink
Revert "test: refactor test-fs-error-messages.js"
Browse files Browse the repository at this point in the history
This reverts commit 907ce8d.

PR-URL: nodejs#11155
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Timothy Gu <timothygu99@gmail.com>
  • Loading branch information
jasnell authored and krydos committed Feb 25, 2017
1 parent e8145bc commit 26210b3
Showing 1 changed file with 164 additions and 118 deletions.
282 changes: 164 additions & 118 deletions test/parallel/test-fs-error-messages.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,156 +9,202 @@ const existingFile2 = path.join(common.fixturesDir, 'create-file.js');
const existingDir = path.join(common.fixturesDir, 'empty');
const existingDir2 = path.join(common.fixturesDir, 'keys');

// Test all operations failing with ENOENT errors
function testEnoentError(file, endMessage, syscal, err) {
const sufix = (endMessage) ? endMessage : '';
// ASYNC_CALL

assert(err instanceof Error);
fs.stat(fn, function(err) {
assert.strictEqual(fn, err.path);
assert.strictEqual(
err.message,
`ENOENT: no such file or directory, ${syscal} '${file}'${sufix}`
);

return true;
}
assert.ok(0 <= err.message.indexOf(fn));
});

// Test all operations failing with EEXIST errors
function testEexistError(source, dest, syscal, err) {
const sufix = (dest) ? ` -> '${dest}'` : '';
fs.lstat(fn, function(err) {
assert.ok(0 <= err.message.indexOf(fn));
});

assert(err instanceof Error);
assert.strictEqual(source, err.path);
assert.strictEqual(
err.message,
`EEXIST: file already exists, ${syscal} '${source}'${sufix}`
);
fs.readlink(fn, function(err) {
assert.ok(0 <= err.message.indexOf(fn));
});

return true;
}
fs.link(fn, 'foo', function(err) {
assert.ok(0 <= err.message.indexOf(fn));
});

// Test all operations failing with ENOTEMPTY errors
function testEnoemptyError(source, dest, err) {
assert(err instanceof Error);
assert.strictEqual(source, err.path);
assert.strictEqual(
err.message,
`ENOTEMPTY: directory not empty, rename '${source}' ` +
`-> '${dest}'`
);

return true;
}
fs.link(existingFile, existingFile2, function(err) {
assert.ok(0 <= err.message.indexOf(existingFile));
assert.ok(0 <= err.message.indexOf(existingFile2));
});

// Test all operations failing with ENOTDIR errors
function testEnotdirError(dir, err) {
assert(err instanceof Error);
assert.strictEqual(dir, err.path);
assert.strictEqual(
err.message,
`ENOTDIR: not a directory, rmdir '${dir}'`
);
fs.symlink(existingFile, existingFile2, function(err) {
assert.ok(0 <= err.message.indexOf(existingFile));
assert.ok(0 <= err.message.indexOf(existingFile2));
});

return true;
}
fs.unlink(fn, function(err) {
assert.ok(0 <= err.message.indexOf(fn));
});

// Generating ENOENTS errors
fs.stat(fn, (err) => testEnoentError(fn, '', 'stat', err));
fs.lstat(fn, (err) => testEnoentError(fn, '', 'lstat', err));
fs.readlink(fn, (err) => testEnoentError(fn, '', 'readlink', err));
fs.link(fn, 'foo', (err) => testEnoentError(fn, ' -> \'foo\'', 'link', err));
fs.unlink(fn, (err) => testEnoentError(fn, '', 'unlink', err));
fs.rmdir(fn, (err) => testEnoentError(fn, '', 'rmdir', err));
fs.chmod(fn, 0o666, (err) => testEnoentError(fn, '', 'chmod', err));
fs.open(fn, 'r', 0o666, (err) => testEnoentError(fn, '', 'open', err));
fs.readFile(fn, (err) => testEnoentError(fn, '', 'open', err));
fs.readdir(fn, (err) => testEnoentError(fn, '', 'scandir', err));
fs.rename(fn, 'foo', function(err) {
assert.ok(0 <= err.message.indexOf(fn));
});

fs.rename(fn, 'foo', (err) => {
testEnoentError(fn, ' -> \'foo\'', 'rename', err);
fs.rename(existingDir, existingDir2, function(err) {
assert.ok(0 <= err.message.indexOf(existingDir));
assert.ok(0 <= err.message.indexOf(existingDir2));
});

assert.throws(() => {
fs.statSync(fn);
}, (err) => testEnoentError(fn, '', 'stat', err));
fs.rmdir(fn, function(err) {
assert.ok(0 <= err.message.indexOf(fn));
});

assert.throws(() => {
fs.lstatSync(fn);
}, (err) => testEnoentError(fn, '', 'lstat', err));
fs.mkdir(existingFile, 0o666, function(err) {
assert.ok(0 <= err.message.indexOf(existingFile));
});

assert.throws(() => {
fs.readlinkSync(fn);
}, (err) => testEnoentError(fn, '', 'readlink', err));
fs.rmdir(existingFile, function(err) {
assert.ok(0 <= err.message.indexOf(existingFile));
});

assert.throws(() => {
fs.linkSync(fn, 'foo');
}, (err) => testEnoentError(fn, ' -> \'foo\'', 'link', err));
fs.chmod(fn, 0o666, function(err) {
assert.ok(0 <= err.message.indexOf(fn));
});

assert.throws(() => {
fs.unlinkSync(fn);
}, (err) => testEnoentError(fn, '', 'unlink', err));
fs.open(fn, 'r', 0o666, function(err) {
assert.ok(0 <= err.message.indexOf(fn));
});

assert.throws(() => {
fs.rmdirSync(fn);
}, (err) => testEnoentError(fn, '', 'rmdir', err));
fs.readFile(fn, function(err) {
assert.ok(0 <= err.message.indexOf(fn));
});

assert.throws(() => {
fs.chmodSync(fn, 0o666);
}, (err) => testEnoentError(fn, '', 'chmod', err));
// Sync

assert.throws(() => {
fs.openSync(fn, 'r');
}, (err) => testEnoentError(fn, '', 'open', err));
const errors = [];
let expected = 0;

assert.throws(() => {
fs.readFileSync(fn);
}, (err) => testEnoentError(fn, '', 'open', err));
try {
++expected;
fs.statSync(fn);
} catch (err) {
errors.push('stat');
assert.ok(0 <= err.message.indexOf(fn));
}

assert.throws(() => {
fs.readdirSync(fn);
}, (err) => testEnoentError(fn, '', 'scandir', err));
try {
++expected;
fs.mkdirSync(existingFile, 0o666);
} catch (err) {
errors.push('mkdir');
assert.ok(0 <= err.message.indexOf(existingFile));
}

assert.throws(() => {
fs.renameSync(fn, 'foo');
}, (err) => testEnoentError(fn, ' -> \'foo\'', 'rename', err));
try {
++expected;
fs.chmodSync(fn, 0o666);
} catch (err) {
errors.push('chmod');
assert.ok(0 <= err.message.indexOf(fn));
}

// Generating EEXIST errors
fs.link(existingFile, existingFile2, (err) => {
testEexistError(existingFile, existingFile2, 'link', err);
});
try {
++expected;
fs.lstatSync(fn);
} catch (err) {
errors.push('lstat');
assert.ok(0 <= err.message.indexOf(fn));
}

fs.symlink(existingFile, existingFile2, (err) => {
testEexistError(existingFile, existingFile2, 'symlink', err);
});
try {
++expected;
fs.readlinkSync(fn);
} catch (err) {
errors.push('readlink');
assert.ok(0 <= err.message.indexOf(fn));
}

fs.mkdir(existingFile, 0o666, (err) => {
testEexistError(existingFile, null, 'mkdir', err);
});
try {
++expected;
fs.linkSync(fn, 'foo');
} catch (err) {
errors.push('link');
assert.ok(0 <= err.message.indexOf(fn));
}

assert.throws(() => {
try {
++expected;
fs.linkSync(existingFile, existingFile2);
}, (err) => testEexistError(existingFile, existingFile2, 'link', err));
} catch (err) {
errors.push('link');
assert.ok(0 <= err.message.indexOf(existingFile));
assert.ok(0 <= err.message.indexOf(existingFile2));
}

assert.throws(() => {
try {
++expected;
fs.symlinkSync(existingFile, existingFile2);
}, (err) => testEexistError(existingFile, existingFile2, 'symlink', err));
} catch (err) {
errors.push('symlink');
assert.ok(0 <= err.message.indexOf(existingFile));
assert.ok(0 <= err.message.indexOf(existingFile2));
}

assert.throws(() => {
fs.mkdirSync(existingFile, 0o666);
}, (err) => testEexistError(existingFile, null, 'mkdir', err));
try {
++expected;
fs.unlinkSync(fn);
} catch (err) {
errors.push('unlink');
assert.ok(0 <= err.message.indexOf(fn));
}

// Generating ENOTEMPTY errors
fs.rename(existingDir, existingDir2, (err) => {
testEnoemptyError(existingDir, existingDir2, err);
});
try {
++expected;
fs.rmdirSync(fn);
} catch (err) {
errors.push('rmdir');
assert.ok(0 <= err.message.indexOf(fn));
}

try {
++expected;
fs.rmdirSync(existingFile);
} catch (err) {
errors.push('rmdir');
assert.ok(0 <= err.message.indexOf(existingFile));
}

try {
++expected;
fs.openSync(fn, 'r');
} catch (err) {
errors.push('opens');
assert.ok(0 <= err.message.indexOf(fn));
}

assert.throws(() => {
try {
++expected;
fs.renameSync(fn, 'foo');
} catch (err) {
errors.push('rename');
assert.ok(0 <= err.message.indexOf(fn));
}

try {
++expected;
fs.renameSync(existingDir, existingDir2);
}, (err) => testEnoemptyError(existingDir, existingDir2, err));
} catch (err) {
errors.push('rename');
assert.ok(0 <= err.message.indexOf(existingDir));
assert.ok(0 <= err.message.indexOf(existingDir2));
}

// Generating ENOTDIR errors
fs.rmdir(existingFile, (err) => testEnotdirError(existingFile, err));
try {
++expected;
fs.readdirSync(fn);
} catch (err) {
errors.push('readdir');
assert.ok(0 <= err.message.indexOf(fn));
}

assert.throws(() => {
fs.rmdirSync(existingFile);
}, (err) => testEnotdirError(existingFile, err));
process.on('exit', function() {
assert.strictEqual(expected, errors.length,
'Test fs sync exceptions raised, got ' + errors.length +
' expected ' + expected);
});

0 comments on commit 26210b3

Please sign in to comment.