Compare commits
4 Commits
develop
...
fuzz-test-
Author | SHA1 | Date |
---|---|---|
John McLear | 2e3592c7a0 | |
John McLear | 37afc82710 | |
John McLear | d60fce6af1 | |
John McLear | 82b80236c7 |
|
@ -1,12 +1,13 @@
|
||||||
/*
|
/*
|
||||||
* Fuzz testing the import endpoint
|
* Fuzz testing the import endpoint
|
||||||
*/
|
*/
|
||||||
|
/*
|
||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
const settings = require(__dirname+'/../../../../tests/container/loadSettings.js').loadSettings();
|
const settings = require(__dirname+'/../../../../tests/container/loadSettings.js').loadSettings();
|
||||||
const host = "http://" + settings.ip + ":" + settings.port;
|
const host = "http://" + settings.ip + ":" + settings.port;
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
const async = require(__dirname+'/../../../../src/node_modules/async');
|
const async = require(__dirname+'/../../../../src/node_modules/async');
|
||||||
const request = require('request');
|
const request = require(__dirname+'/../../../../src/node_modules/request');
|
||||||
const froth = require(__dirname+'/../../../../src/node_modules/mocha-froth');
|
const froth = require(__dirname+'/../../../../src/node_modules/mocha-froth');
|
||||||
|
|
||||||
var filePath = path.join(__dirname, '../../../../APIKEY.txt');
|
var filePath = path.join(__dirname, '../../../../APIKEY.txt');
|
||||||
|
@ -20,16 +21,17 @@ var endPoint = function(point, version){
|
||||||
return '/api/'+version+'/'+point+'?apikey='+apiKey;
|
return '/api/'+version+'/'+point+'?apikey='+apiKey;
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log("Testing against padID", testPadId);
|
//console.log("Testing against padID", testPadId);
|
||||||
console.log("To watch the test live visit " + host + "/p/" + testPadId);
|
//console.log("To watch the test live visit " + host + "/p/" + testPadId);
|
||||||
console.log("Tests will start in 5 seconds, click the URL now!");
|
//console.log("Tests will start in 5 seconds, click the URL now!");
|
||||||
|
|
||||||
setTimeout(function(){
|
setTimeout(function(){
|
||||||
for (let i=1; i<1000000; i++) { // 1M runs
|
for (let i=1; i<5; i++) { // 5000 runs
|
||||||
setTimeout( function timer(){
|
setTimeout( function timer(){
|
||||||
runTest(i);
|
runTest(i);
|
||||||
}, i*100 ); // 100 ms
|
}, i*100 ); // 100 ms
|
||||||
}
|
}
|
||||||
|
process.exit(0);
|
||||||
},5000); // wait 5 seconds
|
},5000); // wait 5 seconds
|
||||||
|
|
||||||
function runTest(number){
|
function runTest(number){
|
||||||
|
@ -42,22 +44,21 @@ function runTest(number){
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
var fN = '/test.txt';
|
var fN = '/tmp/fuzztest.txt';
|
||||||
var cT = 'text/plain';
|
var cT = 'text/plain';
|
||||||
|
|
||||||
// To be more agressive every other test we mess with Etherpad
|
|
||||||
// We provide a weird file name and also set a weird contentType
|
|
||||||
if (number % 2 == 0) {
|
if (number % 2 == 0) {
|
||||||
fN = froth().toString();
|
fN = froth().toString();
|
||||||
cT = froth().toString();
|
cT = froth().toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
let form = req.form();
|
let form = req.form();
|
||||||
|
|
||||||
form.append('file', froth().toString(), {
|
form.append('file', froth().toString(), {
|
||||||
filename: fN,
|
filename: fN,
|
||||||
contentType: cT
|
contentType: cT
|
||||||
});
|
});
|
||||||
|
console.log("here");
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -71,5 +72,4 @@ function makeid()
|
||||||
}
|
}
|
||||||
return text;
|
return text;
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
|
@ -158,8 +158,8 @@ describe('Imports and Exports', function(){
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
if(!settings.abiword && !settings.soffice){
|
if(settings.abiword.indexOf("/" === -1) && settings.soffice.indexOf("/" === -1)){
|
||||||
console.warn("Did not test abiword or soffice");
|
console.log("Did not test abiword or soffice");
|
||||||
}else{
|
}else{
|
||||||
it('Tries to import file type that uses soffice or abioffice', function(done) {
|
it('Tries to import file type that uses soffice or abioffice', function(done) {
|
||||||
|
|
||||||
|
@ -188,7 +188,7 @@ describe('Imports and Exports', function(){
|
||||||
let form = req.form();
|
let form = req.form();
|
||||||
|
|
||||||
form.append('file', wordDoc, {
|
form.append('file', wordDoc, {
|
||||||
filename: '/test.doc',
|
filename: '/tmp/test.doc',
|
||||||
contentType: 'application/msword'
|
contentType: 'application/msword'
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue