Add backend tests for new API functions
These new functions are: * getSavedRevisionsCount * listSavedRevisions * saveRevision + typo fixing in backend tests
This commit is contained in:
parent
845788c39d
commit
92022e493e
|
@ -63,6 +63,9 @@ Pad.prototype.getSavedRevisionsList = function getSavedRevisionsList() {
|
||||||
for(var rev in this.savedRevisions){
|
for(var rev in this.savedRevisions){
|
||||||
savedRev.push(this.savedRevisions[rev].revNum);
|
savedRev.push(this.savedRevisions[rev].revNum);
|
||||||
}
|
}
|
||||||
|
savedRev.sort(function(a, b) {
|
||||||
|
return a - b;
|
||||||
|
});
|
||||||
return savedRev;
|
return savedRev;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -48,6 +48,8 @@ describe('Permission', function(){
|
||||||
-> deletePad -- This gives us a guaranteed clear environment
|
-> deletePad -- This gives us a guaranteed clear environment
|
||||||
-> createPad
|
-> createPad
|
||||||
-> getRevisions -- Should be 0
|
-> getRevisions -- Should be 0
|
||||||
|
-> getSavedRevisionsCount(padID) -- Should be 0
|
||||||
|
-> listSavedRevisions(padID) -- Should be an empty array
|
||||||
-> getHTML -- Should be the default pad text in HTML format
|
-> getHTML -- Should be the default pad text in HTML format
|
||||||
-> deletePad -- Should just delete a pad
|
-> deletePad -- Should just delete a pad
|
||||||
-> getHTML -- Should return an error
|
-> getHTML -- Should return an error
|
||||||
|
@ -56,6 +58,9 @@ describe('Permission', function(){
|
||||||
-> setText
|
-> setText
|
||||||
-> getText -- Should be the text set before
|
-> getText -- Should be the text set before
|
||||||
-> getRevisions -- Should be 0 still?
|
-> getRevisions -- Should be 0 still?
|
||||||
|
-> saveRevision
|
||||||
|
-> getSavedRevisionsCount(padID) -- Should be 0 still?
|
||||||
|
-> listSavedRevisions(padID) -- Should be an empty array still ?
|
||||||
-> padUsersCount -- Should be 0
|
-> padUsersCount -- Should be 0
|
||||||
-> getReadOnlyId -- Should be a value
|
-> getReadOnlyId -- Should be a value
|
||||||
-> listAuthorsOfPad(padID) -- should be empty array?
|
-> listAuthorsOfPad(padID) -- should be empty array?
|
||||||
|
@ -109,11 +114,35 @@ describe('getRevisionsCount', function(){
|
||||||
});
|
});
|
||||||
})
|
})
|
||||||
|
|
||||||
|
describe('getSavedRevisionsCount', function(){
|
||||||
|
it('gets saved revisions count of Pad', function(done) {
|
||||||
|
api.get(endPoint('getSavedRevisionsCount')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0) throw new Error("Unable to get Saved Revisions Count");
|
||||||
|
if(res.body.data.savedRevisions !== 0) throw new Error("Incorrect Saved Revisions Count");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('listSavedRevisions', function(){
|
||||||
|
it('gets saved revision list of Pad', function(done) {
|
||||||
|
api.get(endPoint('listSavedRevisions')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0) throw new Error("Unable to get Saved Revisions List");
|
||||||
|
if(!res.body.data.savedRevisions.equals([])) throw new Error("Incorrect Saved Revisions List");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
describe('getHTML', function(){
|
describe('getHTML', function(){
|
||||||
it('get the HTML of Pad', function(done) {
|
it('get the HTML of Pad', function(done) {
|
||||||
api.get(endPoint('getHTML')+"&padID="+testPadId)
|
api.get(endPoint('getHTML')+"&padID="+testPadId)
|
||||||
.expect(function(res){
|
.expect(function(res){
|
||||||
if(res.body.data.html.length <= 1) throw new Error("Unable to get Revision Count");
|
if(res.body.data.html.length <= 1) throw new Error("Unable to get the HTML");
|
||||||
})
|
})
|
||||||
.expect('Content-Type', /json/)
|
.expect('Content-Type', /json/)
|
||||||
.expect(200, done)
|
.expect(200, done)
|
||||||
|
@ -187,16 +216,50 @@ describe('getText', function(){
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('getRevisionsCount', function(){
|
describe('getRevisionsCount', function(){
|
||||||
it('gets Revision Coutn of a Pad', function(done) {
|
it('gets Revision Count of a Pad', function(done) {
|
||||||
api.get(endPoint('getRevisionsCount')+"&padID="+testPadId)
|
api.get(endPoint('getRevisionsCount')+"&padID="+testPadId)
|
||||||
.expect(function(res){
|
.expect(function(res){
|
||||||
if(res.body.data.revisions !== 1) throw new Error("Unable to set text revision count")
|
if(res.body.data.revisions !== 1) throw new Error("Unable to get text revision count")
|
||||||
})
|
})
|
||||||
.expect('Content-Type', /json/)
|
.expect('Content-Type', /json/)
|
||||||
.expect(200, done)
|
.expect(200, done)
|
||||||
});
|
});
|
||||||
})
|
})
|
||||||
|
|
||||||
|
describe('saveRevision', function(){
|
||||||
|
it('saves Revision', function(done) {
|
||||||
|
api.get(endPoint('saveRevision')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0) throw new Error("Unable to save Revision");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('getSavedRevisionsCount', function(){
|
||||||
|
it('gets saved revisions count of Pad', function(done) {
|
||||||
|
api.get(endPoint('getSavedRevisionsCount')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0) throw new Error("Unable to get Saved Revisions Count");
|
||||||
|
if(res.body.data.savedRevisions !== 1) throw new Error("Incorrect Saved Revisions Count");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('listSavedRevisions', function(){
|
||||||
|
it('gets saved revision list of Pad', function(done) {
|
||||||
|
api.get(endPoint('listSavedRevisions')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0) throw new Error("Unable to get Saved Revisions List");
|
||||||
|
if(!res.body.data.savedRevisions.equals([1])) throw new Error("Incorrect Saved Revisions List");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
describe('padUsersCount', function(){
|
describe('padUsersCount', function(){
|
||||||
it('gets User Count of a Pad', function(done) {
|
it('gets User Count of a Pad', function(done) {
|
||||||
api.get(endPoint('padUsersCount')+"&padID="+testPadId)
|
api.get(endPoint('padUsersCount')+"&padID="+testPadId)
|
||||||
|
@ -461,3 +524,25 @@ function generateLongText(){
|
||||||
}
|
}
|
||||||
return text;
|
return text;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Need this to compare arrays (listSavedRevisions test)
|
||||||
|
Array.prototype.equals = function (array) {
|
||||||
|
// if the other array is a falsy value, return
|
||||||
|
if (!array)
|
||||||
|
return false;
|
||||||
|
// compare lengths - can save a lot of time
|
||||||
|
if (this.length != array.length)
|
||||||
|
return false;
|
||||||
|
for (var i = 0, l=this.length; i < l; i++) {
|
||||||
|
// Check if we have nested arrays
|
||||||
|
if (this[i] instanceof Array && array[i] instanceof Array) {
|
||||||
|
// recurse into the nested arrays
|
||||||
|
if (!this[i].equals(array[i]))
|
||||||
|
return false;
|
||||||
|
} else if (this[i] != array[i]) {
|
||||||
|
// Warning - two different object instances will never be equal: {x:20} != {x:20}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue