require "test_helper"
module Api
- class PermissionsControllerTest < ActionController::TestCase
+ class PermissionsControllerTest < ActionDispatch::IntegrationTest
##
# test all routes which lead to this controller
def test_routes
end
def test_permissions_anonymous
- get :show
+ get permissions_path
assert_response :success
assert_select "osm > permissions", :count => 1 do
assert_select "permission", :count => 0
end
def test_permissions_basic_auth
- basic_authorization create(:user).email, "test"
- get :show
+ auth_header = basic_authorization_header create(:user).email, "test"
+ get permissions_path, :headers => auth_header
assert_response :success
assert_select "osm > permissions", :count => 1 do
assert_select "permission", :count => ClientApplication.all_permissions.size
end
end
- def test_permissions_oauth
- @request.env["oauth.token"] = AccessToken.new do |token|
- # Just to test a few
- token.allow_read_prefs = true
- token.allow_write_api = true
- token.allow_read_gpx = false
+ def test_permissions_oauth1
+ token = create(:access_token,
+ :allow_read_prefs => true,
+ :allow_write_api => true,
+ :allow_read_gpx => false)
+ signed_get permissions_path, :oauth => { :token => token }
+ assert_response :success
+ assert_select "osm > permissions", :count => 1 do
+ assert_select "permission", :count => 2
+ assert_select "permission[name='allow_read_prefs']", :count => 1
+ assert_select "permission[name='allow_write_api']", :count => 1
+ assert_select "permission[name='allow_read_gpx']", :count => 0
end
- get :show
+ end
+
+ def test_permissions_oauth2
+ user = create(:user)
+ token = create(:oauth_access_token,
+ :resource_owner_id => user.id,
+ :scopes => %w[read_prefs write_api])
+ get permissions_path, :headers => bearer_authorization_header(token.token)
assert_response :success
assert_select "osm > permissions", :count => 1 do
assert_select "permission", :count => 2