From f1fc53d88f3126f717d65a9166e3e2d0a2edcfab Mon Sep 17 00:00:00 2001 From: SillyFreak Date: Mon, 13 Apr 2020 17:21:28 +0200 Subject: [PATCH] resolve relative paths, add two test cases --- src/shell/shell.js | 3 ++- tests/spec/shell/mkdirp.spec.js | 27 +++++++++++++++++++++++++++ 2 files changed, 29 insertions(+), 1 deletion(-) diff --git a/src/shell/shell.js b/src/shell/shell.js index 3704e1c7..1ac0371c 100644 --- a/src/shell/shell.js +++ b/src/shell/shell.js @@ -387,7 +387,8 @@ Shell.prototype.mkdirp = function(path, callback) { callback(new Errors.EINVAL('Missing path argument')); return; } - else if (path === '/') { + path = Path.resolve(sh.pwd(), path); + if (path === '/') { callback(); return; } diff --git a/tests/spec/shell/mkdirp.spec.js b/tests/spec/shell/mkdirp.spec.js index 5f88544a..d25c4665 100644 --- a/tests/spec/shell/mkdirp.spec.js +++ b/tests/spec/shell/mkdirp.spec.js @@ -30,6 +30,18 @@ describe('FileSystemShell.mkdirp', function() { }); }); + it('should succeed if provided path is root, given as a relative path (\'.\' in \'/\')', function(done) { + var fs = util.fs(); + var shell = new fs.Shell(); + shell.cd('/', function(err) { + expect(err).to.not.exist; + shell.mkdirp('.', function(err) { + expect(err).to.not.exist; + done(); + }); + }); + }); + it('should succeed if the directory exists', function(done) { var fs = util.fs(); var shell = new fs.Shell(); @@ -67,6 +79,21 @@ describe('FileSystemShell.mkdirp', function() { }); }); + it('should succeed on a folder given as a relative path (\'test\' in \'/\')', function(done) { + var fs = util.fs(); + var shell = new fs.Shell(); + shell.cd('/', function(err) { + expect(err).to.not.exist; + shell.mkdirp('test', function(err) { + expect(err).to.not.exist; + fs.exists('/test', function(dir){ + expect(dir).to.be.true; + done(); + }); + }); + }); + }); + it('should succeed on a folder with a nonexistant parent (\'/test/test\')', function(done) { var fs = util.fs(); var shell = new fs.Shell();