Skip to content

Commit

Permalink
Merge pull request #308 from pkomanek/broken_customization_during_vm_…
Browse files Browse the repository at this point in the history
…provisioning_fix

Customization fix
  • Loading branch information
agrare committed Aug 3, 2018
2 parents 69250d7 + 00adb1e commit ae5a82f
Show file tree
Hide file tree
Showing 2 changed files with 121 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ def build_customization_spec
spec = load_customization_spec(custom_spec_name)
spec = spec.spec unless spec.nil?
_log.info "Loaded custom spec [#{custom_spec_name}]. Override flag: [#{sysprep_spec_override}]"
if sysprep_spec_override == false
if spec && sysprep_spec_override == false
adjust_nicSettingMap(spec)
return spec
end
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,120 @@
describe ManageIQ::Providers::Vmware::InfraManager::Provision::Customization do
let(:custom_spec_name) { 'custom_spec_name' }
let(:target_vm_name) { 'computerName' }
let(:os) { FactoryGirl.create(:operating_system, :product_name => 'Microsoft Windows') }
let(:ems) { FactoryGirl.create(:ems_vmware_with_authentication, :api_version => '6.0', :customization_specs => [custom_spec]) }
let(:custom_spec) { FactoryGirl.create(:customization_spec, :name => custom_spec_name, :spec => spec) }
let(:prov_request) { FactoryGirl.create(:miq_provision_request, :src_vm_id => vm_template.id) }
let(:options) do
{
:pass => 1,
:vm_name => target_vm_name,
:number_of_vms => 1,
:cpu_limit => -1,
:cpu_reserve => 0,
:src_vm_id => [vm_template.id, vm_template.name],
:sysprep_enabled => 'enabled',
:sysprep_custom_spec => custom_spec_name,
:sysprep_spec_override => false,
:sysprep_server_license_mode => 'perServer',
:vm_target_hostname => target_vm_name
}
end
let(:prov_vm) do
FactoryGirl.create(
:miq_provision_vmware,
:miq_request => prov_request,
:source => @vm_template,
:request_type => 'template',
:state => 'pending',
:status => 'Ok',
:options => options
)
end
let(:vm_template) do
FactoryGirl.create(
:template_vmware,
:ext_management_system => ems,
:operating_system => os,
:cpu_limit => -1,
:cpu_reserve => 0
)
end
let(:spec) do
vh = VimHash.new('CustomizationSpec')
vh['options'] = VimHash.new('options') do |opt|
opt.changeSID = 'true'
opt.deleteAccounts = 'false'
end
vh['identity'] = VimHash.new('identity') do |i|
i.guiUnattended = VimHash.new('guiUnattended') do |gu|
gu.password = { 'value' => '123456', 'plainText' => 'true' }
gu.timeZone = '35'
gu.autoLogon = 'true'
gu.autoLogonCount = 1
end
i.userData = VimHash.new('userData') do |ud|
ud.fullName = 'MIQ'
ud.orgName = 'Red Hat'
ud.computerName = { 'name' => target_vm_name }
ud.productId = ''
end
i.identification = VimHash.new('identification') do |idt|
idt.joinWorkgroup = 'WORKGROUP'
end
i.licenseFilePrintData = VimHash.new('licenseFilePrintData') do |lfp|
lfp.autoMode = 'perServer'
lfp.autoUsers = '5'
end
end
vh['globalIPSettings'] = {}
vh['nicSettingMap'] = []
vh
end
let(:new_spec) do
{
"identity" => {
"guiUnattended" => { "autoLogonCount" => 1 },
"identification" => {},
"licenseFilePrintData" => { "autoMode" => "perServer" },
"userData" => {
"fullName" => "sysprep_full_name_value",
"orgName" => "sysprep_organization_value",
"computerName" => { "name" => "computerName" }
}
},
"globalIPSettings" => {},
"nicSettingMap" => [],
"options" => {}
}
end

it 'skips building spec' do
options[:sysprep_enabled] = 'disabled'
expect(prov_vm.build_customization_spec).to(be_nil)
end

context 'build_customization_spec for windows template' do
it 'loads existing spec' do
expect(prov_vm.build_customization_spec).to(eq(spec))
end

it 'loads existing spec and override it' do
spec_for_compare = spec
options[:sysprep_spec_override] = true
options[:sysprep_organization] = 'sysprep_organization_value'
spec_for_compare.identity.userData.orgName = options[:sysprep_organization]
options[:sysprep_full_name] = 'sysprep_full_name_value'
spec_for_compare.identity.userData.fullName = options[:sysprep_full_name]
spec_for_compare.identity.identification = {}
expect(prov_vm.build_customization_spec).to(eq(spec_for_compare))
end

it 'creates a new spec' do
custom_spec.spec = nil
options[:sysprep_full_name] = 'sysprep_full_name_value'
options[:sysprep_organization] = 'sysprep_organization_value'
expect(prov_vm.build_customization_spec).to(eq(new_spec))
end
end
end

0 comments on commit ae5a82f

Please sign in to comment.