|
|
|
const proxyquire = require('proxyquire').noCallThru();
|
|
|
|
const _ = require('lodash');
|
|
|
|
|
|
|
|
module.exports.tests = {};
|
|
|
|
|
|
|
|
module.exports.tests.sanitize = (test, common) => {
|
|
|
|
test('verify that all sanitizers were called as expected', (t) => {
|
|
|
|
const called_sanitizers = [];
|
|
|
|
|
|
|
|
// rather than re-verify the functionality of all the sanitizers, this test just verifies that they
|
|
|
|
// were all called correctly
|
|
|
|
|
|
|
|
// each mock dependency is a function that returns an object.
|
|
|
|
// the object contains a key called {function} sanitize,
|
|
|
|
// which pushes the name of the sanitizer to {array} called_sanitizers
|
|
|
|
const search = proxyquire('../../../sanitizer/search', {
|
|
|
|
'../sanitizer/_single_scalar_parameters': function () {
|
|
|
|
return {
|
|
|
|
sanitize: () => {
|
|
|
|
called_sanitizers.push('_single_scalar_parameters');
|
|
|
|
return { errors: [], warnings: [] };
|
|
|
|
}
|
|
|
|
};
|
|
|
|
},
|
|
|
|
'../sanitizer/_debug': () => {
|
|
|
|
return {
|
|
|
|
sanitize: () => {
|
|
|
|
called_sanitizers.push('_debug');
|
|
|
|
return { errors: [], warnings: [] };
|
|
|
|
}
|
|
|
|
};
|
|
|
|
},
|
|
|
|
'../sanitizer/_text': function () {
|
|
|
|
return {
|
|
|
|
sanitize: () => {
|
|
|
|
called_sanitizers.push('_text');
|
|
|
|
return { errors: [], warnings: [] };
|
|
|
|
}
|
|
|
|
};
|
|
|
|
},
|
|
|
|
'../sanitizer/_size': function() {
|
|
|
|
if (_.isEmpty(arguments)) {
|
|
|
|
return {
|
|
|
|
sanitize: () => {
|
|
|
|
called_sanitizers.push('_size');
|
|
|
|
return { errors: [], warnings: [] };
|
|
|
|
}
|
|
|
|
};
|
|
|
|
} else {
|
|
|
|
throw new Error('should not have passed any parameters to _size');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'../sanitizer/_targets': function (type) {
|
|
|
|
if (['layers', 'sources'].indexOf(type) !== -1) {
|
|
|
|
return {
|
|
|
|
sanitize: () => {
|
|
|
|
called_sanitizers.push(`_targets/${type}`);
|
|
|
|
return { errors: [], warnings: [] };
|
|
|
|
}
|
|
|
|
};
|
|
|
|
} else {
|
|
|
|
throw new Error('incorrect parameters passed to _targets');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'../sanitizer/_sources_and_layers': function () {
|
|
|
|
return {
|
|
|
|
sanitize: () => {
|
|
|
|
called_sanitizers.push('_sources_and_layers');
|
|
|
|
return { errors: [], warnings: [] };
|
|
|
|
}
|
|
|
|
};
|
|
|
|
},
|
|
|
|
'../sanitizer/_flag_bool': function () {
|
|
|
|
if (arguments[0] === 'private' && arguments[1] === false) {
|
|
|
|
return {
|
|
|
|
sanitize: () => {
|
|
|
|
called_sanitizers.push('_flag_bool');
|
|
|
|
return { errors: [], warnings: [] };
|
|
|
|
}
|
|
|
|
};
|
|
|
|
} else {
|
|
|
|
throw new Error('incorrect parameters passed to _flag_bool');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'../sanitizer/_geo_search': function () {
|
|
|
|
return {
|
|
|
|
sanitize: () => {
|
|
|
|
called_sanitizers.push('_geo_search');
|
|
|
|
return { errors: [], warnings: [] };
|
|
|
|
}
|
|
|
|
};
|
|
|
|
},
|
|
|
|
'../sanitizer/_boundary_country': function () {
|
|
|
|
return {
|
|
|
|
sanitize: () => {
|
|
|
|
called_sanitizers.push('_boundary_country');
|
|
|
|
return { errors: [], warnings: [] };
|
|
|
|
}
|
|
|
|
};
|
|
|
|
},
|
|
|
|
'../sanitizer/_categories': function () {
|
|
|
|
return {
|
|
|
|
sanitize: () => {
|
|
|
|
called_sanitizers.push('_categories');
|
|
|
|
return { errors: [], warnings: [] };
|
|
|
|
}
|
|
|
|
};
|
|
|
|
},
|
|
|
|
'../sanitizer/_geonames_warnings': function () {
|
|
|
|
return {
|
|
|
|
sanitize: () => {
|
|
|
|
called_sanitizers.push('_geonames_warnings');
|
|
|
|
return { errors: [], warnings: [] };
|
|
|
|
}
|
|
|
|
};
|
|
|
|
},
|
|
|
|
'../sanitizer/_location_bias': function (defaultParameters) {
|
|
|
|
return {
|
|
|
|
sanitize: () => {
|
|
|
|
if (defaultParameters.key === 'value'){
|
|
|
|
called_sanitizers.push('_location_bias');
|
|
|
|
return { errors: [], warnings: [] };
|
|
|
|
} else {
|
|
|
|
throw new Error('incorrect parameter passed to _location_bias');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
},
|
|
|
|
'../sanitizer/_request_language': () => {
|
|
|
|
return {
|
|
|
|
sanitize: () => {
|
|
|
|
called_sanitizers.push('_request_language');
|
|
|
|
return { errors: [], warnings: [] };
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
const expected_sanitizers = [
|
|
|
|
'_single_scalar_parameters',
|
|
|
|
'_debug',
|
|
|
|
'_text',
|
|
|
|
'_size',
|
|
|
|
'_targets/layers',
|
|
|
|
'_targets/sources',
|
|
|
|
'_sources_and_layers',
|
|
|
|
'_flag_bool',
|
|
|
|
'_location_bias',
|
|
|
|
'_geo_search',
|
|
|
|
'_boundary_country',
|
|
|
|
'_categories',
|
|
|
|
'_geonames_warnings',
|
|
|
|
'_request_language'
|
|
|
|
];
|
|
|
|
|
|
|
|
const req = {};
|
|
|
|
const res = {};
|
|
|
|
|
|
|
|
const middleware = search.middleware({
|
|
|
|
// mock pelias config ap.defaultParameters section for location bias
|
|
|
|
defaultParameters: {
|
|
|
|
key: 'value'
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
middleware(req, res, () => {
|
|
|
|
t.deepEquals(called_sanitizers, expected_sanitizers);
|
|
|
|
t.end();
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports.all = (tape, common) => {
|
|
|
|
|
|
|
|
function test(name, testFunction) {
|
|
|
|
return tape(`SANITIZE /search ${name}`, testFunction);
|
|
|
|
}
|
|
|
|
|
|
|
|
for( const testCase in module.exports.tests ){
|
|
|
|
module.exports.tests[testCase](test, common);
|
|
|
|
}
|
|
|
|
};
|