Browse Source

added support for popularity from placeholder

pull/850/head
Stephen Hess 8 years ago
parent
commit
ba7a81123c
  1. 4
      controller/placeholder.js
  2. 19
      test/unit/controller/placeholder.js

4
controller/placeholder.js

@ -68,6 +68,10 @@ function synthesizeDocs(boundaryCountry, result) {
doc.setPopulation(_.toNumber(result.population)); doc.setPopulation(_.toNumber(result.population));
} }
if (_.conformsTo(result, { 'popularity': isNonNegativeFiniteNumber })) {
doc.setPopularity(_.toNumber(result.popularity));
}
_.defaultTo(result.lineage, []) _.defaultTo(result.lineage, [])
// remove all lineages that don't match an explicit boundary.country // remove all lineages that don't match an explicit boundary.country
.filter(_.curry(matchesBoundaryCountry)(boundaryCountry)) .filter(_.curry(matchesBoundaryCountry)(boundaryCountry))

19
test/unit/controller/placeholder.js

@ -79,7 +79,8 @@ module.exports.tests.success = (test, common) => {
id: 123, id: 123,
name: 'name 1', name: 'name 1',
placetype: 'neighbourhood', placetype: 'neighbourhood',
population: 123456, population: 1234,
popularity: 5678,
lineage: [ lineage: [
{ {
country: { country: {
@ -188,7 +189,8 @@ module.exports.tests.success = (test, common) => {
id: 456, id: 456,
name: 'name 3', name: 'name 3',
placetype: 'locality', placetype: 'locality',
population: 789, population: 4321,
popularity: 8765,
lineage: [ {} ], lineage: [ {} ],
geom: { geom: {
area: 23.45, area: 23.45,
@ -230,7 +232,8 @@ module.exports.tests.success = (test, common) => {
phrase: { phrase: {
'default': 'name 1' 'default': 'name 1'
}, },
population: 123456, population: 1234,
popularity: 5678,
parent: { parent: {
neighbourhood: ['neighbourhood name 1', 'neighbourhood name 2'], neighbourhood: ['neighbourhood name 1', 'neighbourhood name 2'],
neighbourhood_id: ['10', '20'], neighbourhood_id: ['10', '20'],
@ -281,7 +284,8 @@ module.exports.tests.success = (test, common) => {
phrase: { phrase: {
'default': 'name 3' 'default': 'name 3'
}, },
population: 789, population: 4321,
popularity: 8765,
parent: { } parent: { }
} }
] ]
@ -357,7 +361,7 @@ module.exports.tests.success = (test, common) => {
}); });
test('results with string population should convert to number', (t) => { test('results with string population/popularity should convert to number', (t) => {
const logger = require('pelias-mock-logger')(); const logger = require('pelias-mock-logger')();
const placeholder_service = (req, callback) => { const placeholder_service = (req, callback) => {
@ -369,6 +373,7 @@ module.exports.tests.success = (test, common) => {
name: 'name 1', name: 'name 1',
placetype: 'neighbourhood', placetype: 'neighbourhood',
population: '123.4', population: '123.4',
popularity: '567.8',
geom: { geom: {
area: 12.34 area: 12.34
} }
@ -396,6 +401,7 @@ module.exports.tests.success = (test, common) => {
source: 'whosonfirst', source: 'whosonfirst',
source_id: '123', source_id: '123',
population: 123.4, population: 123.4,
popularity: 568,
name: { name: {
'default': 'name 1' 'default': 'name 1'
}, },
@ -414,7 +420,7 @@ module.exports.tests.success = (test, common) => {
}); });
test('results with negative population should not set population', (t) => { test('results with negative population/popularity should not set population/popularity', (t) => {
const logger = require('pelias-mock-logger')(); const logger = require('pelias-mock-logger')();
const placeholder_service = (req, callback) => { const placeholder_service = (req, callback) => {
@ -426,6 +432,7 @@ module.exports.tests.success = (test, common) => {
name: 'name 1', name: 'name 1',
placetype: 'neighbourhood', placetype: 'neighbourhood',
population: -1, population: -1,
popularity: -1,
geom: { geom: {
area: 12.34 area: 12.34
} }

Loading…
Cancel
Save