4 require 'geocoder_controller'
6 class GeocoderControllerTest < ActionController::TestCase
8 # test all routes which lead to this controller
11 { :path => "/search", :method => :get },
12 { :controller => "geocoder", :action => "search" }
15 { :path => "/geocoder/search_latlon", :method => :get },
16 { :controller => "geocoder", :action => "search_latlon" }
19 { :path => "/geocoder/search_us_postcode", :method => :get },
20 { :controller => "geocoder", :action => "search_us_postcode" }
23 { :path => "/geocoder/search_uk_postcode", :method => :get },
24 { :controller => "geocoder", :action => "search_uk_postcode" }
27 { :path => "/geocoder/search_ca_postcode", :method => :get },
28 { :controller => "geocoder", :action => "search_ca_postcode" }
31 { :path => "/geocoder/search_osm_nominatim", :method => :get },
32 { :controller => "geocoder", :action => "search_osm_nominatim" }
35 { :path => "/geocoder/search_geonames", :method => :get },
36 { :controller => "geocoder", :action => "search_geonames" }
39 { :path => "/geocoder/search_osm_nominatim_reverse", :method => :get },
40 { :controller => "geocoder", :action => "search_osm_nominatim_reverse" }
43 { :path => "/geocoder/search_geonames_reverse", :method => :get },
44 { :controller => "geocoder", :action => "search_geonames_reverse" }
49 # Test identification of basic lat/lon pairs
50 def test_identify_latlon_basic
54 '+50.06773 +14.37742',
55 '+50.06773, +14.37742'
57 latlon_check code, 50.06773, 14.37742
62 # Test identification of lat/lon pairs using N/E with degrees
63 def test_identify_latlon_ne_d
65 'N50.06773 E14.37742',
66 'N50.06773, E14.37742',
67 '50.06773N 14.37742E',
68 '50.06773N, 14.37742E'
70 latlon_check code, 50.06773, 14.37742
75 # Test identification of lat/lon pairs using N/W with degrees
76 def test_identify_latlon_nw_d
78 'N50.06773 W14.37742',
79 'N50.06773, W14.37742',
80 '50.06773N 14.37742W',
81 '50.06773N, 14.37742W'
83 latlon_check code, 50.06773, -14.37742
88 # Test identification of lat/lon pairs using S/E with degrees
89 def test_identify_latlon_se_d
91 'S50.06773 E14.37742',
92 'S50.06773, E14.37742',
93 '50.06773S 14.37742E',
94 '50.06773S, 14.37742E'
96 latlon_check code, -50.06773, 14.37742
101 # Test identification of lat/lon pairs using S/W with degrees
102 def test_identify_latlon_sw_d
104 'S50.06773 W14.37742',
105 'S50.06773, W14.37742',
106 '50.06773S 14.37742W',
107 '50.06773S, 14.37742W'
109 latlon_check code, -50.06773, -14.37742
114 # Test identification of lat/lon pairs using N/E with degrees/mins
115 def test_identify_latlon_ne_dm
117 'N 50° 04.064 E 014° 22.645',
118 "N 50° 04.064' E 014° 22.645",
119 "N 50° 04.064', E 014° 22.645'",
120 'N50° 04.064 E14° 22.645',
121 'N 50 04.064 E 014 22.645',
122 'N50 4.064 E14 22.645',
123 "50° 04.064' N, 014° 22.645' E"
125 latlon_check code, 50.06773, 14.37742
130 # Test identification of lat/lon pairs using N/W with degrees/mins
131 def test_identify_latlon_nw_dm
133 'N 50° 04.064 W 014° 22.645',
134 "N 50° 04.064' W 014° 22.645",
135 "N 50° 04.064', W 014° 22.645'",
136 'N50° 04.064 W14° 22.645',
137 'N 50 04.064 W 014 22.645',
138 'N50 4.064 W14 22.645',
139 "50° 04.064' N, 014° 22.645' W"
141 latlon_check code, 50.06773, -14.37742
146 # Test identification of lat/lon pairs using S/E with degrees/mins
147 def test_identify_latlon_se_dm
149 'S 50° 04.064 E 014° 22.645',
150 "S 50° 04.064' E 014° 22.645",
151 "S 50° 04.064', E 014° 22.645'",
152 'S50° 04.064 E14° 22.645',
153 'S 50 04.064 E 014 22.645',
154 'S50 4.064 E14 22.645',
155 "50° 04.064' S, 014° 22.645' E"
157 latlon_check code, -50.06773, 14.37742
162 # Test identification of lat/lon pairs using S/W with degrees/mins
163 def test_identify_latlon_sw_dm
165 'S 50° 04.064 W 014° 22.645',
166 "S 50° 04.064' W 014° 22.645",
167 "S 50° 04.064', W 014° 22.645'",
168 'S50° 04.064 W14° 22.645',
169 'S 50 04.064 W 014 22.645',
170 'S50 4.064 W14 22.645',
171 "50° 04.064' S, 014° 22.645' W"
173 latlon_check code, -50.06773, -14.37742
178 # Test identification of lat/lon pairs using N/E with degrees/mins/secs
179 def test_identify_latlon_ne_dms
181 "N 50° 4' 03.828\" E 14° 22' 38.712\"",
182 "N 50° 4' 03.828\", E 14° 22' 38.712\"",
183 "N 50° 4′ 03.828″, E 14° 22′ 38.712″",
184 'N50 4 03.828 E14 22 38.712',
185 'N50 4 03.828, E14 22 38.712',
186 "50°4'3.828\"N 14°22'38.712\"E"
188 latlon_check code, 50.06773, 14.37742
193 # Test identification of lat/lon pairs using N/W with degrees/mins/secs
194 def test_identify_latlon_nw_dms
196 "N 50° 4' 03.828\" W 14° 22' 38.712\"",
197 "N 50° 4' 03.828\", W 14° 22' 38.712\"",
198 "N 50° 4′ 03.828″, W 14° 22′ 38.712″",
199 'N50 4 03.828 W14 22 38.712',
200 'N50 4 03.828, W14 22 38.712',
201 "50°4'3.828\"N 14°22'38.712\"W"
203 latlon_check code, 50.06773, -14.37742
208 # Test identification of lat/lon pairs using S/E with degrees/mins/secs
209 def test_identify_latlon_se_dms
211 "S 50° 4' 03.828\" E 14° 22' 38.712\"",
212 "S 50° 4' 03.828\", E 14° 22' 38.712\"",
213 "S 50° 4′ 03.828″, E 14° 22′ 38.712″",
214 'S50 4 03.828 E14 22 38.712',
215 'S50 4 03.828, E14 22 38.712',
216 "50°4'3.828\"S 14°22'38.712\"E"
218 latlon_check code, -50.06773, 14.37742
223 # Test identification of lat/lon pairs using S/W with degrees/mins/secs
224 def test_identify_latlon_sw_dms
226 "S 50° 4' 03.828\" W 14° 22' 38.712\"",
227 "S 50° 4' 03.828\", W 14° 22' 38.712\"",
228 "S 50° 4′ 03.828″, W 14° 22′ 38.712″",
229 'S50 4 03.828 W14 22 38.712',
230 'S50 4 03.828, W14 22 38.712',
231 "50°4'3.828\"S 14°22'38.712\"W"
233 latlon_check code, -50.06773, -14.37742
238 # Test identification of US zipcodes
239 def test_identify_us_postcode
244 post :search, query: code
245 assert_response :success
246 assert_equal ['us_postcode', 'osm_nominatim'], assigns(:sources)
251 # Test identification of UK postcodes using examples from
252 # http://en.wikipedia.org/wiki/Postcodes_in_the_United_Kingdom
253 def test_identify_uk_postcode
262 search_check code, ['uk_postcode', 'osm_nominatim']
267 # Test identification of Canadian postcodes
268 def test_identify_ca_postcode
269 search_check 'A1B 2C3', ['ca_postcode', 'osm_nominatim']
273 # Test identification fall through to the default case
274 def test_identify_default
275 search_check 'foo bar baz', ['osm_nominatim']
279 def latlon_check(query, lat, lon)
280 post :search, :query => query
281 assert_response :success
282 assert_template "search"
283 assert_template :layout => "map"
284 assert_equal ['latlon' ,'osm_nominatim_reverse'], assigns(:sources)
285 assert_nil @controller.params[:query]
286 assert_in_delta lat, @controller.params[:lat]
287 assert_in_delta lon, @controller.params[:lon]
289 xhr :post, :search, :query => query
290 assert_response :success
291 assert_template "search"
292 assert_template :layout => "xhr"
293 assert_equal ['latlon' ,'osm_nominatim_reverse'], assigns(:sources)
294 assert_nil @controller.params[:query]
295 assert_in_delta lat, @controller.params[:lat]
296 assert_in_delta lon, @controller.params[:lon]
299 def search_check(query, sources)
300 post :search, :query => query
301 assert_response :success
302 assert_template "search"
303 assert_template :layout => "map"
304 assert_equal sources, assigns(:sources)
306 xhr :post, :search, :query => query
307 assert_response :success
308 assert_template "search"
309 assert_template :layout => "xhr"
310 assert_equal sources, assigns(:sources)