Project

General

Profile

Download (3.28 KB) Statistics
| Branch: | Tag: | Revision:
require 'test_helper'

class AuthSourceLdapsControllerTest < ActionController::TestCase
def test_index
get :index, {}, set_session_user
assert_template 'index'
end

def test_new
get :new, {}, set_session_user
assert_template 'new'
end

def test_create_invalid
AuthSourceLdap.any_instance.stubs(:valid?).returns(false)
post :create, {:auth_source_ldap => {:name => nil}}, set_session_user
assert_template 'new'
end

def test_create_valid
AuthSourceLdap.any_instance.stubs(:valid?).returns(true)
post :create, {:auth_source_ldap => {:name => AuthSourceLdap.first.name}}, set_session_user
assert_redirected_to auth_source_ldaps_url
end

def test_edit
get :edit, {:id => AuthSourceLdap.first}, set_session_user
assert_template 'edit'
end

def test_update_invalid
AuthSourceLdap.any_instance.stubs(:valid?).returns(false)
put :update, {:id => AuthSourceLdap.first, :auth_source_ldap => {:name => AuthSourceLdap.first.name} }, set_session_user
assert_template 'edit'
end

def test_formats_valid
AuthSourceLdap.any_instance.stubs(:valid?).returns(false)
put :update, {:id => AuthSourceLdap.first.id, :format => "weird", :auth_source_ldap => {:name => AuthSourceLdap.first.name} }, set_session_user
assert_response :success

wierd_id = "#{AuthSourceLdap.first.id}.weird"
put :update, {:id => wierd_id, :auth_source_ldap => {:name => AuthSourceLdap.first.name} }, set_session_user
assert_response :success

parameterized_id = "#{AuthSourceLdap.first.id}-#{AuthSourceLdap.first.name.parameterize}"
put :update, {:id => parameterized_id, :auth_source_ldap => {:name => AuthSourceLdap.first.name} }, set_session_user
assert_response :success
end

def test_update_valid
AuthSourceLdap.any_instance.stubs(:valid?).returns(true)
put :update, {:id => AuthSourceLdap.first, :auth_source_ldap => {:name => AuthSourceLdap.first.name} }, set_session_user
assert_redirected_to auth_source_ldaps_url
end

def test_destroy
auth_source_ldap = AuthSourceLdap.first
User.where(:auth_source_id => auth_source_ldap.id).update_all(:auth_source_id => nil)
delete :destroy, {:id => auth_source_ldap}, set_session_user
assert_redirected_to auth_source_ldaps_url
assert !AuthSourceLdap.exists?(auth_source_ldap.id)
end

def setup_user
@request.session[:user] = users(:one).id
users(:one).roles = [Role.find_by_name('Anonymous'), Role.find_by_name('Viewer')]
end

def user_with_viewer_rights_should_fail_to_an_edit_authentication_source
setup_user
get :edit, {:id => AuthSourceLdap.first.id}
assert @response.status == '403 Forbidden'
end

def user_with_viewer_rights_should_succeed_in_viewing_authentication_sources
setup_user
get :index
assert_response :success
end

test "blank account_password submitted does not erase existing account_password" do
auth_source_ldap = AuthSourceLdap.first
old_pass = auth_source_ldap.account_password
as_admin do
put :update, {:commit => "Update", :id => auth_source_ldap.id, :auth_source_ldap => {:account_password => nil, :name => auth_source_ldap.name} }, set_session_user
end
auth_source_ldap = AuthSourceLdap.find(auth_source_ldap.id)
assert_equal old_pass, auth_source_ldap.account_password
end
end
(4-4/46)