From 5f30559680c11f3f052fd51815e7d608bc5831c7 Mon Sep 17 00:00:00 2001 From: Harish Krishna Date: Tue, 24 Feb 2015 18:24:21 -0500 Subject: [PATCH] testing inputs with comma --- test/unit/sanitiser/suggest.js | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/test/unit/sanitiser/suggest.js b/test/unit/sanitiser/suggest.js index 6ea903e5..a576f6de 100644 --- a/test/unit/sanitiser/suggest.js +++ b/test/unit/sanitiser/suggest.js @@ -2,6 +2,7 @@ var suggest = require('../../../sanitiser/suggest'), _sanitize = suggest.sanitize, middleware = suggest.middleware, + delim = ',', defaultError = 'invalid param \'input\': text length, must be >0', defaultClean = { input: 'test', lat:0, @@ -54,6 +55,29 @@ module.exports.tests.sanitize_input = function(test, common) { }); }; +module.exports.tests.sanitize_input_with_delim = function(test, common) { + var inputs = [ 'a,bcd', '123 main st, admin1', ',,,', ' ' ]; + + test('valid inputs with a comma', function(t) { + inputs.forEach( function( input ){ + sanitize({ input: input, lat: 0, lon: 0 }, function( err, clean ){ + var expected = JSON.parse(JSON.stringify( defaultClean )); + expected.input = input; + + var delim_index = input.indexOf(delim); + if (delim_index!==-1) { + expected.input = input.substring(0, input.indexOf(delim)); + expected.input_admin = input.substring(delim_index + 1).trim(); + } + + t.equal(err, undefined, 'no error'); + t.deepEqual(clean, expected, 'clean set correctly (' + input + ')'); + }); + }); + t.end(); + }); +}; + module.exports.tests.sanitize_lat = function(test, common) { var lats = { invalid: [ -181, -120, -91, 91, 120, 181 ],