foreman/test/unit/host_parameter_test.rb @ 8a65dff7
d91a5a87 | José Luis Escalante | require 'test_helper'
|
|
class HostParameterTest < ActiveSupport::TestCase
|
|||
9fd7478e | Paul Kelly | setup do
|
|
User.current = User.find_by_login "admin"
|
|||
end
|
|||
aa1796f3 | Paul Kelly | test "should have a reference_id" do
|
|
d91a5a87 | José Luis Escalante | host_parameter = HostParameter.new
|
|
host_parameter.name = "valid"
|
|||
host_parameter.value = "valid"
|
|||
assert !host_parameter.save
|
|||
c4c59fbb | Ohad Levy | host = Host.first
|
|
aa1796f3 | Paul Kelly | host_parameter.reference_id = host.id
|
|
d91a5a87 | José Luis Escalante | assert host_parameter.save
|
|
end
|
|||
aa1796f3 | Paul Kelly | ||
test "duplicate names cannot exist for a host" do
|
|||
90b83222 | Ohad Levy | @host = hosts(:one)
|
|
9fd7478e | Paul Kelly | as_admin do
|
|
@parameter1 = HostParameter.create :name => "some parameter", :value => "value", :reference_id => @host.id
|
|||
@parameter2 = HostParameter.create :name => "some parameter", :value => "value", :reference_id => @host.id
|
|||
end
|
|||
assert !@parameter2.valid?
|
|||
assert @parameter2.errors.full_messages[0] == "Name has already been taken"
|
|||
aa1796f3 | Paul Kelly | end
|
|
test "duplicate names can exist for different hosts" do
|
|||
90b83222 | Ohad Levy | @host1 = hosts(:one)
|
|
@host2 = hosts(:two)
|
|||
9fd7478e | Paul Kelly | as_admin do
|
|
@parameter1 = HostParameter.create! :name => "some parameter", :value => "value", :reference_id => @host1.id
|
|||
@parameter2 = HostParameter.create! :name => "some parameter", :value => "value", :reference_id => @host2.id
|
|||
end
|
|||
assert @parameter2.valid?
|
|||
end
|
|||
aa1796f3 | Paul Kelly | ||
9fd7478e | Paul Kelly | def setup_user operation
|
|
@one = users(:one)
|
|||
as_admin do
|
|||
role = Role.find_or_create_by_name :name => "#{operation}_hosts"
|
|||
role.permissions = ["#{operation}_hosts".to_sym]
|
|||
@one.roles = [role]
|
|||
@one.domains = []
|
|||
@one.hostgroups = []
|
|||
@one.user_facts = []
|
|||
@one.save!
|
|||
end
|
|||
User.current = @one
|
|||
aa1796f3 | Paul Kelly | end
|
|
9fd7478e | Paul Kelly | 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
|
|||
90b83222 | Ohad Levy | record = HostParameter.create :name => "dummy", :value => "value", :reference_id => hosts(:one).id
|
|
9fd7478e | Paul Kelly | assert record.valid?
|
|
90b83222 | Ohad Levy | assert record.new_record?
|
|
9fd7478e | Paul Kelly | 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.new_record?
|
|||
end
|
|||
test "user with create permissions should be able to create when unconstrained" do
|
|||
setup_user "create"
|
|||
as_admin do
|
|||
@one.domains = []
|
|||
end
|
|||
90b83222 | Ohad Levy | record = HostParameter.create :name => "dummy", :value => "value", :reference_id => hosts(:one).id
|
|
9fd7478e | Paul Kelly | assert record.valid?
|
|
assert !record.new_record?
|
|||
end
|
|||
test "user with view permissions should not be able to create" do
|
|||
setup_user "view"
|
|||
90b83222 | Ohad Levy | record = HostParameter.create :name => "dummy", :value => "value", :reference_id => hosts(:one).id
|
|
9fd7478e | Paul Kelly | 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
|
|||
d91a5a87 | José Luis Escalante | ||
9fd7478e | Paul Kelly | 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
|