Browse Source

Merge pull request #1010 from pelias/coarse_reverse_try_catch

feat(coarse_reverse): ignore empty abbr properties from PIP service
pull/1013/head v3.30.0
Peter Johnson 7 years ago committed by GitHub
parent
commit
e24b8994fc
  1. 2
      controller/coarse_reverse.js
  2. 60
      test/unit/controller/coarse_reverse.js

2
controller/coarse_reverse.js

@ -68,7 +68,7 @@ function synthesizeDoc(results) {
// assign the administrative hierarchy // assign the administrative hierarchy
_.keys(results).forEach((layer) => { _.keys(results).forEach((layer) => {
doc.addParent(layer, results[layer][0].name, results[layer][0].id.toString(), results[layer][0].abbr); doc.addParent(layer, results[layer][0].name, results[layer][0].id.toString(), results[layer][0].abbr || undefined);
}); });
// set centroid if available // set centroid if available

60
test/unit/controller/coarse_reverse.js

@ -911,6 +911,66 @@ module.exports.tests.failure_conditions = (test, common) => {
t.end(); t.end();
}); });
test('service returns 0 length abbr', (t) => {
t.plan(4);
const service = (req, callback) => {
t.deepEquals(req, { clean: { layers: ['neighbourhood'] } } );
const results = {
neighbourhood: [
{ id: 20, name: 'Example', abbr: '' }
]
};
callback(undefined, results);
};
const logger = require('pelias-mock-logger')();
const controller = proxyquire('../../../controller/coarse_reverse', {
'pelias-logger': logger
})(service, _.constant(true));
const req = {
clean: {
layers: ['neighbourhood']
}
};
const res = { };
// verify that next was called
const next = () => {
t.pass('next() was called');
};
controller(req, res, next);
const expected = {
meta: {},
data: [{
name: { default: 'Example' },
phrase: { default: 'Example' },
parent: {
neighbourhood: [ 'Example' ],
neighbourhood_id: [ '20' ],
neighbourhood_a: [ null ]
},
source: 'whosonfirst',
layer: 'neighbourhood',
source_id: '20',
_id: '20',
_type: 'neighbourhood'
}]
};
t.deepEquals(res, expected);
t.notOk(logger.hasErrorMessages());
t.end();
});
}; };
module.exports.all = (tape, common) => { module.exports.all = (tape, common) => {

Loading…
Cancel
Save