Browse Source

Merge pull request #900 from pelias/skip-explicit-coarse-layers

only query ES for non-coarse layers on non-coarse reverse requests
pull/905/head
Stephen K Hess 8 years ago committed by GitHub
parent
commit
5e96c531c3
  1. 4
      query/reverse.js
  2. 1
      query/reverse_defaults.js
  3. 14
      routes/v1.js
  4. 1
      test/unit/controller/coarse_reverse.js
  5. 5
      test/unit/fixture/reverse_null_island.js
  6. 5
      test/unit/fixture/reverse_standard.js
  7. 5
      test/unit/fixture/reverse_with_boundary_country.js
  8. 2
      test/unit/fixture/reverse_with_layer_filtering.js
  9. 41
      test/unit/fixture/reverse_with_layer_filtering_non_coarse_subset.js
  10. 5
      test/unit/fixture/reverse_with_source_filtering.js
  11. 33
      test/unit/query/reverse.js

4
query/reverse.js

@ -3,6 +3,7 @@
const peliasQuery = require('pelias-query'); const peliasQuery = require('pelias-query');
const defaults = require('./reverse_defaults'); const defaults = require('./reverse_defaults');
const check = require('check-types'); const check = require('check-types');
const _ = require('lodash');
const logger = require('pelias-logger').get('api'); const logger = require('pelias-logger').get('api');
//------------------------------ //------------------------------
@ -44,7 +45,8 @@ function generateQuery( clean ){
// layers // layers
if( check.array(clean.layers) && clean.layers.length ) { if( check.array(clean.layers) && clean.layers.length ) {
vs.var( 'layers', clean.layers); // only include non-coarse layers
vs.var( 'layers', _.intersection(clean.layers, ['address', 'street', 'venue']));
logStr += '[param:layers] '; logStr += '[param:layers] ';
} }

1
query/reverse_defaults.js

@ -6,6 +6,7 @@ module.exports = _.merge({}, peliasQuery.defaults, {
'size': 1, 'size': 1,
'track_scores': true, 'track_scores': true,
'layers': ['venue', 'address', 'street'],
'centroid:field': 'center_point', 'centroid:field': 'center_point',

14
routes/v1.js

@ -97,14 +97,9 @@ function addRoutes(app, peliasConfig) {
const placeholderService = serviceWrapper(placeholderConfiguration); const placeholderService = serviceWrapper(placeholderConfiguration);
const isPlaceholderServiceEnabled = _.constant(placeholderConfiguration.isEnabled()); const isPlaceholderServiceEnabled = _.constant(placeholderConfiguration.isEnabled());
// use coarse reverse when requested layers are all coarse
const coarse_reverse_should_execute = all(
isPipServiceEnabled, isCoarseReverse, not(hasRequestErrors)
);
// fallback to coarse reverse when regular reverse didn't return anything // fallback to coarse reverse when regular reverse didn't return anything
const coarse_reverse_fallback_should_execute = all( const coarse_reverse_should_execute = all(
isPipServiceEnabled, not(isCoarseReverse), not(hasRequestErrors), not(hasResponseData) isPipServiceEnabled, not(hasRequestErrors), not(hasResponseData)
); );
const placeholderShouldExecute = all( const placeholderShouldExecute = all(
@ -114,7 +109,7 @@ function addRoutes(app, peliasConfig) {
// execute under the following conditions: // execute under the following conditions:
// - there are no errors or data // - there are no errors or data
// - request is not coarse OR pip service is disabled // - request is not coarse OR pip service is disabled
const original_reverse_should_execute = all( const non_coarse_reverse_should_execute = all(
not(hasResponseDataOrRequestErrors), not(hasResponseDataOrRequestErrors),
any( any(
not(isCoarseReverse), not(isCoarseReverse),
@ -202,9 +197,8 @@ function addRoutes(app, peliasConfig) {
sanitizers.reverse.middleware, sanitizers.reverse.middleware,
middleware.requestLanguage, middleware.requestLanguage,
middleware.calcSize(), middleware.calcSize(),
controllers.search(peliasConfig.api, esclient, queries.reverse, non_coarse_reverse_should_execute),
controllers.coarse_reverse(pipService, coarse_reverse_should_execute), controllers.coarse_reverse(pipService, coarse_reverse_should_execute),
controllers.search(peliasConfig.api, esclient, queries.reverse, original_reverse_should_execute),
controllers.coarse_reverse(pipService, coarse_reverse_fallback_should_execute),
postProc.distances('point.'), postProc.distances('point.'),
// reverse confidence scoring depends on distance from origin // reverse confidence scoring depends on distance from origin
// so it must be calculated first // so it must be calculated first

1
test/unit/controller/coarse_reverse.js

@ -449,6 +449,7 @@ module.exports.tests.success_conditions = (test, common) => {
}; };
t.deepEquals(res, expected); t.deepEquals(res, expected);
t.notOk(logger.hasErrorMessages()); t.notOk(logger.hasErrorMessages());
t.end(); t.end();

5
test/unit/fixture/reverse_null_island.js

@ -13,6 +13,11 @@ module.exports = {
'lon': 0 'lon': 0
} }
} }
},
{
'terms': {
'layer': ['venue', 'address', 'street']
}
}] }]
} }
}, },

5
test/unit/fixture/reverse_standard.js

@ -13,6 +13,11 @@ module.exports = {
'lon': -82.50622 'lon': -82.50622
} }
} }
},
{
'terms': {
'layer': ['venue', 'address', 'street']
}
}] }]
} }
}, },

5
test/unit/fixture/reverse_with_boundary_country.js

@ -23,6 +23,11 @@ module.exports = {
'lon': -82.50622 'lon': -82.50622
} }
} }
},
{
'terms': {
'layer': ['venue', 'address', 'street']
}
}] }]
} }
}, },

2
test/unit/fixture/reverse_with_layer_filtering.js

@ -17,7 +17,7 @@ module.exports = {
}, },
{ {
'terms': { 'terms': {
'layer': ['country'] 'layer': ['venue', 'address', 'street']
} }
} }
] ]

41
test/unit/fixture/reverse_with_layer_filtering_non_coarse_subset.js

@ -0,0 +1,41 @@
var vs = require('../../../query/reverse_defaults');
module.exports = {
'query': {
'bool': {
'filter': [
{
'geo_distance': {
'distance': '500km',
'distance_type': 'plane',
'optimize_bbox': 'indexed',
'center_point': {
'lat': 29.49136,
'lon': -82.50622
}
}
},
{
'terms': {
'layer': ['venue', 'street']
}
}
]
}
},
'sort': [
'_score',
{
'_geo_distance': {
'center_point': {
'lat': 29.49136,
'lon': -82.50622
},
'order': 'asc',
'distance_type': 'plane'
}
}
],
'size': vs.size,
'track_scores': true
};

5
test/unit/fixture/reverse_with_source_filtering.js

@ -19,6 +19,11 @@ module.exports = {
'terms': { 'terms': {
'source': ['test'] 'source': ['test']
} }
},
{
'terms': {
'layer': ['venue', 'address', 'street']
}
} }
] ]
} }

33
test/unit/query/reverse.js

@ -132,23 +132,46 @@ module.exports.tests.query = function(test, common) {
t.end(); t.end();
}); });
test('valid layers filter', function(t) { test('valid layers filter', (t) => {
var query = generate({ const query = generate({
'point.lat': 29.49136, 'point.lat': 29.49136,
'point.lon': -82.50622, 'point.lon': -82.50622,
'boundary.circle.lat': 29.49136, 'boundary.circle.lat': 29.49136,
'boundary.circle.lon': -82.50622, 'boundary.circle.lon': -82.50622,
'boundary.circle.radius': 500, 'boundary.circle.radius': 500,
'layers': ['country'] // only venue, address, and street layers should be retained
'layers': ['neighbourhood', 'venue', 'locality', 'address', 'region', 'street', 'country']
}); });
var compiled = JSON.parse( JSON.stringify( query ) ); const compiled = JSON.parse( JSON.stringify( query ) );
var expected = require('../fixture/reverse_with_layer_filtering'); const expected = require('../fixture/reverse_with_layer_filtering');
t.deepEqual(compiled.type, 'reverse', 'query type set');
t.deepEqual(compiled.body, expected, 'valid reverse query with source filtering');
t.end();
});
test('valid layers filter - subset of non-coarse layers', (t) => {
const query = generate({
'point.lat': 29.49136,
'point.lon': -82.50622,
'boundary.circle.lat': 29.49136,
'boundary.circle.lon': -82.50622,
'boundary.circle.radius': 500,
// only venue, address, and street layers should be retained
'layers': ['neighbourhood', 'venue', 'street', 'locality']
});
const compiled = JSON.parse( JSON.stringify( query ) );
const expected = require('../fixture/reverse_with_layer_filtering_non_coarse_subset');
t.deepEqual(compiled.type, 'reverse', 'query type set'); t.deepEqual(compiled.type, 'reverse', 'query type set');
t.deepEqual(compiled.body, expected, 'valid reverse query with source filtering'); t.deepEqual(compiled.body, expected, 'valid reverse query with source filtering');
t.end(); t.end();
}); });
}; };
module.exports.all = function (tape, common) { module.exports.all = function (tape, common) {

Loading…
Cancel
Save