mirror of
https://github.com/osm-search/Nominatim.git
synced 2026-02-16 15:47:58 +00:00
Remove interpolation lines from placex and save them in an extra table.
This commit is contained in:
@@ -2,41 +2,23 @@
|
||||
Feature: Import of address interpolations
|
||||
Tests that interpolated addresses are added correctly
|
||||
|
||||
Scenario: Simple even two point interpolation
|
||||
Scenario: Simple even interpolation line with two points
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 2 | 1 1
|
||||
| 2 | place | house | 6 | 1 1.001
|
||||
| osm_id | osm_type | class | type | housenumber | geometry
|
||||
| 1 | N | place | house | 2 | 1 1
|
||||
| 2 | N | place | house | 6 | 1 1.001
|
||||
And the place ways
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | houses | even | 1 1, 1 1.001
|
||||
| osm_id | osm_type | class | type | housenumber | geometry
|
||||
| 1 | W | place | houses | even | 1 1, 1 1.001
|
||||
And the ways
|
||||
| id | nodes
|
||||
| 1 | 1,2
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 4 | 1,1.0005
|
||||
Then way 1 expands to lines
|
||||
| startnumber | endnumber | geometry
|
||||
| 2 | 6 | 1 1, 1 1.001
|
||||
|
||||
Scenario: Simple even two point interpolation with zero beginning
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 0 | 1 1
|
||||
| 2 | place | house | 8 | 1 1.001
|
||||
And the place ways
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | houses | even | 1 1, 1 1.001
|
||||
And the ways
|
||||
| id | nodes
|
||||
| 1 | 1,2
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 2 | 1,1.00025
|
||||
| 4 | 1,1.0005
|
||||
| 6 | 1,1.00075
|
||||
|
||||
Scenario: Backwards even two point interpolation
|
||||
Scenario: Backwards even two point interpolation line
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 2 | 1 1
|
||||
@@ -48,77 +30,9 @@ Feature: Import of address interpolations
|
||||
| id | nodes
|
||||
| 1 | 2,1
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 4 | 1,1.0005
|
||||
|
||||
Scenario: Even two point interpolation with odd beginning
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 11 | 1 1
|
||||
| 2 | place | house | 16 | 1 1.001
|
||||
And the place ways
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | houses | even | 1 1, 1 1.001
|
||||
And the ways
|
||||
| id | nodes
|
||||
| 1 | 1,2
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 12 | 1,1.0002
|
||||
| 14 | 1,1.0006
|
||||
|
||||
Scenario: Even two point interpolation with odd end
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 10 | 1 1
|
||||
| 2 | place | house | 15 | 1 1.001
|
||||
And the place ways
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | houses | even | 1 1, 1 1.001
|
||||
And the ways
|
||||
| id | nodes
|
||||
| 1 | 1,2
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 12 | 1,1.0004
|
||||
| 14 | 1,1.0008
|
||||
|
||||
Scenario: Reverse even two point interpolation with odd beginning
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 11 | 1 1
|
||||
| 2 | place | house | 16 | 1 1.001
|
||||
And the place ways
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | houses | even | 1 1.001, 1 1
|
||||
And the ways
|
||||
| id | nodes
|
||||
| 1 | 2,1
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 12 | 1,1.0002
|
||||
| 14 | 1,1.0006
|
||||
|
||||
Scenario: Reverse even two point interpolation with odd end
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 10 | 1 1
|
||||
| 2 | place | house | 15 | 1 1.001
|
||||
And the place ways
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | houses | even | 1 1.001, 1 1
|
||||
And the ways
|
||||
| id | nodes
|
||||
| 1 | 2,1
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 12 | 1,1.0004
|
||||
| 14 | 1,1.0008
|
||||
Then way 1 expands to lines
|
||||
| startnumber | endnumber | geometry
|
||||
| 2 | 6 | 1 1, 1 1.001
|
||||
|
||||
Scenario: Simple odd two point interpolation
|
||||
Given the place nodes
|
||||
@@ -132,29 +46,9 @@ Feature: Import of address interpolations
|
||||
| id | nodes
|
||||
| 1 | 1,2
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 3 | 1,1.0002
|
||||
| 5 | 1,1.0004
|
||||
| 7 | 1,1.0006
|
||||
| 9 | 1,1.0008
|
||||
|
||||
Scenario: Odd two point interpolation with even beginning
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 2 | 1 1
|
||||
| 2 | place | house | 7 | 1 1.001
|
||||
And the place ways
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | houses | odd | 1 1, 1 1.001
|
||||
And the ways
|
||||
| id | nodes
|
||||
| 1 | 1,2
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 3 | 1,1.0002
|
||||
| 5 | 1,1.0006
|
||||
Then way 1 expands to lines
|
||||
| startnumber | endnumber | geometry
|
||||
| 1 | 11 | 1 1, 1 1.001
|
||||
|
||||
Scenario: Simple all two point interpolation
|
||||
Given the place nodes
|
||||
@@ -168,27 +62,11 @@ Feature: Import of address interpolations
|
||||
| id | nodes
|
||||
| 1 | 1,2
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 2 | 1,1.0005
|
||||
Then way 1 expands to lines
|
||||
| startnumber | endnumber | geometry
|
||||
| 1 | 3 | 1 1, 1 1.001
|
||||
|
||||
Scenario: Simple numbered two point interpolation
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 3 | 1 1
|
||||
| 2 | place | house | 9 | 1 1.001
|
||||
And the place ways
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | houses | 3 | 1 1, 1 1.001
|
||||
And the ways
|
||||
| id | nodes
|
||||
| 1 | 1,2
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 6 | 1,1.0005
|
||||
|
||||
Scenario: Even two point interpolation with intermediate empty node
|
||||
Scenario: Even two point interpolation line with intermediate empty node
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 2 | 1 1
|
||||
@@ -200,14 +78,11 @@ Feature: Import of address interpolations
|
||||
| id | nodes
|
||||
| 1 | 1,3,2
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 4 | 1,1.0005
|
||||
| 6 | 1,1.001
|
||||
| 8 | 1.0005,1.001
|
||||
Then way 1 expands to lines
|
||||
| startnumber | endnumber | geometry
|
||||
| 2 | 10 | 1 1, 1 1.001, 1.001 1.001
|
||||
|
||||
|
||||
Scenario: Even two point interpolation with intermediate duplicated empty node
|
||||
Scenario: Even two point interpolation line with intermediate duplicated empty node
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 2 | 1 1
|
||||
@@ -219,13 +94,11 @@ Feature: Import of address interpolations
|
||||
| id | nodes
|
||||
| 1 | 1,3,3,2
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 4 | 1,1.0005
|
||||
| 6 | 1,1.001
|
||||
| 8 | 1.0005,1.001
|
||||
Then way 1 expands to lines
|
||||
| startnumber | endnumber | geometry
|
||||
| 2 | 10 | 1 1, 1 1.001, 1.001 1.001
|
||||
|
||||
Scenario: Simple even three point interpolation
|
||||
Scenario: Simple even three point interpolation line
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 2 | 1 1
|
||||
@@ -238,14 +111,12 @@ Feature: Import of address interpolations
|
||||
| id | nodes
|
||||
| 1 | 1,3,2
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 4 | 1,1.00025
|
||||
| 6 | 1,1.0005
|
||||
| 8 | 1,1.00075
|
||||
| 12 | 1.0005,1.001
|
||||
Then way 1 expands to lines
|
||||
| startnumber | endnumber | geometry
|
||||
| 2 | 10 | 1 1, 1 1.001
|
||||
| 10 | 14 | 1 1.001, 1.001 1.001
|
||||
|
||||
Scenario: Simple even four point interpolation
|
||||
Scenario: Simple even four point interpolation line
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 2 | 1 1
|
||||
@@ -259,15 +130,13 @@ Feature: Import of address interpolations
|
||||
| id | nodes
|
||||
| 1 | 1,3,2,4
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 4 | 1,1.00025
|
||||
| 6 | 1,1.0005
|
||||
| 8 | 1,1.00075
|
||||
| 12 | 1.0005,1.001
|
||||
| 16 | 1.001,1.0015
|
||||
Then way 1 expands to lines
|
||||
| startnumber | endnumber | geometry
|
||||
| 2 | 10 | 1 1, 1 1.001
|
||||
| 10 | 14 | 1 1.001, 1.001 1.001
|
||||
| 14 | 18 | 1.001 1.001, 1.001 1.002
|
||||
|
||||
Scenario: Reverse simple even three point interpolation
|
||||
Scenario: Reverse simple even three point interpolation line
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 2 | 1 1
|
||||
@@ -280,14 +149,12 @@ Feature: Import of address interpolations
|
||||
| id | nodes
|
||||
| 1 | 2,3,1
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 4 | 1,1.00025
|
||||
| 6 | 1,1.0005
|
||||
| 8 | 1,1.00075
|
||||
| 12 | 1.0005,1.001
|
||||
Then way 1 expands to lines
|
||||
| startnumber | endnumber | geometry
|
||||
| 2 | 10 | 1 1, 1 1.001
|
||||
| 10 | 14 | 1 1.001, 1.001 1.001
|
||||
|
||||
Scenario: Even three point interpolation with odd center point
|
||||
Scenario: Even three point interpolation line with odd center point
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 2 | 1 1
|
||||
@@ -300,12 +167,12 @@ Feature: Import of address interpolations
|
||||
| id | nodes
|
||||
| 1 | 1,3,2
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 4 | 1,1.0004
|
||||
| 6 | 1,1.0008
|
||||
Then way 1 expands to lines
|
||||
| startnumber | endnumber | geometry
|
||||
| 2 | 7 | 1 1, 1 1.001
|
||||
| 7 | 8 | 1 1.001, 1.001 1.001
|
||||
|
||||
Scenario: Interpolation on self-intersecting way
|
||||
Scenario: Interpolation line with self-intersecting way
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 2 | 0 0
|
||||
@@ -318,12 +185,12 @@ Feature: Import of address interpolations
|
||||
| id | nodes
|
||||
| 1 | 1,2,3,2
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 4 | 0,0.0005
|
||||
| 8 | 0,0.0015
|
||||
Then way 1 expands to lines
|
||||
| startnumber | endnumber | geometry
|
||||
| 2 | 6 | 0 0, 0 0.001
|
||||
| 6 | 10 | 0 0.001, 0 0.002
|
||||
|
||||
Scenario: Interpolation on self-intersecting way II
|
||||
Scenario: Interpolation line with self-intersecting way II
|
||||
Given the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 2 | 0 0
|
||||
@@ -335,24 +202,24 @@ Feature: Import of address interpolations
|
||||
| id | nodes
|
||||
| 1 | 1,2,3,2
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 4 | 0,0.0005
|
||||
Then way 1 expands to lines
|
||||
| startnumber | endnumber | geometry
|
||||
| 2 | 6 | 0 0, 0 0.001
|
||||
|
||||
|
||||
Scenario: addr:street on interpolation way
|
||||
Given the scene parallel-road
|
||||
And the place nodes
|
||||
Scenario: addr:street on interpolation way
|
||||
Given the scene parallel-road
|
||||
And the place nodes
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 1 | place | house | 2 | :n-middle-w
|
||||
| 2 | place | house | 6 | :n-middle-e
|
||||
| 3 | place | house | 12 | :n-middle-w
|
||||
| 4 | place | house | 16 | :n-middle-e
|
||||
And the place ways
|
||||
And the place ways
|
||||
| osm_id | class | type | housenumber | street | geometry
|
||||
| 10 | place | houses | even | | :w-middle
|
||||
| 11 | place | houses | even | Cloud Street | :w-middle
|
||||
And the place ways
|
||||
And the place ways
|
||||
| osm_id | class | type | name | geometry
|
||||
| 2 | highway | tertiary | 'name' : 'Sun Way' | :w-north
|
||||
| 3 | highway | tertiary | 'name' : 'Cloud Street' | :w-south
|
||||
@@ -360,49 +227,49 @@ Feature: Import of address interpolations
|
||||
| id | nodes
|
||||
| 10 | 1,100,101,102,2
|
||||
| 11 | 3,200,201,202,4
|
||||
When importing
|
||||
Then table placex contains
|
||||
When importing
|
||||
Then table placex contains
|
||||
| object | parent_place_id
|
||||
| N1 | W2
|
||||
| N2 | W2
|
||||
| N3 | W3
|
||||
| N4 | W3
|
||||
| W10 | W2
|
||||
| W11 | W3
|
||||
And way 10 expands exactly to housenumbers 4
|
||||
And way 11 expands exactly to housenumbers 14
|
||||
Then table location_property_osmline contains
|
||||
| object | parent_place_id | startnumber | endnumber
|
||||
| W10 | W2 | 2 | 6
|
||||
| W11 | W3 | 12 | 16
|
||||
|
||||
Scenario: addr:street on housenumber way
|
||||
Given the scene parallel-road
|
||||
And the place nodes
|
||||
Scenario: addr:street on housenumber way
|
||||
Given the scene parallel-road
|
||||
And the place nodes
|
||||
| osm_id | class | type | housenumber | street | geometry
|
||||
| 1 | place | house | 2 | | :n-middle-w
|
||||
| 2 | place | house | 6 | | :n-middle-e
|
||||
| 3 | place | house | 12 | Cloud Street | :n-middle-w
|
||||
| 4 | place | house | 16 | Cloud Street | :n-middle-e
|
||||
And the place ways
|
||||
And the place ways
|
||||
| osm_id | class | type | housenumber | geometry
|
||||
| 10 | place | houses | even | :w-middle
|
||||
| 11 | place | houses | even | :w-middle
|
||||
And the place ways
|
||||
And the place ways
|
||||
| osm_id | class | type | name | geometry
|
||||
| 2 | highway | tertiary | 'name' : 'Sun Way' | :w-north
|
||||
| 3 | highway | tertiary | 'name' : 'Cloud Street' | :w-south
|
||||
And the ways
|
||||
| id | nodes
|
||||
| id | nodes
|
||||
| 10 | 1,100,101,102,2
|
||||
| 11 | 3,200,201,202,4
|
||||
When importing
|
||||
Then table placex contains
|
||||
When importing
|
||||
Then table placex contains
|
||||
| object | parent_place_id
|
||||
| N1 | W2
|
||||
| N2 | W2
|
||||
| N3 | W3
|
||||
| N4 | W3
|
||||
| W10 | W2
|
||||
| W11 | W3
|
||||
And way 10 expands exactly to housenumbers 4
|
||||
And way 11 expands exactly to housenumbers 14
|
||||
And table location_property_osmline contains
|
||||
| object | parent_place_id | startnumber | endnumber
|
||||
| W10 | W2 | 2 | 6
|
||||
| W11 | W3 | 12 | 16
|
||||
|
||||
Scenario: Geometry of points and way don't match (github #253)
|
||||
Given the place nodes
|
||||
@@ -417,10 +284,10 @@ Feature: Import of address interpolations
|
||||
| id | nodes
|
||||
| 1 | 1,2,3
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 4 | 144.963016723312,-37.7629464422819+-0.000005
|
||||
| 8 | 144.9631440856,-37.762223694978+-0.000005
|
||||
Then way 1 expands to lines
|
||||
| startnumber | endnumber | geometry
|
||||
| 2 | 6 | 144.9629794 -37.7630755, 144.9630541 -37.7628174
|
||||
| 6 | 10 | 144.9630541 -37.7628174, 144.9632341 -37.76163
|
||||
|
||||
Scenario: Place with missing address information
|
||||
Given the place nodes
|
||||
@@ -435,7 +302,6 @@ Feature: Import of address interpolations
|
||||
| id | nodes
|
||||
| 1 | 1,2,3
|
||||
When importing
|
||||
Then way 1 expands to housenumbers
|
||||
| housenumber | centroid
|
||||
| 25 | 0.0001,0.0002
|
||||
| 27 | 0.0001,0.0003
|
||||
Then way 1 expands to lines
|
||||
| startnumber | endnumber | geometry
|
||||
| 23 | 29 | 0.0001 0.0001, 0.0001 0.0002, 0.0001 0.0004
|
||||
|
||||
@@ -23,17 +23,19 @@ Feature: Update of address interpolations
|
||||
| object | parent_place_id
|
||||
| N1 | W2
|
||||
| N2 | W2
|
||||
| W10 | W2
|
||||
And way 10 expands exactly to housenumbers 4
|
||||
And table location_property_osmline contains
|
||||
| object | parent_place_id | startnumber | endnumber
|
||||
| W10 | W2 | 2 | 6
|
||||
When updating place ways
|
||||
| osm_id | class | type | housenumber | street | geometry
|
||||
| 10 | place | houses | even | Cloud Street | :w-middle
|
||||
Then way 10 expands exactly to housenumbers 4
|
||||
And table placex contains
|
||||
Then table placex contains
|
||||
| object | parent_place_id
|
||||
| N1 | W3
|
||||
| N2 | W3
|
||||
| W10 | W3
|
||||
And table location_property_osmline contains
|
||||
| object | parent_place_id | startnumber | endnumber
|
||||
| W10 | W3 | 2 | 6
|
||||
|
||||
@Fail
|
||||
Scenario: addr:street added to housenumbers
|
||||
@@ -57,18 +59,20 @@ Feature: Update of address interpolations
|
||||
| object | parent_place_id
|
||||
| N1 | W2
|
||||
| N2 | W2
|
||||
| W10 | W2
|
||||
And way 10 expands exactly to housenumbers 4
|
||||
And table location_property_osmline contains
|
||||
| object | parent_place_id | startnumber | endnumber
|
||||
| W10 | W2 | 2 | 6
|
||||
When updating place nodes
|
||||
| osm_id | class | type | street | housenumber | geometry
|
||||
| 1 | place | house | Cloud Street| 2 | :n-middle-w
|
||||
| 2 | place | house | Cloud Street| 6 | :n-middle-e
|
||||
Then way 10 expands exactly to housenumbers 4
|
||||
And table placex contains
|
||||
Then table placex contains
|
||||
| object | parent_place_id
|
||||
| N1 | W3
|
||||
| N2 | W3
|
||||
| W10 | W3
|
||||
And table location_property_osmline contains
|
||||
| object | parent_place_id | startnumber | endnumber
|
||||
| W10 | W3 | 2 | 6
|
||||
|
||||
|
||||
Scenario: interpolation tag removed
|
||||
@@ -92,10 +96,11 @@ Feature: Update of address interpolations
|
||||
| object | parent_place_id
|
||||
| N1 | W2
|
||||
| N2 | W2
|
||||
| W10 | W2
|
||||
And way 10 expands exactly to housenumbers 4
|
||||
And table location_property_osmline contains
|
||||
| object | parent_place_id | startnumber | endnumber
|
||||
| W10 | W2 | 2 | 6
|
||||
When marking for delete W10
|
||||
Then way 10 expands to no housenumbers
|
||||
Then table location_property_osmline has no entry for W10
|
||||
And table placex contains
|
||||
| object | parent_place_id
|
||||
| N1 | W2
|
||||
@@ -122,17 +127,19 @@ Feature: Update of address interpolations
|
||||
| object | parent_place_id
|
||||
| N1 | W2
|
||||
| N2 | W2
|
||||
| W10 | W2
|
||||
And way 10 expands exactly to housenumbers 4
|
||||
And table location_property_osmline contains
|
||||
| object | parent_place_id | startnumber | endnumber
|
||||
| W10 | W2 | 2 | 6
|
||||
When updating place ways
|
||||
| osm_id | class | type | name | geometry
|
||||
| 3 | highway | unclassified | 'name' : 'Cloud Street' | :w-south
|
||||
Then way 10 expands exactly to housenumbers 4
|
||||
And table placex contains
|
||||
Then table placex contains
|
||||
| object | parent_place_id
|
||||
| N1 | W3
|
||||
| N2 | W3
|
||||
| W10 | W3
|
||||
And table location_property_osmline contains
|
||||
| object | parent_place_id | startnumber | endnumber
|
||||
| W10 | W3 | 2 | 6
|
||||
|
||||
|
||||
Scenario: referenced road deleted
|
||||
@@ -156,12 +163,14 @@ Feature: Update of address interpolations
|
||||
| object | parent_place_id
|
||||
| N1 | W3
|
||||
| N2 | W3
|
||||
| W10 | W3
|
||||
And way 10 expands exactly to housenumbers 4
|
||||
And table location_property_osmline contains
|
||||
| object | parent_place_id | startnumber | endnumber
|
||||
| W10 | W3 | 2 | 6
|
||||
When marking for delete W3
|
||||
Then way 10 expands exactly to housenumbers 4
|
||||
And table placex contains
|
||||
Then table placex contains
|
||||
| object | parent_place_id
|
||||
| N1 | W2
|
||||
| N2 | W2
|
||||
| W10 | W2
|
||||
And table location_property_osmline contains
|
||||
| object | parent_place_id | startnumber | endnumber
|
||||
| W10 | W2 | 2 | 6
|
||||
|
||||
@@ -35,6 +35,7 @@ def check_placex_names(step, osmtyp, osmid):
|
||||
|
||||
|
||||
|
||||
|
||||
@step(u'table ([a-z_]+) contains$')
|
||||
def check_placex_content(step, tablename):
|
||||
""" check that the given lines are in the given table
|
||||
@@ -49,13 +50,21 @@ def check_placex_content(step, tablename):
|
||||
q = 'SELECT *'
|
||||
if tablename == 'placex':
|
||||
q = q + ", ST_X(centroid) as clat, ST_Y(centroid) as clon"
|
||||
q = q + ", ST_GeometryType(geometry) as geometrytype"
|
||||
q = q + ' FROM %s where osm_type = %%s and osm_id = %%s' % (tablename,)
|
||||
if tablename == 'location_property_osmline':
|
||||
q = q + ' FROM %s where osm_id = %%s' % (tablename,)
|
||||
else:
|
||||
q = q + ' FROM %s where osm_type = %%s and osm_id = %%s' % (tablename,)
|
||||
if cls is None:
|
||||
params = (osmtype, osmid)
|
||||
if tablename == 'location_property_osmline':
|
||||
params = (osmid,)
|
||||
else:
|
||||
params = (osmtype, osmid)
|
||||
else:
|
||||
q = q + ' and class = %s'
|
||||
params = (osmtype, osmid, cls)
|
||||
if tablename == 'location_property_osmline':
|
||||
params = (osmid, cls)
|
||||
else:
|
||||
params = (osmtype, osmid, cls)
|
||||
cur.execute(q, params)
|
||||
assert(cur.rowcount > 0)
|
||||
for res in cur:
|
||||
@@ -92,6 +101,18 @@ def check_placex_missing(step, tablename, osmtyp, osmid, placeclass):
|
||||
cur.close()
|
||||
world.conn.commit()
|
||||
|
||||
@step(u'table location_property_osmline has no entry for W(\d+)?')
|
||||
def check_osmline_missing(step, osmid):
|
||||
cur = world.conn.cursor()
|
||||
try:
|
||||
q = 'SELECT count(*) FROM location_property_osmline where osm_id = %s' % (osmid, )
|
||||
cur.execute(q)
|
||||
numres = cur.fetchone()[0]
|
||||
assert_equals (numres, 0)
|
||||
finally:
|
||||
cur.close()
|
||||
world.conn.commit()
|
||||
|
||||
@step(u'search_name table contains$')
|
||||
def check_search_name_content(step):
|
||||
cur = world.conn.cursor(cursor_factory=psycopg2.extras.DictCursor)
|
||||
@@ -134,12 +155,35 @@ def check_interpolated_housenumbers(step, nodeid):
|
||||
FROM placex WHERE osm_type = 'W' and osm_id = %s
|
||||
and class = 'place' and type = 'address'""",
|
||||
(int(nodeid),))
|
||||
|
||||
assert_equals(len(numbers), cur.rowcount)
|
||||
for r in cur:
|
||||
assert_in(r["housenumber"], numbers)
|
||||
world.match_geometry((r['clat'], r['clon']), numbers[r["housenumber"]])
|
||||
del numbers[r["housenumber"]]
|
||||
|
||||
@step(u'way (\d+) expands to lines')
|
||||
def check_interpolation_lines(step, wayid):
|
||||
"""Check that the correct interpolation line has been entered in
|
||||
location_property_osmline for the given source line/nodes. Expected are three columns:
|
||||
startnumber, endnumber and linegeo
|
||||
"""
|
||||
lines = {}
|
||||
for line in step.hashes:
|
||||
assert line["startnumber"] not in lines
|
||||
lines[line["startnumber"]] = {'endnumber': line["endnumber"], 'geometry': line["geometry"]}
|
||||
cur = world.conn.cursor(cursor_factory=psycopg2.extras.DictCursor)
|
||||
cur.execute("""SELECT startnumber::text, endnumber::text, st_astext(linegeo) as geometry
|
||||
FROM location_property_osmline WHERE osm_id = %s""",
|
||||
(int(wayid),))
|
||||
assert_equals(len(lines), cur.rowcount)
|
||||
for r in cur:
|
||||
assert_in(r["startnumber"], lines)
|
||||
assert_equals(r["endnumber"], lines[r["startnumber"]]["endnumber"])
|
||||
linegeo = str(str(r["geometry"].split('(')[1]).split(')')[0]).replace(',', ', ')
|
||||
assert_equals(linegeo, lines[r["startnumber"]]["geometry"])
|
||||
del lines[r["startnumber"]]
|
||||
|
||||
@step(u'way (\d+) expands exactly to housenumbers ([0-9,]*)')
|
||||
def check_interpolated_housenumber_list(step, nodeid, numberlist):
|
||||
""" Checks that the interpolated house numbers corresponds
|
||||
@@ -149,7 +193,7 @@ def check_interpolated_housenumber_list(step, nodeid, numberlist):
|
||||
cur = world.conn.cursor()
|
||||
cur.execute("""SELECT housenumber FROM placex
|
||||
WHERE osm_type = 'W' and osm_id = %s
|
||||
and class = 'place' and type = 'address'""", (int(nodeid),))
|
||||
and class = 'place' and type = 'address'""", (int(nodeid),))
|
||||
for r in cur:
|
||||
assert_in(r[0], expected, "Unexpected house number %s for node %s." % (r[0], nodeid))
|
||||
expected.remove(r[0])
|
||||
|
||||
@@ -23,6 +23,7 @@ import os
|
||||
import subprocess
|
||||
import random
|
||||
import base64
|
||||
import sys
|
||||
|
||||
psycopg2.extensions.register_type(psycopg2.extensions.UNICODE)
|
||||
|
||||
@@ -143,8 +144,8 @@ def import_set_scene(step, scene):
|
||||
|
||||
@step(u'the (named )?place (node|way|area)s')
|
||||
def import_place_table_nodes(step, named, osmtype):
|
||||
"""Insert a list of nodes into the placex table.
|
||||
Expects a table where columns are named in the same way as placex.
|
||||
"""Insert a list of nodes into the place table.
|
||||
Expects a table where columns are named in the same way as place.
|
||||
"""
|
||||
cur = world.conn.cursor()
|
||||
cur.execute('ALTER TABLE place DISABLE TRIGGER place_before_insert')
|
||||
@@ -214,18 +215,19 @@ def import_database(step):
|
||||
""" Runs the actual indexing. """
|
||||
world.run_nominatim_script('setup', 'create-functions', 'create-partition-functions')
|
||||
cur = world.conn.cursor()
|
||||
#world.db_dump_table('place')
|
||||
cur.execute("""insert into placex (osm_type, osm_id, class, type, name, admin_level,
|
||||
housenumber, street, addr_place, isin, postcode, country_code, extratags,
|
||||
geometry) select * from place""")
|
||||
geometry) select * from place where not (class='place' and type='houses' and osm_type='W')""")
|
||||
cur.execute("""select insert_osmline (osm_id, housenumber, street, addr_place, postcode, country_code, geometry) from place where class='place' and type='houses' and osm_type='W'""")
|
||||
world.conn.commit()
|
||||
world.run_nominatim_script('setup', 'index', 'index-noanalyse')
|
||||
#world.db_dump_table('placex')
|
||||
|
||||
#world.db_dump_table('location_property_osmline')
|
||||
|
||||
@step(u'updating place (node|way|area)s')
|
||||
def update_place_table_nodes(step, osmtype):
|
||||
""" Replace a geometry in place by reinsertion and reindex database.
|
||||
"""
|
||||
""" Replace a geometry in place by reinsertion and reindex database."""
|
||||
world.run_nominatim_script('setup', 'create-functions', 'create-partition-functions', 'enable-diff-updates')
|
||||
if osmtype == 'node':
|
||||
_insert_place_table_nodes(step.hashes, False)
|
||||
|
||||
@@ -123,16 +123,19 @@ def match_geometry(coord, matchstring):
|
||||
logger.debug("Distances expected: %f, got: %f" % (expdist, dist))
|
||||
assert dist <= expdist, "Geometry too far away, expected: %f, got: %f" % (expdist, dist)
|
||||
|
||||
@world.absorb
|
||||
def print_statement(element):
|
||||
print '\n\n\n'+str(element)+'\n\n\n'
|
||||
|
||||
|
||||
@world.absorb
|
||||
def db_dump_table(table):
|
||||
cur = world.conn.cursor()
|
||||
cur.execute('SELECT * FROM %s' % table)
|
||||
print '<<<<<<< BEGIN OF TABLE DUMP %s' % table
|
||||
print '\n\n\n<<<<<<< BEGIN OF TABLE DUMP %s' % table
|
||||
for res in cur:
|
||||
print res
|
||||
print '<<<<<<< END OF TABLE DUMP %s' % table
|
||||
print '<<<<<<< END OF TABLE DUMP %s\n\n\n' % table
|
||||
|
||||
@world.absorb
|
||||
def db_drop_database(name):
|
||||
|
||||
Reference in New Issue
Block a user