A housenumber without the place it refers to is of only limited use.
- IF parent_place_id is null THEN
- RETURN 0;
- END IF;
-
RETURN parent_place_id;
END;
$$
RETURN parent_place_id;
END;
$$
ST_PointOnSurface(NEW.linegeo),
NEW.linegeo);
ST_PointOnSurface(NEW.linegeo),
NEW.linegeo);
+ -- Cannot find a parent street. We will not be able to display a reliable
+ -- address, so drop entire interpolation.
+ IF NEW.parent_place_id is NULL THEN
+ DELETE FROM location_property_osmline where place_id = OLD.place_id;
+ RETURN NULL;
+ END IF;
+
NEW.token_info := token_strip_info(NEW.token_info);
IF NEW.address ? '_inherited' THEN
NEW.address := hstore('interpolation', NEW.address->'interpolation');
NEW.token_info := token_strip_info(NEW.token_info);
IF NEW.address ? '_inherited' THEN
NEW.address := hstore('interpolation', NEW.address->'interpolation');
Feature: Import of address interpolations
Tests that interpolated addresses are added correctly
Feature: Import of address interpolations
Tests that interpolated addresses are added correctly
+ Scenario: Simple even interpolation line with two points and no street nearby
+ Given the grid with origin 1,1
+ | 1 | | 9 | | 2 |
+ Given the places
+ | osm | class | type | housenr |
+ | N1 | place | house | 2 |
+ | N2 | place | house | 6 |
+ And the places
+ | osm | class | type | addr+interpolation | geometry |
+ | W1 | place | houses | even | 1,2 |
+ And the ways
+ | id | nodes |
+ | 1 | 1,2 |
+ When importing
+ Then W1 expands to no interpolation
+
Scenario: Simple even interpolation line with two points
Given the grid with origin 1,1
| 1 | | 9 | | 2 |
Scenario: Simple even interpolation line with two points
Given the grid with origin 1,1
| 1 | | 9 | | 2 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 2 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,2 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 4,5 |
And the ways
| id | nodes |
| 1 | 1,2 |
And the ways
| id | nodes |
| 1 | 1,2 |
Scenario: Backwards even two point interpolation line
Given the grid with origin 1,1
| 1 | 8 | 9 | 2 |
Scenario: Backwards even two point interpolation line
Given the grid with origin 1,1
| 1 | 8 | 9 | 2 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 2 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 2,1 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 2,1 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 4,5 |
And the ways
| id | nodes |
| 1 | 2,1 |
And the ways
| id | nodes |
| 1 | 2,1 |
Scenario: Simple odd two point interpolation
Given the grid with origin 1,1
| 1 | 8 | | | 9 | 2 |
Scenario: Simple odd two point interpolation
Given the grid with origin 1,1
| 1 | 8 | | | 9 | 2 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 1 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 1 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | odd | 1,2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | odd | 1,2 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 4,5 |
And the ways
| id | nodes |
| 1 | 1,2 |
And the ways
| id | nodes |
| 1 | 1,2 |
Scenario: Simple all two point interpolation
Given the grid with origin 1,1
| 1 | 8 | 9 | 2 |
Scenario: Simple all two point interpolation
Given the grid with origin 1,1
| 1 | 8 | 9 | 2 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 1 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 1 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | all | 1,2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | all | 1,2 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 4,5 |
And the ways
| id | nodes |
| 1 | 1,2 |
And the ways
| id | nodes |
| 1 | 1,2 |
Scenario: Even two point interpolation line with intermediate empty node
Given the grid
| 1 | 8 | | 3 | 9 | 2 |
Scenario: Even two point interpolation line with intermediate empty node
Given the grid
| 1 | 8 | | 3 | 9 | 2 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 2 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,3,2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,3,2 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 4,5 |
And the ways
| id | nodes |
| 1 | 1,3,2 |
And the ways
| id | nodes |
| 1 | 1,3,2 |
Scenario: Even two point interpolation line with intermediate duplicated empty node
Given the grid
Scenario: Even two point interpolation line with intermediate duplicated empty node
Given the grid
| 1 | 8 | 3 | 9 | 2 |
Given the places
| osm | class | type | housenr |
| 1 | 8 | 3 | 9 | 2 |
Given the places
| osm | class | type | housenr |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,3,2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,3,2 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 4,5 |
And the ways
| id | nodes |
| 1 | 1,3,3,2 |
And the ways
| id | nodes |
| 1 | 1,3,3,2 |
Scenario: Simple even three point interpolation line
Given the grid
Scenario: Simple even three point interpolation line
Given the grid
| 1 | 8 | | 9 | 3 | 7 | 2 |
Given the places
| osm | class | type | housenr |
| 1 | 8 | | 9 | 3 | 7 | 2 |
Given the places
| osm | class | type | housenr |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,3,2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,3,2 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 4,5 |
And the ways
| id | nodes |
| 1 | 1,3,2 |
And the ways
| id | nodes |
| 1 | 1,3,2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,3,2,4 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,3,2,4 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 1,3,2,4 |
And the ways
| id | nodes |
| 1 | 1,3,2,4 |
And the ways
| id | nodes |
| 1 | 1,3,2,4 |
Scenario: Reverse simple even three point interpolation line
Given the grid
| 1 | 8 | | 9 | 3 | 7 | 2 |
Scenario: Reverse simple even three point interpolation line
Given the grid
| 1 | 8 | | 9 | 3 | 7 | 2 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 2 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 2,3,1 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 2,3,1 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 4,5 |
And the ways
| id | nodes |
| 1 | 2,3,1 |
And the ways
| id | nodes |
| 1 | 2,3,1 |
Scenario: Even three point interpolation line with odd center point
Given the grid
| 1 | | 10 | | | 11 | 3 | 2 |
Scenario: Even three point interpolation line with odd center point
Given the grid
| 1 | | 10 | | | 11 | 3 | 2 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 2 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,3,2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,3,2 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 4,5 |
And the ways
| id | nodes |
| 1 | 1,3,2 |
And the ways
| id | nodes |
| 1 | 1,3,2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,2,3,2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,2,3,2 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 1,2,3 |
And the ways
| id | nodes |
| 1 | 1,2,3,2 |
And the ways
| id | nodes |
| 1 | 1,2,3,2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,2,3,2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,2,3,2 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 1,2,3 |
And the ways
| id | nodes |
| 1 | 1,2,3,2 |
And the ways
| id | nodes |
| 1 | 1,2,3,2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 144.9632341 -37.76163,144.9630541 -37.7628172,144.9629794 -37.7630755 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 144.9632341 -37.76163,144.9630541 -37.7628172,144.9629794 -37.7630755 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 144.9632341 -37.76163,144.9629794 -37.7630755 |
And the ways
| id | nodes |
| 1 | 1,2,3 |
And the ways
| id | nodes |
| 1 | 1,2,3 |
Scenario: Place with missing address information
Given the grid
| 1 | | 2 | | | 3 |
Scenario: Place with missing address information
Given the grid
| 1 | | 2 | | | 3 |
And the places
| osm | class | type | housenr |
| N1 | place | house | 23 |
And the places
| osm | class | type | housenr |
| N1 | place | house | 23 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | odd | 1,2,3 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | odd | 1,2,3 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 4,5 |
And the ways
| id | nodes |
| 1 | 1,2,3 |
And the ways
| id | nodes |
| 1 | 1,2,3 |
Given the places
| osm | class | type | housenr | geometry |
| W1 | place | houses | even | 1 1, 1 1.001 |
Given the places
| osm | class | type | housenr | geometry |
| W1 | place | houses | even | 1 1, 1 1.001 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 1 1, 1 1.001 |
When importing
Then W1 expands to no interpolation
Scenario: Ways with nodes without housenumbers are ignored
Given the grid
When importing
Then W1 expands to no interpolation
Scenario: Ways with nodes without housenumbers are ignored
Given the grid
+ | 1 | | 2 |
+ | 4 | | 5 |
Given the places
| osm | class | type |
| N1 | place | house |
Given the places
| osm | class | type |
| N1 | place | house |
Given the places
| osm | class | type | housenr | geometry |
| W1 | place | houses | even | 1,2 |
Given the places
| osm | class | type | housenr | geometry |
| W1 | place | houses | even | 1,2 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 4,5 |
When importing
Then W1 expands to no interpolation
Scenario: Two point interpolation starting at 0
Given the grid with origin 1,1
| 1 | 10 | | | 11 | 2 |
When importing
Then W1 expands to no interpolation
Scenario: Two point interpolation starting at 0
Given the grid with origin 1,1
| 1 | 10 | | | 11 | 2 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 0 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 0 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,2 |
+ And the places
+ | osm | class | type | name | geometry |
+ | W10 | highway | residential | London Road |4,5 |
And the ways
| id | nodes |
| 1 | 1,2 |
And the ways
| id | nodes |
| 1 | 1,2 |
When sending v1/reverse at 1,1
Then results contain
| ID | osm | type | display_name |
When sending v1/reverse at 1,1
Then results contain
| ID | osm | type | display_name |
+ | 0 | N1 | house | 0, London Road |
Scenario: Parenting of interpolation with additional tags
Given the grid
Scenario: Parenting of interpolation with additional tags
Given the grid
Scenario Outline: Bad interpolation values are ignored
Given the grid with origin 1,1
| 1 | | 9 | | 2 |
Scenario Outline: Bad interpolation values are ignored
Given the grid with origin 1,1
| 1 | | 9 | | 2 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 2 |
Given the places
| osm | class | type | housenr |
| N1 | place | house | 2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | <value> | 1,2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | <value> | 1,2 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 4,5 |
And the ways
| id | nodes |
| 1 | 1,2 |
And the ways
| id | nodes |
| 1 | 1,2 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,2,3,4 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 1,2,3,4 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 1,4 |
And the ways
| id | nodes |
| 1 | 1,2,3,4 |
And the ways
| id | nodes |
| 1 | 1,2,3,4 |
Scenario: Interpolation line with duplicated points
Given the grid
| 7 | 10 | 8 | 11 | 9 |
Scenario: Interpolation line with duplicated points
Given the grid
| 7 | 10 | 8 | 11 | 9 |
Given the places
| osm | class | type | housenr | geometry |
| N1 | place | house | 2 | 7 |
Given the places
| osm | class | type | housenr | geometry |
| N1 | place | house | 2 | 7 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 7,8,8,9 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 7,8,8,9 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 4,5 |
And the ways
| id | nodes |
| 1 | 1,2,3,4 |
And the ways
| id | nodes |
| 1 | 1,2,3,4 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 8,9 |
And the places
| osm | class | type | addr+interpolation | geometry |
| W1 | place | houses | even | 8,9 |
+ And the named places
+ | osm | class | type | geometry |
+ | W10 | highway | residential | 1,4 |
And the ways
| id | nodes |
| 1 | 1,8,9,2,3,4 |
And the ways
| id | nodes |
| 1 | 1,8,9,2,3,4 |
"""
n1 Taddr:housenumber=3
n2 Taddr:housenumber=17
"""
n1 Taddr:housenumber=3
n2 Taddr:housenumber=17
+ w33 Thighway=residential,name=Tao Nn1,n2
"""
Then place contains
| object | type |
"""
Then place contains
| object | type |
| object | type |
| N1:place | house |
| N2:place | house |
| object | type |
| N1:place | house |
| N2:place | house |
+ | W33:highway | residential |
Then location_property_osmline contains exactly
| object |
| 99:5 |
Then location_property_osmline contains exactly
| object |
| 99:5 |
"""
n1 Taddr:housenumber=3
n2 Taddr:housenumber=17
"""
n1 Taddr:housenumber=3
n2 Taddr:housenumber=17
+ w33 Thighway=residential Nn1,n2
w99 Thighway=residential Nn1,n2
"""
Then place contains
w99 Thighway=residential Nn1,n2
"""
Then place contains
| object | type |
| N1:place | house |
| N2:place | house |
| object | type |
| N1:place | house |
| N2:place | house |
+ | W33:highway | residential |
And location_property_osmline contains exactly
| object |
| 99:5 |
And location_property_osmline contains exactly
| object |
| 99:5 |
"""
n1 Taddr:housenumber=3
n2 Taddr:housenumber=17
"""
n1 Taddr:housenumber=3
n2 Taddr:housenumber=17
+ w33 Thighway=residential Nn1,n2
w34 Tpostcode=4456 Nn1,n2
"""
Then place contains exactly
| object | type |
| N1:place | house |
| N2:place | house |
w34 Tpostcode=4456 Nn1,n2
"""
Then place contains exactly
| object | type |
| N1:place | house |
| N2:place | house |
+ | W33:highway | residential |
| W34:place | postcode |
When updating osm data
| W34:place | postcode |
When updating osm data
| object | type |
| N1:place | house |
| N2:place | house |
| object | type |
| N1:place | house |
| N2:place | house |
+ | W33:highway | residential |
| W34:place | houses |
When indexing
Then location_property_osmline contains exactly
| W34:place | houses |
When indexing
Then location_property_osmline contains exactly
| object | type |
| N1:place | house |
| N2:place | house |
| object | type |
| N1:place | house |
| N2:place | house |
+ | W33:highway | residential |