|
require 'test_helper'
|
|
|
|
class Api::V2::ConfigTemplatesControllerTest < ActionController::TestCase
|
|
test "should get index" do
|
|
get :index
|
|
templates = ActiveSupport::JSON.decode(@response.body)
|
|
assert !templates.empty?, "Should response with template"
|
|
assert_response :success
|
|
end
|
|
|
|
test "should get template detail" do
|
|
get :show, { :id => templates(:pxekickstart).to_param }
|
|
assert_response :success
|
|
template = ActiveSupport::JSON.decode(@response.body)
|
|
assert !template.empty?
|
|
assert_equal template["name"], templates(:pxekickstart).name
|
|
end
|
|
|
|
test "should create valid" do
|
|
ProvisioningTemplate.any_instance.stubs(:valid?).returns(true)
|
|
valid_attrs = { :template => "This is a test template", :template_kind_id => template_kinds(:ipxe).id, :name => "RandomName" }
|
|
post :create, { :config_template => valid_attrs }
|
|
template = ActiveSupport::JSON.decode(@response.body)
|
|
assert template["name"] == "RandomName"
|
|
assert_response :created
|
|
end
|
|
|
|
test "should not create invalid" do
|
|
post :create
|
|
assert_response 422
|
|
end
|
|
|
|
test "should update valid" do
|
|
ProvisioningTemplate.any_instance.stubs(:valid?).returns(true)
|
|
put :update, { :id => templates(:pxekickstart).to_param,
|
|
:config_template => { :template => "blah" } }
|
|
assert_response :ok
|
|
end
|
|
|
|
test "should update associated operating systems with unwrapped parameters" do
|
|
tpl = templates(:pxekickstart)
|
|
os = operatingsystems(:solaris10)
|
|
refute tpl.operatingsystem_ids.include?(os.id), "OS can't be associated to the config template before the test"
|
|
|
|
ProvisioningTemplate.any_instance.stubs(:valid?).returns(true)
|
|
put :update, { :id => tpl.to_param,
|
|
:operatingsystem_ids => [os.to_param] }
|
|
assert_response :ok
|
|
|
|
tpl.reload
|
|
assert tpl.operatingsystem_ids.include?(os.id), "OS was not assigned to the config template"
|
|
end
|
|
|
|
test "should not update invalid" do
|
|
put :update, { :id => templates(:pxekickstart).to_param,
|
|
:config_template => { :name => "" } }
|
|
assert_response 422
|
|
end
|
|
|
|
test "should not destroy template with associated hosts" do
|
|
config_template = templates(:pxekickstart)
|
|
delete :destroy, { :id => config_template.to_param }
|
|
assert_response 422
|
|
assert ProvisioningTemplate.exists?(config_template.id)
|
|
end
|
|
|
|
test "should destroy" do
|
|
config_template = templates(:pxekickstart)
|
|
config_template.os_default_templates.clear
|
|
delete :destroy, { :id => config_template.to_param }
|
|
assert_response :ok
|
|
refute ProvisioningTemplate.exists?(config_template.id)
|
|
end
|
|
|
|
test "should build pxe menu" do
|
|
ProxyAPI::TFTP.any_instance.stubs(:create_default).returns(true)
|
|
ProxyAPI::TFTP.any_instance.stubs(:fetch_boot_file).returns(true)
|
|
post :build_pxe_default
|
|
response_body = ActiveSupport::JSON.decode(@response.body)
|
|
assert_response 200
|
|
assert response_body.is_a?(Hash)
|
|
refute response_body['message'].nil?
|
|
end
|
|
|
|
test "should add audit comment" do
|
|
ProvisioningTemplate.auditing_enabled = true
|
|
ProvisioningTemplate.any_instance.stubs(:valid?).returns(true)
|
|
put :update, { :id => templates(:pxekickstart).to_param,
|
|
:config_template => { :audit_comment => "aha", :template => "tmp" } }
|
|
assert_response :success
|
|
assert_equal "aha", templates(:pxekickstart).audits.last.comment
|
|
end
|
|
|
|
test 'should clone template' do
|
|
original_config_template = templates(:pxekickstart)
|
|
post :clone, { :id => original_config_template.to_param,
|
|
:config_template => {:name => 'MyClone'} }
|
|
assert_response :success
|
|
template = ActiveSupport::JSON.decode(@response.body)
|
|
assert_equal(template['name'], 'MyClone')
|
|
assert_equal(template['template'], original_config_template.template)
|
|
end
|
|
|
|
test 'clone name should not be blank' do
|
|
post :clone, { :id => templates(:pxekickstart).to_param,
|
|
:config_template => {:name => ''} }
|
|
assert_response :unprocessable_entity
|
|
end
|
|
|
|
test "should show templates from os" do
|
|
get :index, { :operatingsystem_id => operatingsystems(:centos5_3).fullname }
|
|
assert_response :success
|
|
end
|
|
|
|
test "should list templates with non-admin user" do
|
|
setup_user('view', 'provisioning_templates')
|
|
get :index, {}, set_session_user.merge(:user => User.current.id)
|
|
assert_response :success
|
|
templates = ActiveSupport::JSON.decode(@response.body)
|
|
assert !templates.empty?, "Should respond with templates"
|
|
end
|
|
|
|
test "should show template with non-admin user" do
|
|
setup_user('view', 'provisioning_templates')
|
|
get :show, { :id => templates(:pxekickstart).to_param }, set_session_user.merge(:user => User.current.id)
|
|
assert_response :success
|
|
end
|
|
end
|