+
+ def test_capabilities_json
+ get api_capabilities_path, :params => { :format => "json" }
+ assert_response :success
+ js = ActiveSupport::JSON.decode(@response.body)
+ assert_not_nil js
+
+ assert_equal Settings.api_version, js["version"]
+ assert_equal Settings.generator, js["generator"]
+ assert_equal Settings.api_version, js["api"]["version"]["minimum"]
+ assert_equal Settings.api_version, js["api"]["version"]["maximum"]
+ assert_equal Settings.max_request_area, js["api"]["area"]["maximum"]
+ assert_equal Settings.max_note_request_area, js["api"]["note_area"]["maximum"]
+ assert_equal Settings.tracepoints_per_page, js["api"]["tracepoints"]["per_page"]
+ assert_equal Changeset::MAX_ELEMENTS, js["api"]["changesets"]["maximum_elements"]
+ assert_equal Settings.default_changeset_query_limit, js["api"]["changesets"]["default_query_limit"]
+ assert_equal Settings.max_changeset_query_limit, js["api"]["changesets"]["maximum_query_limit"]
+ assert_equal Settings.max_number_of_relation_members, js["api"]["relationmembers"]["maximum"]
+ assert_equal Settings.default_note_query_limit, js["api"]["notes"]["default_query_limit"]
+ assert_equal Settings.max_note_query_limit, js["api"]["notes"]["maximum_query_limit"]
+ assert_equal "online", js["api"]["status"]["database"]
+ assert_equal "online", js["api"]["status"]["api"]
+ assert_equal "online", js["api"]["status"]["gpx"]
+ assert_equal Settings.imagery_blacklist.length, js["policy"]["imagery"]["blacklist"].length
+ end
+
+ def test_capabilities_api_readonly
+ with_settings(:status => "api_readonly") do
+ get api_capabilities_path
+ assert_response :success
+ assert_select "osm[version='#{Settings.api_version}'][generator='#{Settings.generator}']", :count => 1 do
+ assert_select "api", :count => 1 do
+ assert_select "status[database='online']", :count => 1
+ assert_select "status[api='readonly']", :count => 1
+ assert_select "status[gpx='online']", :count => 1
+ end
+ end
+ end
+ end
+
+ def test_capabilities_api_offline
+ with_settings(:status => "api_offline") do
+ get api_capabilities_path
+ assert_response :success
+ assert_select "osm[version='#{Settings.api_version}'][generator='#{Settings.generator}']", :count => 1 do
+ assert_select "api", :count => 1 do
+ assert_select "status[database='online']", :count => 1
+ assert_select "status[api='offline']", :count => 1
+ assert_select "status[gpx='online']", :count => 1
+ end
+ end
+ end
+ end
+
+ def test_capabilities_database_readonly
+ with_settings(:status => "database_readonly") do
+ get api_capabilities_path
+ assert_response :success
+ assert_select "osm[version='#{Settings.api_version}'][generator='#{Settings.generator}']", :count => 1 do
+ assert_select "api", :count => 1 do
+ assert_select "status[database='readonly']", :count => 1
+ assert_select "status[api='readonly']", :count => 1
+ assert_select "status[gpx='readonly']", :count => 1
+ end
+ end
+ end
+ end
+
+ def test_capabilities_database_offline
+ with_settings(:status => "database_offline") do
+ get api_capabilities_path
+ assert_response :success
+ assert_select "osm[version='#{Settings.api_version}'][generator='#{Settings.generator}']", :count => 1 do
+ assert_select "api", :count => 1 do
+ assert_select "status[database='offline']", :count => 1
+ assert_select "status[api='offline']", :count => 1
+ assert_select "status[gpx='offline']", :count => 1
+ end
+ end
+ end
+ end
+
+ def test_capabilities_gpx_offline
+ with_settings(:status => "gpx_offline") do
+ get api_capabilities_path
+ assert_response :success
+ assert_select "osm[version='#{Settings.api_version}'][generator='#{Settings.generator}']", :count => 1 do
+ assert_select "api", :count => 1 do
+ assert_select "status[database='online']", :count => 1
+ assert_select "status[api='online']", :count => 1
+ assert_select "status[gpx='offline']", :count => 1
+ end
+ end
+ end
+ end