Revision acfbc458
Added by Marek Hulán about 10 years ago
test/unit/host_parameter_test.rb | ||
---|---|---|
assert @parameter2.valid?
|
||
end
|
||
|
||
def setup_user operation, type = "params"
|
||
@one = users(:one)
|
||
as_admin do
|
||
role = Role.find_or_create_by_name :name => "#{operation}_#{type}"
|
||
role.permissions = ["#{operation}_#{type}".to_sym]
|
||
@one.roles = [role]
|
||
@one.domains.destroy_all
|
||
@one.hostgroups.destroy_all
|
||
@one.user_facts.destroy_all
|
||
@one.save!
|
||
end
|
||
User.current = @one
|
||
end
|
||
|
||
test "user with create permissions should be able to create when permitted" do
|
||
setup_user "create"
|
||
as_admin do
|
||
@one.domains = [domains(:mydomain)]
|
||
@one.save!
|
||
end
|
||
host_parameter = HostParameter.create! :name => "dummy", :value => "value", :reference_id => hosts(:one).id
|
||
assert host_parameter
|
||
end
|
||
|
||
test "user with create permissions should not be able to create when not permitted" do
|
||
setup_user "create"
|
||
as_admin do
|
||
@one.hostgroups = [hostgroups(:common)]
|
||
@one.save!
|
||
hosts(:one).update_attribute :hostgroup, hostgroups(:unusual)
|
||
end
|
||
record = HostParameter.create :name => "dummy", :value => "value", :reference_id => hosts(:one).id
|
||
assert record.valid?
|
||
assert !record.save
|
||
end
|
||
|
||
test "user with create permissions should be able to create when unconstrained" do
|
||
setup_user "create"
|
||
as_admin do
|
||
@one.domains.destroy_all
|
||
end
|
||
host_parameter = HostParameter.create! :name => "dummy", :value => "value", :reference_id => hosts(:one).id
|
||
assert host_parameter
|
||
end
|
||
|
||
test "user with view permissions should not be able to create" do
|
||
setup_user "view", "hosts"
|
||
record = HostParameter.create :name => "dummy", :value => "value", :reference_id => hosts(:one).id
|
||
assert record.valid?
|
||
assert record.new_record?
|
||
end
|
||
|
||
test "user with destroy permissions should be able to destroy" do
|
||
setup_user "destroy"
|
||
record = HostParameter.first
|
||
assert record.destroy
|
||
assert record.frozen?
|
||
end
|
||
|
||
test "user with edit permissions should not be able to destroy" do
|
||
setup_user "edit"
|
||
record = HostParameter.first
|
||
assert !record.destroy
|
||
assert !record.frozen?
|
||
end
|
||
|
||
test "user with edit permissions should be able to edit" do
|
||
setup_user "edit"
|
||
record = HostParameter.first
|
||
record.name = "renamed"
|
||
assert record.save
|
||
end
|
||
|
||
test "user with destroy permissions should not be able to edit" do
|
||
setup_user "destroy"
|
||
record = HostParameter.first
|
||
record.name = "renamed"
|
||
assert !record.save
|
||
end
|
||
end
|
Also available in: Unified diff
fixes #812 - new permissions model, user group role and nest support, role filters for better granularity
Contributions from: