From 8c249c26f48841aa24bc84b9c5b885c6eb2c01d2 Mon Sep 17 00:00:00 2001 From: Stephen Hess Date: Fri, 13 Jan 2017 12:24:30 -0500 Subject: [PATCH] initialize esclient in routes/v1, eliminating need for src/backend --- controller/place.js | 4 ++-- controller/search.js | 8 +++---- routes/v1.js | 19 ++++++++-------- service/mget.js | 12 +++++----- service/search.js | 10 ++++----- src/backend.js | 6 ----- test/unit/controller/place.js | 2 +- test/unit/controller/search.js | 2 +- test/unit/mock/backend.js | 28 +++++++++++------------- test/unit/run.js | 5 ++--- test/unit/service/mget.js | 4 ++-- test/unit/service/search.js | 4 ++-- test/unit/src/backend.js | 40 ---------------------------------- 13 files changed, 48 insertions(+), 96 deletions(-) delete mode 100644 src/backend.js delete mode 100644 test/unit/src/backend.js diff --git a/controller/place.js b/controller/place.js index 77562f70..28523665 100644 --- a/controller/place.js +++ b/controller/place.js @@ -1,7 +1,7 @@ var service = { mget: require('../service/mget') }; var logger = require('pelias-logger').get('api'); -function setup( config, backend ){ +function setup( config, esclient ){ function controller( req, res, next ){ // do not run controller when a request @@ -20,7 +20,7 @@ function setup( config, backend ){ logger.debug( '[ES req]', query ); - service.mget( backend, query, function( err, docs ) { + service.mget( esclient, query, function( err, docs ) { // error handler if( err ){ req.errors.push( err ); diff --git a/controller/search.js b/controller/search.js index b81f9c4b..8c845938 100644 --- a/controller/search.js +++ b/controller/search.js @@ -4,7 +4,7 @@ var service = { search: require('../service/search') }; var logger = require('pelias-logger').get('api'); var logging = require( '../helper/logging' ); -function setup( config, backend, query ){ +function setup( config, esclient, query ){ function controller( req, res, next ){ // do not run controller when a request // validation error has occurred. @@ -33,7 +33,7 @@ function setup( config, backend, query ){ return next(); } - // backend command + // elasticsearch command var cmd = { index: config.indexName, searchType: 'dfs_query_then_fetch', @@ -42,8 +42,8 @@ function setup( config, backend, query ){ logger.debug( '[ES req]', cmd ); - // query backend - service.search( backend, cmd, function( err, docs, meta ){ + // query elasticsearch + service.search( esclient, cmd, function( err, docs, meta ){ // error handler if( err ){ diff --git a/routes/v1.js b/routes/v1.js index bb38498f..e7e4d941 100644 --- a/routes/v1.js +++ b/routes/v1.js @@ -1,6 +1,8 @@ var Router = require('express').Router; var reverseQuery = require('../query/reverse'); -var backend = require('../src/backend'); + +const config = require( 'pelias-config' ).generate(); +const esclient = require('elasticsearch').Client(config.esclient); /** ----------------------- sanitizers ----------------------- **/ var sanitizers = { @@ -75,12 +77,11 @@ function addRoutes(app, peliasConfig) { search: createRouter([ sanitizers.search.middleware, middleware.calcSize(), - // 2nd parameter is `backend` which gets initialized internally // 3rd parameter is which query module to use, use fallback/geodisambiguation // first, then use original search strategy if first query didn't return anything - controllers.search(peliasConfig, backend, queries.libpostal), + controllers.search(peliasConfig, esclient, queries.libpostal), sanitizers.search_fallback.middleware, - controllers.search(peliasConfig, backend, queries.fallback_to_old_prod), + controllers.search(peliasConfig, esclient, queries.fallback_to_old_prod), postProc.trimByGranularity(), postProc.distances('focus.point.'), postProc.confidenceScores(peliasConfig), @@ -98,7 +99,7 @@ function addRoutes(app, peliasConfig) { structured: createRouter([ sanitizers.structured_geocoding.middleware, middleware.calcSize(), - controllers.search(peliasConfig, backend, queries.structured_geocoding), + controllers.search(peliasConfig, esclient, queries.structured_geocoding), postProc.trimByGranularityStructured(), postProc.distances('focus.point.'), postProc.confidenceScores(peliasConfig), @@ -115,7 +116,7 @@ function addRoutes(app, peliasConfig) { ]), autocomplete: createRouter([ sanitizers.autocomplete.middleware, - controllers.search(peliasConfig, backend, require('../query/autocomplete')), + controllers.search(peliasConfig, esclient, require('../query/autocomplete')), postProc.distances('focus.point.'), postProc.confidenceScores(peliasConfig), postProc.dedupe(), @@ -131,7 +132,7 @@ function addRoutes(app, peliasConfig) { reverse: createRouter([ sanitizers.reverse.middleware, middleware.calcSize(), - controllers.search(peliasConfig, backend, reverseQuery), + controllers.search(peliasConfig, esclient, reverseQuery), postProc.distances('point.'), // reverse confidence scoring depends on distance from origin // so it must be calculated first @@ -149,7 +150,7 @@ function addRoutes(app, peliasConfig) { nearby: createRouter([ sanitizers.nearby.middleware, middleware.calcSize(), - controllers.search(peliasConfig, backend, reverseQuery), + controllers.search(peliasConfig, esclient, reverseQuery), postProc.distances('point.'), // reverse confidence scoring depends on distance from origin // so it must be calculated first @@ -166,7 +167,7 @@ function addRoutes(app, peliasConfig) { ]), place: createRouter([ sanitizers.place.middleware, - controllers.place(peliasConfig, backend), + controllers.place(peliasConfig, esclient), postProc.accuracy(), postProc.localNamingConventions(), postProc.renamePlacenames(), diff --git a/service/mget.js b/service/mget.js index 99576176..b68a5bed 100644 --- a/service/mget.js +++ b/service/mget.js @@ -13,26 +13,26 @@ var logger = require( 'pelias-logger' ).get( 'api' ); -function service( backend, query, cb ){ +function service( esclient, query, cb ){ - // backend command + // elasticsearch command var cmd = { body: { docs: query } }; - // query new backend - backend.client.mget( cmd, function( err, data ){ + // query elasticsearch + esclient.mget( cmd, function( err, data ){ // log total ms elasticsearch reported the query took to execute if( data && data.took ){ logger.verbose( 'time elasticsearch reported:', data.took / 1000 ); } - // handle backend errors + // handle elasticsearch errors if( err ){ - logger.error( `backend error ${err}`); + logger.error( `elasticsearch error ${err}`); return cb( err ); } diff --git a/service/search.js b/service/search.js index 82e13dc1..9453aaa2 100644 --- a/service/search.js +++ b/service/search.js @@ -7,19 +7,19 @@ var logger = require( 'pelias-logger' ).get( 'api' ); -function service( backend, cmd, cb ){ +function service( esclient, cmd, cb ){ - // query new backend - backend.client.search( cmd, function( err, data ){ + // query elasticsearch + esclient.search( cmd, function( err, data ){ // log total ms elasticsearch reported the query took to execute if( data && data.took ){ logger.verbose( 'time elasticsearch reported:', data.took / 1000 ); } - // handle backend errors + // handle elasticsearch errors if( err ){ - logger.error( `backend error ${err}` ); + logger.error( `elasticsearch error ${err}` ); return cb( err ); } diff --git a/src/backend.js b/src/backend.js deleted file mode 100644 index 44059d5b..00000000 --- a/src/backend.js +++ /dev/null @@ -1,6 +0,0 @@ -const config = require( 'pelias-config' ).generate().esclient; -const client = require('elasticsearch').Client(config); - -module.exports = { - client: client -}; diff --git a/test/unit/controller/place.js b/test/unit/controller/place.js index 0376eec6..216b99f3 100644 --- a/test/unit/controller/place.js +++ b/test/unit/controller/place.js @@ -110,7 +110,7 @@ module.exports.tests.functional_failure = function(test, common) { var controller = setup( fakeDefaultConfig, backend ); var req = { clean: { ids: [ {'id' : 123, layers: [ 'b' ] } ] }, errors: [], warnings: [] }; var next = function( message ){ - t.equal(req.errors[0],'a backend error occurred','error passed to errorHandler'); + t.equal(req.errors[0],'an elasticsearch error occurred','error passed to errorHandler'); t.end(); }; controller(req, undefined, next ); diff --git a/test/unit/controller/search.js b/test/unit/controller/search.js index 86f07b97..2b87990d 100644 --- a/test/unit/controller/search.js +++ b/test/unit/controller/search.js @@ -151,7 +151,7 @@ module.exports.tests.functional_failure = function(test, common) { var controller = setup( fakeDefaultConfig, backend, mockQuery() ); var req = { clean: { a: 'b' }, errors: [], warnings: [] }; var next = function(){ - t.equal(req.errors[0],'a backend error occurred'); + t.equal(req.errors[0],'an elasticsearch error occurred'); t.end(); }; controller(req, undefined, next ); diff --git a/test/unit/mock/backend.js b/test/unit/mock/backend.js index 9292fe33..104f84dc 100644 --- a/test/unit/mock/backend.js +++ b/test/unit/mock/backend.js @@ -4,7 +4,7 @@ responses['client/suggest/ok/1'] = function( cmd, cb ){ return cb( undefined, suggestEnvelope([ { score: 1, text: 'mocktype:mockid1' } ], [ { score: 2, text: 'mocktype:mockid2' } ]) ); }; responses['client/suggest/fail/1'] = function( cmd, cb ){ - return cb( 'a backend error occurred' ); + return cb( 'an elasticsearch error occurred' ); }; responses['client/search/ok/1'] = function( cmd, cb ){ return cb( undefined, searchEnvelope([{ @@ -32,7 +32,7 @@ responses['client/search/ok/1'] = function( cmd, cb ){ }])); }; responses['client/search/fail/1'] = function( cmd, cb ){ - return cb( 'a backend error occurred' ); + return cb( 'an elasticsearch error occurred' ); }; responses['client/search/timeout/1'] = function( cmd, cb) { @@ -73,19 +73,17 @@ responses['client/mget/fail/1'] = responses['client/search/fail/1']; function setup( key, cmdCb ){ function backend( a, b ){ return { - client: { - mget: function( cmd, cb ){ - if( 'function' === typeof cmdCb ){ cmdCb( cmd ); } - return responses[key.indexOf('mget') === -1 ? 'client/mget/ok/1' : key].apply( this, arguments ); - }, - suggest: function( cmd, cb ){ - if( 'function' === typeof cmdCb ){ cmdCb( cmd ); } - return responses[key].apply( this, arguments ); - }, - search: function( cmd, cb ){ - if( 'function' === typeof cmdCb ){ cmdCb( cmd ); } - return responses[key].apply( this, arguments ); - } + mget: function( cmd, cb ){ + if( 'function' === typeof cmdCb ){ cmdCb( cmd ); } + return responses[key.indexOf('mget') === -1 ? 'client/mget/ok/1' : key].apply( this, arguments ); + }, + suggest: function( cmd, cb ){ + if( 'function' === typeof cmdCb ){ cmdCb( cmd ); } + return responses[key].apply( this, arguments ); + }, + search: function( cmd, cb ){ + if( 'function' === typeof cmdCb ){ cmdCb( cmd ); } + return responses[key].apply( this, arguments ); } }; } diff --git a/test/unit/run.js b/test/unit/run.js index 817f26dd..cc89a699 100644 --- a/test/unit/run.js +++ b/test/unit/run.js @@ -11,8 +11,8 @@ var common = { var tests = [ require('./app'), require('./controller/index'), - // require('./controller/place'), - // require('./controller/search'), + require('./controller/place'), + require('./controller/search'), require('./helper/diffPlaces'), require('./helper/geojsonify'), require('./helper/logging'), @@ -61,7 +61,6 @@ var tests = [ require('./sanitizer/_deprecate_quattroshapes'), require('./sanitizer/_categories'), require('./sanitizer/nearby'), - require('./src/backend'), require('./src/configValidation'), require('./sanitizer/autocomplete'), require('./sanitizer/structured_geocoding'), diff --git a/test/unit/service/mget.js b/test/unit/service/mget.js index aea0a62d..6d347111 100644 --- a/test/unit/service/mget.js +++ b/test/unit/service/mget.js @@ -79,7 +79,7 @@ module.exports.tests.functional_failure = function(test, common) { get: () => { return { error: (msg) => { - t.equal(msg, 'backend error a backend error occurred'); + t.equal(msg, 'elasticsearch error an elasticsearch error occurred'); } }; } @@ -88,7 +88,7 @@ module.exports.tests.functional_failure = function(test, common) { }); service( backend, [ query ], function(err, data) { - t.equal(err, 'a backend error occurred','error passed to errorHandler'); + t.equal(err, 'an elasticsearch error occurred','error passed to errorHandler'); t.equal(data, undefined, 'data is undefined'); }); }); diff --git a/test/unit/service/search.js b/test/unit/service/search.js index 7167ed6c..146b9744 100644 --- a/test/unit/service/search.js +++ b/test/unit/service/search.js @@ -88,7 +88,7 @@ module.exports.tests.functional_failure = function(test, common) { get: () => { return { error: (msg) => { - t.equal(msg, 'backend error a backend error occurred'); + t.equal(msg, 'elasticsearch error an elasticsearch error occurred'); } }; } @@ -97,7 +97,7 @@ module.exports.tests.functional_failure = function(test, common) { }); service( backend, [ query ], function(err, data) { - t.equal(err, 'a backend error occurred','error passed to errorHandler'); + t.equal(err, 'an elasticsearch error occurred','error passed to errorHandler'); t.equal(data, undefined, 'data is undefined'); }); }); diff --git a/test/unit/src/backend.js b/test/unit/src/backend.js deleted file mode 100644 index 1b750396..00000000 --- a/test/unit/src/backend.js +++ /dev/null @@ -1,40 +0,0 @@ -var proxyquire = require('proxyquire'); - -var stubConfig = { - generate: function generate() { - return { - esclient: { - hosts: [ - 'http://notLocalhost:9200', - 'http://anotherHost:9200' - ] - } - }; - } -}; - - -module.exports.tests = {}; - -module.exports.tests.config_properly_passed = function(test, common) { - test('Elasticsearch config is properly passed to elasticsearch module', function(t) { - var stubElasticsearchClient = { - Client: function(config) { - t.deepEquals(config.hosts, [ 'http://notLocalhost:9200', 'http://anotherHost:9200' ], 'hosts set correctly' ); - t.end(); - } - }; - - proxyquire('../../../src/backend', { 'pelias-config': stubConfig, 'elasticsearch': stubElasticsearchClient } ); - }); -}; - -module.exports.all = function (tape, common) { - function test(name, testFunction) { - return tape('SANTIZE src/backend ' + name, testFunction); - } - - for( var testCase in module.exports.tests ){ - module.exports.tests[testCase](test, common); - } -};