-
-
Notifications
You must be signed in to change notification settings - Fork 23
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
add optional popularity column to pelias csv importer #80
add optional popularity column to pelias csv importer #80
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think that we should throw errors for popularity....
const popularityString = getCaseInsensitive('popularity', record); | ||
const popularity = parseInt(popularityString); | ||
if (popularityString && (isNaN(popularity) || !/^\d+$/.test(popularityString))) { | ||
throw new Error("Popularity must be an int, got " + popularityString) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think that we should throw errors for popularity.... This is not a required field, so a default value is enough when the data is incorrect.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I can't recall, does throw
-ing here kill the whole importer or does it print a message and skip just this one row?
In general, we've had this problem across all the importers, where different people have one of two needs:
- they want the import to finish if at all possible, even if one file/record/etc fails
- they want the import to be as complete as possible, and would rather the entire import fails than some invalid data makes its way in, or some data is missed
Where needed, we've introduced flags like missingFilesAreFatal
in the OA importer to toggle between the two preferences.
So, if this throw
causes the whole importer to fail, then we need to provide a way to allow invalid records to be skipped. If it prints a warning/error and continues on importing other records, then it's probably fine.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Okay, looks like it does just skip that one record. Now you all know the background anyway :)
How else would a user discover that they had bad data?
…On Wed, Sep 30, 2020 at 5:59 PM Jones Magloire ***@***.***> wrote:
***@***.**** approved this pull request.
I don't think that we should throw errors for popularity....
------------------------------
In lib/streams/documentStream.js
<#80 (comment)>:
> @@ -5,6 +5,16 @@ const through = require( 'through2' );
const peliasModel = require( 'pelias-model' );
const NAME_REGEX = /^name(_json)?_([a-z]{2})$/i;
+function getPopularity(record) {
+ const popularityString = getCaseInsensitive('popularity', record);
+ const popularity = parseInt(popularityString);
+ if (popularityString && (isNaN(popularity) || !/^\d+$/.test(popularityString))) {
+ throw new Error("Popularity must be an int, got " + popularityString)
I don't think that we should throw errors for popularity.... This is not a
required field, so a default value is enough when the data is incorrect.
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#80 (review)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AADMZMHGJKWMZAXHAQEC24TSIOS2HANCNFSM4R6IZNOQ>
.
--
*David Blackman*
creative technologist & wandering
help me find my purpose <http://purpose.blackmad.com>
|
Hum... I thought it would just print a message on failure (with the try/catch). But in fact there is also a report at the end with |
943035b
to
0cca254
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I added some quick docs and this now looks good to go. Thanks!
0cca254
to
93b063e
Compare
To make external POIs be at the baseline scoring as OSM venues, they should have some baseline popularity, since many OSM POIs have a popularity of ~2000 which makes it hard for third party chain data to compete with it
Connects #71