Refactored user_role and controller. Now much more DRY.

This commit is contained in:
Matt Amos 2009-10-01 17:15:34 +00:00
parent 77851bac7b
commit 1e3b3c1f10
6 changed files with 119 additions and 68 deletions

View file

@ -1,38 +0,0 @@
require File.dirname(__FILE__) + '/../test_helper'
class UserRolesControllerTest < ActionController::TestCase
fixtures :users, :user_roles
test "grant" do
check_forbidden(:grant, :public_user)
check_forbidden(:grant, :moderator_user)
check_success(:grant, :administrator_user)
end
test "revoke" do
check_forbidden(:revoke, :public_user)
check_forbidden(:revoke, :moderator_user)
check_success(:revoke, :administrator_user)
end
def check_forbidden(action, user)
UserRole::ALL_ROLES.each do |role|
u = users(user)
basic_authorization(u.email, "test")
get(action, {:display_name => users(:second_public_user).display_name, :role => role}, {'user' => u.id})
assert_response :redirect
assert_redirected_to "/403.html"
end
end
def check_success(action, user)
UserRole::ALL_ROLES.each do |role|
u = users(user)
basic_authorization(u.email, "test")
get(action, {:display_name => users(:second_public_user).display_name, :role => role}, {'user' => u.id})
assert_response :success
end
end
end