Skip to content

Commit

Permalink
Update: Add mkdirp Windows tests & improve mkdirp tests (closes #180)
Browse files Browse the repository at this point in the history
  • Loading branch information
phated committed Nov 28, 2017
1 parent 2423450 commit 98e5c8f
Showing 1 changed file with 46 additions and 22 deletions.
68 changes: 46 additions & 22 deletions test/file-operations.js
Original file line number Diff line number Diff line change
Expand Up @@ -917,85 +917,111 @@ describe('mkdirp', function() {
var DEFAULT_DIR_MODE = parseInt('0777', 8);
var MODE_MASK = parseInt('0777', 8);

it('makes single directory', function(done) {
var dir = path.join(__dirname, './fixtures/bif');

afterEach(function() {
return del(dir);
});

it('makes a single directory', function(done) {
mkdirp(dir, function(err) {
expect(err).toNotExist();

fs.stat(dir, function(err2, stats) {
expect(err2).toNotExist();
expect(stats).toExist();

done();
});
});
});

it('makes single directory w/ correct permissions', function(done) {
if (isWindows) {
this.skip();
return;
}

var dir = path.join(__dirname, './fixtures/bif');
mkdirp(dir, function(err) {
expect(err).toNotExist();

fs.stat(dir, function(err2, stats) {
expect(err2).toNotExist();
expect(stats.mode & MODE_MASK).toEqual(DEFAULT_DIR_MODE & ~process.umask());
del(dir);

done();
});
});
});

it('makes multiple directories', function(done) {
var nestedDir = path.join(dir, './bam/bof');
mkdirp(nestedDir, function(err) {
expect(err).toNotExist();

fs.stat(nestedDir, function(err2, stats) {
expect(err2).toNotExist();
expect(stats).toExist();

done();
});
});
});

it('makes multiple directories w/ correct permissions', function(done) {
if (isWindows) {
this.skip();
return;
}

var dir = path.join(__dirname, './fixtures/bif/bam/bof');
mkdirp(dir, function(err) {
var nestedDir = path.join(dir, './bam/bof');
mkdirp(nestedDir, function(err) {
expect(err).toNotExist();

fs.stat(dir, function(err2, stats) {
fs.stat(nestedDir, function(err2, stats) {
expect(err2).toNotExist();
expect(stats.mode & MODE_MASK).toEqual(DEFAULT_DIR_MODE & ~process.umask());
del(path.join(__dirname, './fixtures/bif'));

done();
});
});
});

it('makes directory with mode', function(done) {
it('makes directory with custom mode', function(done) {
if (isWindows) {
this.skip();
return;
}

var dir = path.join(__dirname, './fixtures/bif');
var mode = parseInt('0700',8);
mkdirp(dir, mode, function(err) {
expect(err).toNotExist();

fs.stat(dir, function(err2, stats) {
expect(err2).toNotExist();
expect(stats.mode & MODE_MASK).toEqual(mode & ~process.umask());
del(dir).then(function() {
done();
});

done();
});
});
});

it('makes multiple directories with mode', function(done) {
it('makes multiple directories with custom mode', function(done) {
if (isWindows) {
this.skip();
return;
}

var dir = path.join(__dirname, './fixtures/bif/bam/bof');
var nestedDir = path.join(dir, './bam/bof');
var mode = parseInt('0700',8);
mkdirp(dir, mode, function(err) {
mkdirp(nestedDir, mode, function(err) {
expect(err).toNotExist();

fs.stat(dir, function(err2, stats) {
fs.stat(nestedDir, function(err2, stats) {
expect(err2).toNotExist();
expect(stats.mode & MODE_MASK).toEqual(mode & ~process.umask());
del(path.join(__dirname, './fixtures/bif'))
.then(function() {
done();
});

done();
});
});
});
Expand All @@ -1006,7 +1032,6 @@ describe('mkdirp', function() {
return;
}

var dir = path.join(__dirname, './fixtures/bif');
var mode = parseInt('0700',8);
mkdirp(dir, function(err) {
expect(err).toNotExist();
Expand All @@ -1021,7 +1046,6 @@ describe('mkdirp', function() {
fs.stat(dir, function(err4, stats) {
expect(err2).toNotExist();
expect(stats.mode & MODE_MASK).toEqual(mode & ~process.umask());
del(path.join(__dirname, './fixtures/bif'));

done();
});
Expand Down

0 comments on commit 98e5c8f

Please sign in to comment.