chef-provisioning-vsphere 0.5.1 → 0.5.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 9429c5a2889eb0b8c3a74c2aa968e6134d6933df
|
4
|
+
data.tar.gz: e48b0fe64f042425825347c5408fbf33bcdd7fea
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 7daa42c1d264122430a212d5b2433f8ebc2e67b2e043853af254d8f9d3d6489d14d3ecb9d5b0303ce99bb6c260c2d29168e9ebd06661f7ec474f9e5b992d576b
|
7
|
+
data.tar.gz: bfffe594fc7914b88753a64f2bf527d6877fbe2e7ea92c100c91368c05523f80c5f69e8013a7a20b7e85920cb7549c678229ead358dab5185b8255b2a79cef77
|
@@ -110,6 +110,8 @@ module ChefProvisioningVsphere
|
|
110
110
|
# -- vm_folder: name of the vSphere folder containing the VM
|
111
111
|
#
|
112
112
|
def allocate_machine(action_handler, machine_spec, machine_options)
|
113
|
+
merge_options! machine_options
|
114
|
+
|
113
115
|
if machine_spec.location
|
114
116
|
Chef::Log.warn(
|
115
117
|
"Checking to see if #{machine_spec.location} has been created...")
|
@@ -142,6 +144,13 @@ module ChefProvisioningVsphere
|
|
142
144
|
vm
|
143
145
|
end
|
144
146
|
|
147
|
+
def merge_options!(machine_options)
|
148
|
+
@config = Cheffish::MergedConfig.new(
|
149
|
+
{ machine_options: machine_options },
|
150
|
+
@config
|
151
|
+
)
|
152
|
+
end
|
153
|
+
|
145
154
|
def add_machine_spec_location(vm, machine_spec)
|
146
155
|
machine_spec.location = {
|
147
156
|
'driver_url' => driver_url,
|
@@ -188,6 +197,8 @@ module ChefProvisioningVsphere
|
|
188
197
|
end
|
189
198
|
|
190
199
|
def ready_machine(action_handler, machine_spec, machine_options)
|
200
|
+
merge_options! machine_options
|
201
|
+
|
191
202
|
vm = start_machine(action_handler, machine_spec, machine_options)
|
192
203
|
if vm.nil?
|
193
204
|
raise "Machine #{machine_spec.name} does not have a server "\
|
@@ -350,10 +361,12 @@ module ChefProvisioningVsphere
|
|
350
361
|
|
351
362
|
# Connect to machine without acquiring it
|
352
363
|
def connect_to_machine(machine_spec, machine_options)
|
364
|
+
merge_options! machine_options
|
353
365
|
machine_for(machine_spec, machine_options)
|
354
366
|
end
|
355
367
|
|
356
368
|
def destroy_machine(action_handler, machine_spec, machine_options)
|
369
|
+
merge_options! machine_options
|
357
370
|
vm = vm_for(machine_spec)
|
358
371
|
if vm
|
359
372
|
action_handler.perform_action "Delete VM [#{vm.parent.name}/#{vm.name}]" do
|
@@ -372,6 +385,7 @@ module ChefProvisioningVsphere
|
|
372
385
|
end
|
373
386
|
|
374
387
|
def stop_machine(action_handler, machine_spec, machine_options)
|
388
|
+
merge_options! machine_options
|
375
389
|
vm = vm_for(machine_spec)
|
376
390
|
if vm
|
377
391
|
action_handler.perform_action "Shutdown guest OS and power off VM [#{vm.parent.name}/#{vm.name}]" do
|
@@ -381,6 +395,7 @@ module ChefProvisioningVsphere
|
|
381
395
|
end
|
382
396
|
|
383
397
|
def start_machine(action_handler, machine_spec, machine_options)
|
398
|
+
merge_options! machine_options
|
384
399
|
vm = vm_for(machine_spec)
|
385
400
|
if vm
|
386
401
|
action_handler.perform_action "Power on VM [#{vm.parent.name}/#{vm.name}]" do
|
@@ -519,15 +534,21 @@ module ChefProvisioningVsphere
|
|
519
534
|
require 'chef/provisioning/convergence_strategy/install_msi'
|
520
535
|
require 'chef/provisioning/convergence_strategy/install_cached'
|
521
536
|
require 'chef/provisioning/convergence_strategy/no_converge'
|
522
|
-
|
537
|
+
|
538
|
+
mopts = machine_options[:convergence_options].to_hash.dup
|
539
|
+
mopts[:chef_server] = mopts[:chef_server].to_hash.dup if mopts[:chef_server]
|
540
|
+
|
523
541
|
if !machine_spec.location
|
524
|
-
return Chef::Provisioning::ConvergenceStrategy::NoConverge.new(
|
542
|
+
return Chef::Provisioning::ConvergenceStrategy::NoConverge.new(
|
543
|
+
mopts, config)
|
525
544
|
end
|
526
545
|
|
527
546
|
if machine_spec.location['is_windows']
|
528
|
-
Chef::Provisioning::ConvergenceStrategy::InstallMsi.new(
|
547
|
+
Chef::Provisioning::ConvergenceStrategy::InstallMsi.new(
|
548
|
+
mopts, config)
|
529
549
|
else
|
530
|
-
Chef::Provisioning::ConvergenceStrategy::InstallCached.new(
|
550
|
+
Chef::Provisioning::ConvergenceStrategy::InstallCached.new(
|
551
|
+
mopts, config)
|
531
552
|
end
|
532
553
|
end
|
533
554
|
|
@@ -74,12 +74,12 @@ module Kitchen
|
|
74
74
|
chef_server = Cheffish.default_chef_server
|
75
75
|
config[:machine_options][:convergence_options] = {:chef_server => chef_server}
|
76
76
|
machine_spec = Chef::Provisioning.chef_managed_entry_store(chef_server).new_entry(:machine, name)
|
77
|
-
|
77
|
+
url = URI::VsphereUrl.from_config(@config[:driver_options]).to_s
|
78
|
+
driver = Chef::Provisioning.driver_for_url(url, config)
|
78
79
|
action_handler = Chef::Provisioning::ActionHandler.new
|
79
80
|
block.call(action_handler, driver, machine_spec)
|
80
81
|
end
|
81
82
|
end
|
82
|
-
|
83
83
|
end
|
84
84
|
end
|
85
85
|
end
|