]> git.openstreetmap.org Git - nominatim.git/blob - test/bdd/db/query/postcodes.feature
add forgotten BDD test
[nominatim.git] / test / bdd / db / query / postcodes.feature
1 @DB
2 Feature: Querying fo postcode variants
3
4     Scenario: Postcodes in Singapore (6-digit postcode)
5         Given the grid with origin SG
6             | 10 |   |   |   | 11 |
7         And the places
8             | osm | class   | type | name   | addr+postcode | geometry |
9             | W1  | highway | path | Lorang | 399174        | 10,11    |
10         When importing
11         When sending search query "399174"
12         Then results contain
13             | ID | type     | display_name |
14             | 0  | postcode | 399174, Singapore |
15
16
17     @fail-legacy
18     Scenario Outline: Postcodes in the Netherlands (mixed postcode with spaces)
19         Given the grid with origin NL
20             | 10 |   |   |   | 11 |
21         And the places
22             | osm | class   | type | name     | addr+postcode | geometry |
23             | W1  | highway | path | De Weide | 3993 DX       | 10,11    |
24         When importing
25         When sending search query "3993 DX"
26         Then results contain
27             | ID | type     | display_name |
28             | 0  | postcode | 3993 DX, Nederland      |
29         When sending search query "3993dx"
30         Then results contain
31             | ID | type     | display_name |
32             | 0  | postcode | 3993 DX, Nederland      |
33
34         Examples:
35             | postcode |
36             | 3993 DX  |
37             | 3993DX   |
38             | 3993 dx  |
39
40
41     @fail-legacy
42     Scenario: Postcodes in Singapore (6-digit postcode)
43         Given the grid with origin SG
44             | 10 |   |   |   | 11 |
45         And the places
46             | osm | class   | type | name   | addr+postcode | geometry |
47             | W1  | highway | path | Lorang | 399174        | 10,11    |
48         When importing
49         When sending search query "399174"
50         Then results contain
51             | ID | type     | display_name |
52             | 0  | postcode | 399174, Singapore       |
53
54
55     @fail-legacy
56     Scenario Outline: Postcodes in Andorra (with country code)
57         Given the grid with origin AD
58             | 10 |   |   |   | 11 |
59         And the places
60             | osm | class   | type | name   | addr+postcode | geometry |
61             | W1  | highway | path | Lorang | <postcode>    | 10,11    |
62         When importing
63         When sending search query "675"
64         Then results contain
65             | ID | type     | display_name |
66             | 0  | postcode | AD675, Andorra |
67         When sending search query "AD675"
68         Then results contain
69             | ID | type     | display_name |
70             | 0  | postcode | AD675, Andorra |
71
72         Examples:
73             | postcode |
74             | 675      |
75             | AD 675   |
76             | AD675    |
77
78
79     Scenario: Different postcodes with the same normalization can both be found
80         Given the places
81            | osm | class | type  | addr+postcode | addr+housenumber | geometry |
82            | N34 | place | house | EH4 7EA       | 111              | country:gb |
83            | N35 | place | house | E4 7EA        | 111              | country:gb |
84         When importing
85         Then location_postcode contains exactly
86            | country | postcode | geometry |
87            | gb      | EH4 7EA  | country:gb |
88            | gb      | E4 7EA   | country:gb |
89         When sending search query "EH4 7EA"
90         Then results contain
91            | type     | display_name |
92            | postcode | EH4 7EA, United Kingdom |
93         When sending search query "E4 7EA"
94         Then results contain
95            | type     | display_name |
96            | postcode | E4 7EA, United Kingdom |
97
98
99     @fail-legacy
100     @v1-api-python-only
101     Scenario: Postcode areas are preferred over postcode points
102         Given the grid with origin DE
103             | 1 | 2 |
104             | 4 | 3 |
105         Given the places
106             | osm | class    | type        | postcode | geometry    |
107             | R23 | boundary | postal_code | 12345    | (1,2,3,4,1) |
108         When importing
109         Then location_postcode contains exactly
110           | country | postcode |
111           | de      | 12345    |
112         When sending search query "12345, de"
113         Then results contain
114           | osm |
115           | R23 |