Project

General

Profile

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

class UserTest < ActiveSupport::TestCase
def setup
User.current = User.find_by_login "admin"
@user = User.create :auth_source => auth_sources(:one), :login => "foo", :mail => "foo@bar.com"
end

test "should have login" do
u = User.new :auth_source => auth_sources(:one), :mail => "foo@bar.com"
assert !u.save
end

test "should have mail" do
u = User.new :auth_source => auth_sources(:one), :login => "foo"
assert !u.save
end

test "login should be unique" do
u = User.new :auth_source => auth_sources(:one), :login => "foo", :mail => "foo@bar.com"

assert !u.valid?
end

test "login should also be unique across usergroups" do
ug = Usergroup.create :name => "foo"
u = User.new :auth_source => auth_sources(:one), :login => "foo", :mail => "foo@bar.com"

assert !u.valid?
end

test "mail should have format" do
u = User.new :auth_source => auth_sources(:one), :login => "foo", :mail => "bar"
assert !u.valid?
end

test "login size should not exceed the 30 characters" do
u = User.new :auth_source => auth_sources(:one), :login => "a" * 31, :mail => "foo@bar.com"
assert !u.save
end

test "firstname should have the correct format" do
@user.firstname = "The Riddle?"
assert !@user.save

@user.firstname = " _''. - nah"
assert @user.save
end

test "lastname should have the correct format" do
@user.lastname = "it's the JOKER$$$"
assert !@user.save

@user.lastname = " _''. - nah"
assert @user.save
end

test "firstname should not exceed the 30 characters" do
@user.firstname = "a" * 31
assert !@user.save
end

test "lastname should not exceed the 30 characters" do
@user.firstname = "a" * 31
assert !@user.save
end

test "mail should not exceed the 60 characters" do
u = User.create :auth_source => auth_sources(:one), :login => "foo"
u.mail = "foo" * 20 + "@bar.com"
assert !u.save
end

test "to_label method should return a firstname and the lastname" do
@user.firstname = "Ali Al"
@user.lastname = "Salame"
assert @user.save

assert_equal "Ali Al Salame", @user.to_label
end

test "when try to login if password is empty should return nil" do
assert_equal nil, User.try_to_login("anything", "")
end
# couldn't continue testing the rest of login method cause use auth_source.authenticate, which is not implemented yet

test "should not be able to delete the admin account" do
assert !User.find_by_login("admin").destroy
end

def setup_user operation
@one = users(:one)
as_admin do
role = Role.find_or_create_by_name :name => "#{operation}_users"
role.permissions = ["#{operation}_users".to_sym]
@one.roles = [role]
@one.save!
end
User.current = @one
end

test "user with create permissions should be able to create" do
setup_user "create"
record = User.new :login => "dummy", :mail => "j@j.com", :auth_source_id => AuthSourceInternal.first.id
record.password_hash = "asd"
assert record.save
assert record.valid?
assert !record.new_record?
end

test "user with view permissions should not be able to create" do
setup_user "view"
record = User.new :login => "dummy", :mail => "j@j.com", :auth_source_id => AuthSourceInternal.first.id
record.password_hash = "asd"
assert !record.save
assert record.valid?
assert record.new_record?
end

test "user with destroy permissions should be able to destroy" do
setup_user "destroy"
record = users(:one)
assert record.destroy
assert record.frozen?
end

test "user with edit permissions should not be able to destroy" do
setup_user "edit"
record = User.first
assert !record.destroy
assert !record.frozen?
end

test "user with edit permissions should be able to edit" do
setup_user "edit"
record = User.first
record.login = "renamed"
assert record.save
end

test "user with destroy permissions should not be able to edit" do
setup_user "destroy"
record = User.first
record.login = "renamed"
assert !record.save
assert record.valid?
end

end

(42-42/43)