const _ = require('lodash'); const proxyquire = require('proxyquire').noCallThru(); module.exports.tests = {}; module.exports.tests.text_parser = function(test, common) { test('all variables should be parsed', function(t) { var sanitizer = proxyquire('../../../sanitizer/_synthesize_analysis', { 'pelias-text-analyzer': { parse: function(query) { t.fail('parse should not have been called'); } }}); const raw = { query: ' \t query \t value \t ', neighbourhood: ' \t neighbourhood \t value \t ', borough: ' \t borough \t value \t ', locality: ' \t locality \t value \t ', county: ' \t county \t value \t ', region: ' \t region \t value \t ', postalcode: ' \t postalcode \t value \t ', country: ' \t country \t value \t ' }; const clean = {}; const expected_clean = { parsed_text: { query: 'query value', neighbourhood: 'neighbourhood value', borough: 'borough value', city: 'locality value', county: 'county value', state: 'region value', postalcode: 'postalcode value', country: 'country value' } }; const messages = sanitizer(raw, clean); t.deepEquals(clean, expected_clean); t.deepEquals(messages.errors, [], 'no errors'); t.deepEquals(messages.warnings, [], 'no warnings'); t.end(); }); test('non-string and blank string values should be treated as not supplied', function(t) { var sanitizer = proxyquire('../../../sanitizer/_synthesize_analysis', { 'pelias-text-analyzer': { parse: function(query) { t.fail('parse should not have been called'); } }}); // helper to return a random value that's considered invalid function getInvalidValue() { return _.sample([{}, [], false, '', ' \t ', 17, undefined]); } const raw = { query: getInvalidValue(), address: getInvalidValue(), neighbourhood: getInvalidValue(), borough: getInvalidValue(), locality: getInvalidValue(), county: getInvalidValue(), region: getInvalidValue(), postalcode: getInvalidValue(), country: getInvalidValue() }; const clean = {}; const expected_clean = { parsed_text: {} }; const messages = sanitizer(raw, clean); t.deepEquals(clean, expected_clean); t.deepEquals(messages.errors, ['at least one of the following fields is required: ' + 'query, address, neighbourhood, borough, locality, county, region, postalcode, country'], 'no errors'); t.deepEquals(messages.warnings, [], 'no warnings'); t.end(); }); test('no supplied fields should return error', function(t) { var sanitizer = proxyquire('../../../sanitizer/_synthesize_analysis', { 'pelias-text-analyzer': { parse: function(query) { t.fail('parse should not have been called'); } }}); const raw = {}; const clean = {}; const expected_clean = { parsed_text: {} }; const messages = sanitizer(raw, clean); t.deepEquals(clean, expected_clean); t.deepEquals(messages.errors, ['at least one of the following fields is required: ' + 'query, address, neighbourhood, borough, locality, county, region, postalcode, country'], 'no errors'); t.deepEquals(messages.warnings, [], 'no warnings'); t.end(); }); test('postalcode-only parsed_text should return error', function(t) { var sanitizer = proxyquire('../../../sanitizer/_synthesize_analysis', { 'pelias-text-analyzer': { parse: function(query) { t.fail('parse should not have been called'); } }}); const raw = { postalcode: 'postalcode value' }; const clean = {}; const expected_clean = { parsed_text: { postalcode: 'postalcode value' } }; const messages = sanitizer(raw, clean); t.deepEquals(clean, expected_clean); t.deepEquals(messages.errors, ['postalcode-only inputs are not supported'], 'no errors'); t.deepEquals(messages.warnings, [], 'no warnings'); t.end(); }); test('text_analyzer identifying house number should extract it and street', function(t) { var sanitizer = proxyquire('../../../sanitizer/_synthesize_analysis', { 'pelias-text-analyzer': { parse: function(query) { t.equals(query, 'Number Value Street Value Number Value'); return { number: 'Number Value' }; } }}); const raw = { address: 'Number Value Street Value Number Value' }; const clean = {}; const expected_clean = { parsed_text: { number: 'Number Value', street: 'Street Value Number Value' } }; const messages = sanitizer(raw, clean); t.deepEquals(clean, expected_clean); t.deepEquals(messages.errors, [], 'no errors'); t.deepEquals(messages.warnings, [], 'no warnings'); t.end(); }); test('text_analyzer identifying postalcode but not house number should assign to number and remove from address', function(t) { var sanitizer = proxyquire('../../../sanitizer/_synthesize_analysis', { 'pelias-text-analyzer': { parse: function(query) { t.equals(query, 'Number Value Street Value Number Value'); return { postalcode: 'Number Value' }; } }}); const raw = { address: 'Number Value Street Value Number Value' }; const clean = {}; const expected_clean = { parsed_text: { number: 'Number Value', street: 'Street Value Number Value' } }; const messages = sanitizer(raw, clean); t.deepEquals(clean, expected_clean); t.deepEquals(messages.errors, [], 'no errors'); t.deepEquals(messages.warnings, [], 'no warnings'); t.end(); }); test('text_analyzer not revealing possible number should move address to street', function(t) { var sanitizer = proxyquire('../../../sanitizer/_synthesize_analysis', { 'pelias-text-analyzer': { parse: function(query) { t.equals(query, 'Street Value'); return {}; } }}); const raw = { address: 'Street Value' }; const clean = {}; const expected_clean = { parsed_text: { street: 'Street Value' } }; const messages = sanitizer(raw, clean); t.deepEquals(clean, expected_clean); t.deepEquals(messages.errors, [], 'no errors'); t.deepEquals(messages.warnings, [], 'no warnings'); t.end(); }); }; module.exports.all = function (tape, common) { function test(name, testFunction) { return tape('sanitizer _synthesize_analysis: ' + name, testFunction); } for( const testCase in module.exports.tests ){ module.exports.tests[testCase](test, common); } };