* implemented first two tests of fs.promises.read * simplified the 2nd fs.promises.read test * implemented test on file position update for fs.promises.read * implemented directory read failure test for fs.promises.read * implemented test to check the return type to be a Promise in fs.promises.read * fixed indentation and also fixed a catch statement to allow all code to be reachable * made tests more promise-friendly * applied some style changes and test changes as per @rdittrich97 suggestions * removed lines that are unnecessary for promise-based testing and syntactically simplified some function definitions * removed more unnecessary check lines in directory check fail test
This commit is contained in:
parent
86b6b2a907
commit
1156f420c4
|
@ -88,3 +88,87 @@ describe('fs.read', function() {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('fs.promises.read', function() {
|
||||||
|
beforeEach(util.setup);
|
||||||
|
afterEach(util.cleanup);
|
||||||
|
|
||||||
|
it('should be a function', function() {
|
||||||
|
var fsPromises = util.fs().promises;
|
||||||
|
expect(fsPromises.read).to.be.a('function');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return a promise', function() {
|
||||||
|
var fsPromises = util.fs().promises;
|
||||||
|
expect(fsPromises.read()).to.be.a('Promise');
|
||||||
|
});
|
||||||
|
it('should read data from a file', function() {
|
||||||
|
var fsPromises = util.fs().promises;
|
||||||
|
var wbuffer = new Filer.Buffer([1, 2, 3, 4, 5, 6, 7, 8]);
|
||||||
|
var rbuffer = new Filer.Buffer(wbuffer.length);
|
||||||
|
var fdesc;
|
||||||
|
rbuffer.fill(0);
|
||||||
|
|
||||||
|
return fsPromises.open('/myfile', 'w+')
|
||||||
|
.then((fd)=>{
|
||||||
|
fdesc=fd;
|
||||||
|
return fsPromises.write(fd, wbuffer, 0, wbuffer.length, 0);
|
||||||
|
})
|
||||||
|
.then((result)=>{
|
||||||
|
expect(result).to.equal(wbuffer.length);
|
||||||
|
return fsPromises.read(fdesc, rbuffer,0,rbuffer.length,0);
|
||||||
|
})
|
||||||
|
.then((result)=>{
|
||||||
|
expect(result).to.equal(rbuffer.length);
|
||||||
|
expect(wbuffer).to.deep.equal(rbuffer);
|
||||||
|
})
|
||||||
|
;
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should update the current file position', function() {
|
||||||
|
var fsPromises = util.fs().promises;
|
||||||
|
var wbuffer = new Filer.Buffer([1, 2, 3, 4, 5, 6, 7, 8]);
|
||||||
|
var rbuffer = new Filer.Buffer(wbuffer.length);
|
||||||
|
rbuffer.fill(0);
|
||||||
|
var _result = 0;
|
||||||
|
var fdesc;
|
||||||
|
|
||||||
|
return fsPromises.open('/myfile', 'w+')
|
||||||
|
.then((fd)=>{
|
||||||
|
fdesc=fd;
|
||||||
|
return fsPromises.write(fd, wbuffer, 0, wbuffer.length, 0 );
|
||||||
|
})
|
||||||
|
.then((result)=>{
|
||||||
|
expect(result).to.equal(wbuffer.length);
|
||||||
|
return fsPromises.read(fdesc, rbuffer, 0, rbuffer.length / 2, undefined);
|
||||||
|
})
|
||||||
|
.then((result)=>{
|
||||||
|
_result += result;
|
||||||
|
return fsPromises.read(fdesc,rbuffer,rbuffer.length / 2, rbuffer.length, undefined);
|
||||||
|
})
|
||||||
|
.then((result)=>{
|
||||||
|
_result+=result;
|
||||||
|
expect(_result).to.equal(rbuffer.length);
|
||||||
|
expect(wbuffer).to.deep.equal(rbuffer);
|
||||||
|
})
|
||||||
|
;
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should fail to read a directory', function() {
|
||||||
|
var fsPromises = util.fs().promises;
|
||||||
|
var buf = new Filer.Buffer(20);
|
||||||
|
var buf2 = new Filer.Buffer(20);
|
||||||
|
buf.fill(0);
|
||||||
|
buf2.fill(0);
|
||||||
|
|
||||||
|
return fsPromises.mkdir('/mydir')
|
||||||
|
.then(()=>fsPromises.open('/mydir', 'r'))
|
||||||
|
.then(fd=>fsPromises.read(fd, buf, 0, buf.length, 0))
|
||||||
|
.catch((error)=>{
|
||||||
|
expect(error).to.exist;
|
||||||
|
expect(error.code).to.equal('EISDIR');
|
||||||
|
expect(buf).to.deep.equal(buf2);
|
||||||
|
})
|
||||||
|
;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
Loading…
Reference in New Issue