|
|
|
var sanitize = require('../../../sanitiser/_ids');
|
|
|
|
|
|
|
|
var delimiter = ':';
|
|
|
|
var types = require('../../../query/types');
|
|
|
|
var inputs = {
|
|
|
|
valid: [ 'geoname:1', 'osmnode:2', 'admin0:53', 'osmway:44', 'geoname:5' ],
|
|
|
|
invalid: [ ':', '', '::', 'geoname:', ':234', 'gibberish:23' ]
|
|
|
|
};
|
|
|
|
|
|
|
|
var formatError = function(input) {
|
|
|
|
return 'id `' + input + 'is invalid: must be of the format type:id for ex: \'geoname:4163334\'';
|
|
|
|
};
|
|
|
|
var lengthError = 'invalid param \'ids\': length must be >0';
|
|
|
|
var defaultMissingTypeError = function(input) {
|
|
|
|
var type = input.split(delimiter)[0];
|
|
|
|
return type + ' is invalid. It must be one of these values - [' + types.join(', ') + ']';
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports.tests = {};
|
|
|
|
|
|
|
|
module.exports.tests.invalid_ids = function(test, common) {
|
|
|
|
test('invalid id: empty string', function(t) {
|
|
|
|
var raw = { ids: '' };
|
|
|
|
var clean = {};
|
|
|
|
|
|
|
|
var messages = sanitize(raw, clean);
|
|
|
|
|
|
|
|
t.equal(messages.errors[0], lengthError, 'ids length error returned');
|
|
|
|
t.equal(clean.ids, undefined, 'ids unset in clean object');
|
|
|
|
t.end();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('invalid id: single colon', function(t) {
|
|
|
|
var raw = { ids: ':' };
|
|
|
|
var clean = {};
|
|
|
|
|
|
|
|
var messages = sanitize(raw, clean);
|
|
|
|
|
|
|
|
t.equal(messages.errors[0], formatError(':'), 'format error returned');
|
|
|
|
t.equal(clean.ids, undefined, 'ids unset in clean object');
|
|
|
|
t.end();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('invalid id: double colon', function(t) {
|
|
|
|
var raw = { ids: '::' };
|
|
|
|
var clean = {};
|
|
|
|
|
|
|
|
var messages = sanitize(raw, clean);
|
|
|
|
|
|
|
|
t.equal(messages.errors[0], formatError('::'), 'format error returned');
|
|
|
|
t.equal(clean.ids, undefined, 'ids unset in clean object');
|
|
|
|
t.end();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('invalid id: only type section present', function(t) {
|
|
|
|
var raw = { ids: 'geoname:' };
|
|
|
|
var clean = {};
|
|
|
|
|
|
|
|
var messages = sanitize(raw, clean);
|
|
|
|
|
|
|
|
t.equal(messages.errors[0], formatError('geoname:'), 'format error returned');
|
|
|
|
t.equal(clean.ids, undefined, 'ids unset in clean object');
|
|
|
|
t.end();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('invalid id: only type id section present', function(t) {
|
|
|
|
var raw = { ids: ':234' };
|
|
|
|
var clean = {};
|
|
|
|
|
|
|
|
var messages = sanitize(raw, clean);
|
|
|
|
|
|
|
|
t.equal(messages.errors[0], formatError(':234'), 'format error returned');
|
|
|
|
t.equal(clean.ids, undefined, 'ids unset in clean object');
|
|
|
|
t.end();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('invalid id: type name invalid', function(t) {
|
|
|
|
var raw = { ids: 'gibberish:23' };
|
|
|
|
var clean = {};
|
|
|
|
|
|
|
|
var messages = sanitize(raw, clean);
|
|
|
|
|
|
|
|
t.equal(messages.errors[0], defaultMissingTypeError('gibberish:23'), 'format error returned');
|
|
|
|
t.equal(clean.ids, undefined, 'ids unset in clean object');
|
|
|
|
t.end();
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports.tests.valid_ids = function(test, common) {
|
|
|
|
test('ids: valid input', function(t) {
|
|
|
|
inputs.valid.forEach( function( input ){
|
|
|
|
var input_parts = input.split(delimiter);
|
|
|
|
var expected_clean = { ids: [ { id: input_parts[1], type: input_parts[0] } ]};
|
|
|
|
var raw = { ids: input };
|
|
|
|
var clean = {};
|
|
|
|
|
|
|
|
var messages = sanitize( raw, clean );
|
|
|
|
|
|
|
|
t.deepEqual( messages.errors, [], 'no error (' + input + ')' );
|
|
|
|
t.deepEqual( clean, expected_clean, 'clean set correctly (' + input + ')');
|
|
|
|
});
|
|
|
|
t.end();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('ids: valid input with multiple values' , function(t) {
|
|
|
|
var raw = { ids: inputs.valid.join(',') };
|
|
|
|
var clean = {};
|
|
|
|
var expected_clean={
|
|
|
|
ids: [],
|
|
|
|
};
|
|
|
|
// construct the expected id and type for each valid input
|
|
|
|
inputs.valid.forEach( function( input ){
|
|
|
|
var input_parts = input.split(delimiter);
|
|
|
|
expected_clean.ids.push({ id: input_parts[1], type: input_parts[0] });
|
|
|
|
});
|
|
|
|
|
|
|
|
var messages = sanitize( raw, clean );
|
|
|
|
|
|
|
|
t.deepEqual( messages.errors, [], 'no errors' );
|
|
|
|
t.deepEqual( clean, expected_clean, 'clean set correctly' );
|
|
|
|
t.end();
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports.tests.array_of_ids = function(test, common) {
|
|
|
|
// see https://github.com/pelias/api/issues/272
|
|
|
|
test('array of ids sent by queryparser', function(t) {
|
|
|
|
var raw = { ids: ['geoname:2', 'oswmay:4'] };
|
|
|
|
var clean = {};
|
|
|
|
|
|
|
|
var messages = sanitize( raw, clean);
|
|
|
|
|
|
|
|
t.deepEqual( messages.errors, ['`ids` parameter specified multiple times.'], 'error sent' );
|
|
|
|
t.deepEqual( clean.ids, undefined, 'response is empty due to error' );
|
|
|
|
t.end();
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports.tests.multiple_ids = function(test, common) {
|
|
|
|
test('duplicate ids', function(t) {
|
|
|
|
var expected_clean = { ids: [ { id: '1', type: 'geoname' }, { id: '2', type: 'osmnode' } ] };
|
|
|
|
var raw = { ids: 'geoname:1,osmnode:2' };
|
|
|
|
var clean = {};
|
|
|
|
|
|
|
|
var messages = sanitize( raw, clean);
|
|
|
|
|
|
|
|
t.deepEqual( messages.errors, [], 'no errors' );
|
|
|
|
t.deepEqual( messages.warnings, [], 'no warnings' );
|
|
|
|
t.deepEqual(clean, expected_clean, 'clean set correctly');
|
|
|
|
t.end();
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports.tests.de_dupe = function(test, common) {
|
|
|
|
test('duplicate ids', function(t) {
|
|
|
|
var expected_clean = { ids: [ { id: '1', type: 'geoname' }, { id: '2', type: 'osmnode' } ]};
|
|
|
|
var raw = { ids: 'geoname:1,osmnode:2,geoname:1' };
|
|
|
|
var clean = {};
|
|
|
|
|
|
|
|
var messages = sanitize( raw, clean );
|
|
|
|
|
|
|
|
t.deepEqual( messages.errors, [], 'no errors' );
|
|
|
|
t.deepEqual( messages.warnings, [], 'no warnings' );
|
|
|
|
t.deepEqual(clean, expected_clean, 'clean set correctly');
|
|
|
|
t.end();
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports.all = function (tape, common) {
|
|
|
|
function test(name, testFunction) {
|
|
|
|
return tape('SANTIZE _ids ' + name, testFunction);
|
|
|
|
}
|
|
|
|
|
|
|
|
for( var testCase in module.exports.tests ){
|
|
|
|
module.exports.tests[testCase](test, common);
|
|
|
|
}
|
|
|
|
};
|