Project

General

Profile

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

class ProvisioningTemplatesControllerTest < ActionController::TestCase
basic_pagination_per_page_test
basic_pagination_rendered_test

test "index" do
get :index, session: set_session_user
assert_template 'index'
end

test "new" do
get :new, session: set_session_user
assert_template 'new'
end

test "create invalid" do
ProvisioningTemplate.any_instance.stubs(:valid?).returns(false)
post :create, params: { :provisioning_template => {:name => "123"} }, session: set_session_user
assert_template 'new'
end

test "create valid" do
ProvisioningTemplate.any_instance.stubs(:valid?).returns(true)
post :create, params: { :provisioning_template => {:name => "123"} }, session: set_session_user
assert_redirected_to provisioning_templates_url
end

test "edit" do
get :edit, params: { :id => templates(:pxekickstart).to_param }, session: set_session_user
assert_template 'edit'
end

test "edit page contains help information" do
Setting[:safemode_render] = true
get :edit, params: { :id => templates(:pxekickstart).to_param }, session: set_session_user
assert_includes @response.body, Foreman::Renderer::ALLOWED_HELPERS.first.to_s
assert_includes @response.body, Foreman::Renderer::ALLOWED_VARIABLES.first.to_s
assert_includes @response.body, 'foreman_server_fqdn'
end

test "lock" do
@request.env['HTTP_REFERER'] = provisioning_templates_path
get :lock, params: { :id => templates(:pxekickstart).to_param }, session: set_session_user
assert_redirected_to provisioning_templates_path
assert_equal ProvisioningTemplate.unscoped.find(templates(:pxekickstart).id).locked, true
end

test "unlock" do
@request.env['HTTP_REFERER'] = provisioning_templates_path
get :unlock, params: { :id => templates(:locked).to_param }, session: set_session_user
assert_redirected_to provisioning_templates_path
assert_equal ProvisioningTemplate.unscoped.find(templates(:locked).id).locked, false
end

test "clone" do
get :clone_template, params: { :id => templates(:pxekickstart).to_param }, session: set_session_user
assert_template 'new'
end

test "export" do
get :export, params: { :id => templates(:pxekickstart).to_param }, session: set_session_user
assert_response :success
assert_equal 'text/plain', response.content_type
assert_equal templates(:pxekickstart).to_erb, response.body
assert_equal 'attachment; filename="centos5_3_pxelinux.erb"', response.headers['Content-Disposition']
end

test "update invalid" do
ProvisioningTemplate.any_instance.stubs(:valid?).returns(false)
put :update, params: { :id => templates(:pxekickstart).to_param, :provisioning_template => {:name => "123"} }, session: set_session_user
assert_template 'edit'
end

test "update valid" do
ProvisioningTemplate.any_instance.stubs(:valid?).returns(true)
put :update, params: { :id => templates(:pxekickstart).to_param, :provisioning_template => {:name => "123"} }, session: set_session_user
assert_redirected_to provisioning_templates_url
end

test "destroy should fail with assoicated hosts" do
config_template = templates(:pxekickstart)
delete :destroy, params: { :id => config_template.to_param }, session: set_session_user
assert_redirected_to provisioning_templates_url
assert ProvisioningTemplate.unscoped.exists?(config_template.id)
end

test "destroy" do
config_template = templates(:pxekickstart)
config_template.os_default_templates.clear
delete :destroy, params: { :id => config_template.to_param }, session: set_session_user
assert_redirected_to provisioning_templates_url
assert !ProvisioningTemplate.unscoped.exists?(config_template.id)
end

test "audit comment" do
ProvisioningTemplate.auditing_enabled = true
ProvisioningTemplate.any_instance.stubs(:valid?).returns(true)
put :update, params: { :id => templates(:pxekickstart).to_param, :provisioning_template => {:audit_comment => "aha", :template => "tmp" } }, session: set_session_user
assert_redirected_to provisioning_templates_url
assert_equal "aha", templates(:pxekickstart).audits.last.comment
end

test "history in edit" do
setup_users
ProvisioningTemplate.auditing_enabled = true
ProvisioningTemplate.any_instance.stubs(:valid?).returns(true)
template = templates(:pxekickstart)
template.template = template.template.upcase
assert template.save
assert_equal template.audits.count, 1
get :edit, params: { :id => template.to_param }, session: set_session_user

assert @response.body.match('audit-content')
end

context 'PXE menu' do
setup do
TemplateKind::PXE.each do |kind|
["chainload", "discovery"].each do |snippet_type|
snippet = File.read(File.expand_path(File.dirname(__FILE__) + "/../../app/views/unattended/provisioning_templates/snippet/_#{kind.downcase}_#{snippet_type}.erb"))
ProvisioningTemplate.create!(:name => "#{kind.downcase}_#{snippet_type}", :template => snippet, :snippet => true)
end
template = File.read(File.expand_path(File.dirname(__FILE__) + "/../../app/views/unattended/provisioning_templates/#{kind}/#{kind.downcase}_global_default.erb"))
template_kind = TemplateKind.find_by :name => kind
ProvisioningTemplate.find_or_create_by(:name => "#{kind} global default").update(:template => template, :template_kind => template_kind)
end
ProxyAPI::TFTP.any_instance.stubs(:fetch_boot_file).returns(true)
Setting[:unattended_url] = "http://foreman.unattended.url"
@request.env['HTTP_REFERER'] = provisioning_templates_path
end

test "build menu" do
ProxyAPI::TFTP.any_instance.expects(:create_default).with(regexp_matches(/^PXE.*/), has_entry(:menu, regexp_matches(/ks=http:\/\/foreman.unattended.url\/unattended\/template/))).returns(true).times(3)
get :build_pxe_default, session: set_session_user
assert flash[:success].present?
assert flash[:error].empty?
assert_redirected_to provisioning_templates_path
end

test "build menu should return with error code if no TFTP defined" do
SmartProxy.stubs(:with_features).with('TFTP').returns([])
get :build_pxe_default, session: set_session_user
assert flash[:error].present?
end

test "pxe menu's labels should be sorted" do
t1 = TemplateCombination.new :hostgroup => hostgroups(:db), :environment => environments(:production)
t1.provisioning_template = templates(:mystring2)
t2 = TemplateCombination.new :hostgroup => hostgroups(:common), :environment => environments(:production)
t2.provisioning_template = templates(:mystring2)
t1.save
t2.save
ProxyAPI::TFTP.any_instance.expects(:create_default).with(regexp_matches(/^PXE.*/), has_entry(:menu, regexp_matches(/#{hostgroups(:common).name}.*#{hostgroups(:db).name}/m))).returns(true).times(3)
get :build_pxe_default, session: set_session_user
assert_redirected_to provisioning_templates_path
end

test "kickstart url should support in nested hostgroup " do
t1 = TemplateCombination.new :hostgroup => hostgroups(:inherited), :environment => environments(:production)
t1.provisioning_template = templates(:mystring2)
t1.save
ProxyAPI::TFTP.any_instance.expects(:create_default).with(regexp_matches(/^PXE.*/), has_entry(:menu, regexp_matches(/ks=http:\/\/foreman.unattended.url\/unattended\/template\/MyString2\/Parent\/inherited/))).returns(true).times(3)
get :build_pxe_default, session: set_session_user
assert_redirected_to provisioning_templates_path
end

test "pxe menu's labels should be sorted by full hostgroup title" do
first = FactoryBot.build(:hostgroup, :parent => FactoryBot.create(:hostgroup, :name => "parent1"), :name => "def", :operatingsystem => operatingsystems(:centos5_3), :architecture => architectures(:x86_64), :medium => media(:one))
second = FactoryBot.build(:hostgroup, :parent => FactoryBot.create(:hostgroup, :name => "parent2"), :name => "abc", :operatingsystem => operatingsystems(:centos5_3), :architecture => architectures(:x86_64), :medium => media(:one))
FactoryBot.create(:template_combination, :provisioning_template => templates(:mystring2), :hostgroup => second)
FactoryBot.create(:template_combination, :provisioning_template => templates(:mystring2), :hostgroup => first)
ProxyAPI::TFTP.any_instance.expects(:create_default).with(regexp_matches(/^PXE.*/), has_entry(:menu, regexp_matches(/#{first.name}.*#{second.name}/m))).returns(true).times(3)
get :build_pxe_default, session: set_session_user
assert_redirected_to provisioning_templates_path
end
end

test 'preview' do
host = FactoryBot.create(:host, :managed, :operatingsystem => FactoryBot.create(:suse, :with_archs, :with_media))
template = FactoryBot.create(:provisioning_template)

# works for given host
post :preview, params: { :preview_host_id => host.id, :template => '<%= @host.name -%>', :id => template }, session: set_session_user
assert_equal host.hostname.to_s, @response.body

# without host specified it uses first one
post :preview, params: { :template => '<%= 1+1 -%>', :id => template }, session: set_session_user
assert_equal '2', @response.body

post :preview, params: { :template => '<%= 1+1 -%>' }, session: set_session_user
assert_equal '2', @response.body

post :preview, params: { :template => '<%= 1+ -%>', :id => template }, session: set_session_user
assert_includes @response.body, 'parse error on value'
end

context 'templates combinations' do
test 'can be added on template creation' do
template_combination = { :environment_id => environments(:production).id,
:hostgroup_id => hostgroups(:db).id }
provisioning_template = {
:name => 'foo',
:template => '#nocontent',
:template_kind_id => TemplateKind.find_by_name('iPXE').id,
:template_combinations_attributes => { '3923' => template_combination }
}
assert_difference('TemplateCombination.unscoped.count', 1) do
assert_difference('ProvisioningTemplate.unscoped.count', 1) do
post :create, params: {
:provisioning_template => provisioning_template
}, session: set_session_user
end
end
end

context 'for already existing templates' do
setup do
@template_combination = FactoryBot.create(:template_combination)
end

test 'can be edited' do
template = @template_combination.provisioning_template
new_environment = FactoryBot.create(:environment)
assert_not_equal new_environment, @template_combination.environment
put :update, params: {
:id => template.to_param,
:provisioning_template => {
:template_combinations_attributes => {
'0' => {
:id => @template_combination.id,
:environment_id => new_environment.id,
:hostgroup_id => @template_combination.hostgroup.id
}
}
}
}, session: set_session_user
assert_response :found
as_admin do
@template_combination.reload
assert_equal new_environment, @template_combination.environment
end
end

test 'can be destroyed' do
assert_difference('TemplateCombination.count', -1) do
put :update, params: {
:id => @template_combination.provisioning_template.to_param,
:provisioning_template => {
:template_combinations_attributes => {
'0' => {
:id => @template_combination.id,
:_destroy => 1
}
}
}
}, session: set_session_user
end
assert_response :found
end
end
end
end
(35-35/53)