var parser = require('../../../helper/query_parser'); var layers_map = require('../../../query/layers'); module.exports.tests = {}; module.exports.tests.interface = function(test, common) { test('interface', function(t) { t.equal(typeof parser.get_parsed_address, 'function', 'valid function'); t.equal(typeof parser.get_layers, 'function', 'valid function'); t.end(); }); }; module.exports.tests.split_on_comma = function(test, common) { var queries = ['soho, new york', 'chelsea, london', '123 main, new york']; var delim = ','; var testParse = function(query) { test('naive parsing ' + query, function(t) { var address = parser.get_parsed_address(query); var delimIndex = query.indexOf(delim); var name = query.substring(0, delimIndex); var admin_parts = query.substring(delimIndex + 1).trim(); t.equal(typeof address, 'object', 'valid object'); t.equal(address.name, name, 'name set correctly to ' + address.name); t.equal(address.admin_parts, admin_parts, 'admin_parts set correctly to ' + address.admin_parts); t.end(); }); }; for (var key in queries) { testParse( queries[key] ); } }; module.exports.tests.parse_three_chars_or_less = function(test, common) { var chars_queries = ['a', 'bb', 'ccc']; var num_queries = ['1', '12', '123']; var alphanum_q = ['a1', '1a2', '12c']; var testParse = function(query) { test('query length < 3 (' + query + ')', function(t) { var address = parser.get_parsed_address(query); var target_layer = layers_map.coarse; var layers = parser.get_layers(query); t.equal(typeof address, 'object', 'valid object'); t.deepEqual(layers, target_layer, 'admin_parts set correctly to ' + target_layer.join(', ')); t.end(); }); }; var queries = chars_queries.concat(num_queries).concat(alphanum_q); for (var key in queries) { testParse( queries[key] ); } }; module.exports.tests.parse_one_or_more_tokens = function(test, common) { var one_token_queries = ['hyderbad', 'yugoslavia', 'somethingreallybigbutjustonetokenstill']; var two_tokens_nonum = ['small town', 'biggg city', 'another empire']; var two_tokens_withnum= ['123 main', 'sixty 1', '123-980 house']; // parse address is now always true to fix pelias/api#194 var testParse = function(query, parse_address) { test('query with one or more tokens (' + query + ')', function(t) { var address = parser.get_parsed_address(query); var target_layer = layers_map.coarse.concat(layers_map.venue); var layers = parser.get_layers(query); t.equal(typeof address, 'object', 'valid object'); if (parse_address) { t.deepEqual(address.regions.join(''), query, 'since query contained a number, it went through address parsing'); } else { t.deepEqual(layers, target_layer, 'admin_parts set correctly to ' + target_layer.join(', ')); } t.end(); }); }; var queries = one_token_queries.concat(two_tokens_nonum); for (var key in queries) { testParse( queries[key], true ); } for (key in two_tokens_withnum) { testParse( two_tokens_withnum[key], true ); } }; module.exports.tests.parse_address = function(test, common) { var addresses_nonum = [{ non_street: 'main particle', city: 'new york'}, { non_street: 'biggg city block' }, { non_street: 'the empire state building' } ]; var address_with_num = [{ number: 123, street: 'main st', city: 'new york', state: 'ny'}, { number: 456, street: 'pine ave', city: 'san francisco', state: 'CA'}, { number: 1980, street: 'house st', city: 'hoboken', state: 'NY'} ]; var address_with_zip = [{ number: 1, street: 'main st', city: 'new york', state: 'ny', zip: 10010}, { number: 4, street: 'ape ave', city: 'san diego', state: 'CA', zip: 98970}, { number: 19, street: 'house dr', city: 'houston', state: 'TX', zip: 79089} ]; var testParse = function(query, hasNumber, hasZip) { var testcase = 'parse query with ' + (hasNumber ? 'a house number ': 'no house number '); testcase += 'and ' + (hasZip ? 'a zip ' : 'no zip '); test(testcase, function(t) { var query_string = ''; for (var k in query) { query_string += ' ' + query[k]; } // remove leading whitespace query_string = query_string.substring(1); var address = parser.get_parsed_address(query_string); t.equal(typeof address, 'object', 'valid object for the address ('+query_string+')'); if (!hasNumber && !hasZip && query.non_street) { t.equal(address.regions.join(''), query_string, 'expected parsing result'); } else { t.equal(address.regions.join(''), query.city, 'city in regions (' + query.city +')'); } if ((hasNumber || hasZip) && query.street) { t.equal(typeof address.number, 'number', 'valid house number format (' + address.number + ')'); t.equal(address.number, query.number, 'correct house number (' + query.number + ')'); t.equal(typeof address.street, 'string', 'valid street name format (' + address.street + ')'); t.equal(address.street, query.street, 'correct street name (' + query.street + ')'); } if (hasZip) { t.equal(typeof address.postalcode, 'number', 'valid zip (' + address.postalcode + ')'); t.equal(address.postalcode, query.zip, 'correct postal code (' + query.zip + ')'); } t.end(); }); }; for (var key in addresses_nonum) { testParse( addresses_nonum[key] ); } for (key in address_with_num) { testParse( address_with_num[key], true ); } for (key in address_with_zip) { testParse( address_with_zip[key], true, true ); } }; module.exports.all = function (tape, common) { function test(name, testFunction) { return tape('QUERY PARSING: ' + name, testFunction); } for( var testCase in module.exports.tests ){ module.exports.tests[testCase](test, common); } };