vmpooler 0.18.0 → 1.1.0

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.
@@ -79,7 +79,7 @@ module Vmpooler
79
79
  return current_vm['vm_host'] if rand(1..100) > provider_config['migratevm_couldmove_percent']
80
80
 
81
81
  # Simulate a 10 node cluster and randomly pick a different one
82
- new_host = 'HOST' + rand(1..10).to_s while new_host == current_vm['vm_host']
82
+ new_host = "HOST#{rand(1..10)}" while new_host == current_vm['vm_host']
83
83
 
84
84
  new_host
85
85
  end
@@ -95,9 +95,7 @@ module Vmpooler
95
95
  end
96
96
 
97
97
  # Inject clone failure
98
- unless provider_config['migratevm_fail_percent'].nil?
99
- raise('Dummy Failure for migratevm_fail_percent') if rand(1..100) <= provider_config['migratevm_fail_percent']
100
- end
98
+ raise('Dummy Failure for migratevm_fail_percent') if !provider_config['migratevm_fail_percent'].nil? && rand(1..100) <= provider_config['migratevm_fail_percent']
101
99
 
102
100
  @write_lock.synchronize do
103
101
  current_vm = get_dummy_vm(pool_name, vm_name)
@@ -116,27 +114,23 @@ module Vmpooler
116
114
  return nil if dummy.nil?
117
115
 
118
116
  # Randomly power off the VM
119
- unless dummy['powerstate'] != 'PoweredOn' || provider_config['getvm_poweroff_percent'].nil?
120
- if rand(1..100) <= provider_config['getvm_poweroff_percent']
121
- @write_lock.synchronize do
122
- dummy = get_dummy_vm(pool_name, vm_name)
123
- dummy['powerstate'] = 'PoweredOff'
124
- write_backing_file
125
- end
126
- logger.log('d', "[ ] [#{dummy['poolname']}] '#{dummy['name']}' is being Dummy Powered Off")
117
+ if !(dummy['powerstate'] != 'PoweredOn' || provider_config['getvm_poweroff_percent'].nil?) && rand(1..100) <= provider_config['getvm_poweroff_percent']
118
+ @write_lock.synchronize do
119
+ dummy = get_dummy_vm(pool_name, vm_name)
120
+ dummy['powerstate'] = 'PoweredOff'
121
+ write_backing_file
127
122
  end
123
+ logger.log('d', "[ ] [#{dummy['poolname']}] '#{dummy['name']}' is being Dummy Powered Off")
128
124
  end
129
125
 
130
126
  # Randomly rename the host
131
- unless dummy['hostname'] != dummy['name'] || provider_config['getvm_rename_percent'].nil?
132
- if rand(1..100) <= provider_config['getvm_rename_percent']
133
- @write_lock.synchronize do
134
- dummy = get_dummy_vm(pool_name, vm_name)
135
- dummy['hostname'] = 'DUMMY' + dummy['name']
136
- write_backing_file
137
- end
138
- logger.log('d', "[ ] [#{dummy['poolname']}] '#{dummy['name']}' is being Dummy renamed")
127
+ if !(dummy['hostname'] != dummy['name'] || provider_config['getvm_rename_percent'].nil?) && rand(1..100) <= provider_config['getvm_rename_percent']
128
+ @write_lock.synchronize do
129
+ dummy = get_dummy_vm(pool_name, vm_name)
130
+ dummy['hostname'] = "DUMMY#{dummy['name']}"
131
+ write_backing_file
139
132
  end
133
+ logger.log('d', "[ ] [#{dummy['poolname']}] '#{dummy['name']}' is being Dummy renamed")
140
134
  end
141
135
 
142
136
  obj['name'] = dummy['name']
@@ -196,9 +190,7 @@ module Vmpooler
196
190
 
197
191
  begin
198
192
  # Inject clone failure
199
- unless provider_config['createvm_fail_percent'].nil?
200
- raise('Dummy Failure for createvm_fail_percent') if rand(1..100) <= provider_config['createvm_fail_percent']
201
- end
193
+ raise('Dummy Failure for createvm_fail_percent') if !provider_config['createvm_fail_percent'].nil? && rand(1..100) <= provider_config['createvm_fail_percent']
202
194
 
203
195
  # Assert the VM is ready for use
204
196
  @write_lock.synchronize do
@@ -229,9 +221,7 @@ module Vmpooler
229
221
  end
230
222
 
231
223
  # Inject create failure
232
- unless provider_config['createdisk_fail_percent'].nil?
233
- raise('Dummy Failure for createdisk_fail_percent') if rand(1..100) <= provider_config['createdisk_fail_percent']
234
- end
224
+ raise('Dummy Failure for createdisk_fail_percent') if !provider_config['createdisk_fail_percent'].nil? && rand(1..100) <= provider_config['createdisk_fail_percent']
235
225
 
236
226
  @write_lock.synchronize do
237
227
  vm_object = get_dummy_vm(pool_name, vm_name)
@@ -255,9 +245,7 @@ module Vmpooler
255
245
  end
256
246
 
257
247
  # Inject create failure
258
- unless provider_config['createsnapshot_fail_percent'].nil?
259
- raise('Dummy Failure for createsnapshot_fail_percent') if rand(1..100) <= provider_config['createsnapshot_fail_percent']
260
- end
248
+ raise('Dummy Failure for createsnapshot_fail_percent') if !provider_config['createsnapshot_fail_percent'].nil? && rand(1..100) <= provider_config['createsnapshot_fail_percent']
261
249
 
262
250
  @write_lock.synchronize do
263
251
  vm_object = get_dummy_vm(pool_name, vm_name)
@@ -282,9 +270,7 @@ module Vmpooler
282
270
  end
283
271
 
284
272
  # Inject create failure
285
- unless provider_config['revertsnapshot_fail_percent'].nil?
286
- raise('Dummy Failure for revertsnapshot_fail_percent') if rand(1..100) <= provider_config['revertsnapshot_fail_percent']
287
- end
273
+ raise('Dummy Failure for revertsnapshot_fail_percent') if !provider_config['revertsnapshot_fail_percent'].nil? && rand(1..100) <= provider_config['revertsnapshot_fail_percent']
288
274
  end
289
275
 
290
276
  vm_object['snapshots'].include?(snapshot_name)
@@ -320,9 +306,7 @@ module Vmpooler
320
306
  end
321
307
 
322
308
  # Inject destroy VM failure
323
- unless provider_config['destroyvm_fail_percent'].nil?
324
- raise('Dummy Failure for migratevm_fail_percent') if rand(1..100) <= provider_config['destroyvm_fail_percent']
325
- end
309
+ raise('Dummy Failure for migratevm_fail_percent') if !provider_config['destroyvm_fail_percent'].nil? && rand(1..100) <= provider_config['destroyvm_fail_percent']
326
310
 
327
311
  # 'Destroy' the VM
328
312
  @write_lock.synchronize do
@@ -354,9 +338,7 @@ module Vmpooler
354
338
  # it's ready to receive a connection
355
339
  sleep(2)
356
340
 
357
- unless provider_config['vmready_fail_percent'].nil?
358
- raise('Dummy Failure for vmready_fail_percent') if rand(1..100) <= provider_config['vmready_fail_percent']
359
- end
341
+ raise('Dummy Failure for vmready_fail_percent') if !provider_config['vmready_fail_percent'].nil? && rand(1..100) <= provider_config['vmready_fail_percent']
360
342
 
361
343
  @write_lock.synchronize do
362
344
  vm_object['ready'] = true
@@ -1,6 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  require 'vmpooler/providers/base'
4
+ require 'bigdecimal'
5
+ require 'bigdecimal/util'
4
6
 
5
7
  module Vmpooler
6
8
  class PoolManager
@@ -49,9 +51,7 @@ module Vmpooler
49
51
  end
50
52
 
51
53
  def folder_configured?(folder_title, base_folder, configured_folders, whitelist)
52
- if whitelist
53
- return true if whitelist.include?(folder_title)
54
- end
54
+ return true if whitelist&.include?(folder_title)
55
55
  return false unless configured_folders.keys.include?(folder_title)
56
56
  return false unless configured_folders[folder_title] == base_folder
57
57
 
@@ -68,7 +68,7 @@ module Vmpooler
68
68
  redis.hset("vmpooler__vm__#{vm_name}", 'destroy', Time.now)
69
69
 
70
70
  # Auto-expire metadata key
71
- redis.expire('vmpooler__vm__' + vm_name, (data_ttl * 60 * 60))
71
+ redis.expire("vmpooler__vm__#{vm_name}", (data_ttl * 60 * 60))
72
72
  redis.exec
73
73
  end
74
74
 
@@ -203,9 +203,7 @@ module Vmpooler
203
203
  return
204
204
  end
205
205
  wait_for_host_selection(dc, target, loop_delay, max_age) if target[dc].key?('checking')
206
- if target[dc].key?('check_time_finished')
207
- select_target_hosts(target, cluster, datacenter) if now - target[dc]['check_time_finished'] > max_age
208
- end
206
+ select_target_hosts(target, cluster, datacenter) if target[dc].key?('check_time_finished') && now - target[dc]['check_time_finished'] > max_age
209
207
  end
210
208
 
211
209
  def wait_for_host_selection(dc, target, maxloop = 0, loop_delay = 1, max_age = 60)
@@ -418,15 +416,15 @@ module Vmpooler
418
416
  # Determine network device type
419
417
  # All possible device type options here: https://vdc-download.vmware.com/vmwb-repository/dcr-public/98d63b35-d822-47fe-a87a-ddefd469df06/2e3c7b58-f2bd-486e-8bb1-a75eb0640bee/doc/vim.vm.device.VirtualEthernetCard.html
420
418
  network_device =
421
- if template_vm_network_device.is_a? RbVmomi::VIM::VirtualVmxnet2
419
+ if template_vm_network_device.instance_of? RbVmomi::VIM::VirtualVmxnet2
422
420
  RbVmomi::VIM.VirtualVmxnet2
423
- elsif template_vm_network_device.is_a? RbVmomi::VIM::VirtualVmxnet3
421
+ elsif template_vm_network_device.instance_of? RbVmomi::VIM::VirtualVmxnet3
424
422
  RbVmomi::VIM.VirtualVmxnet3
425
- elsif template_vm_network_device.is_a? RbVmomi::VIM::VirtualE1000
423
+ elsif template_vm_network_device.instance_of? RbVmomi::VIM::VirtualE1000
426
424
  RbVmomi::VIM.VirtualE1000
427
- elsif template_vm_network_device.is_a? RbVmomi::VIM::VirtualE1000e
425
+ elsif template_vm_network_device.instance_of? RbVmomi::VIM::VirtualE1000e
428
426
  RbVmomi::VIM.VirtualE1000e
429
- elsif template_vm_network_device.is_a? RbVmomi::VIM::VirtualSriovEthernetCard
427
+ elsif template_vm_network_device.instance_of? RbVmomi::VIM::VirtualSriovEthernetCard
430
428
  RbVmomi::VIM.VirtualSriovEthernetCard
431
429
  else
432
430
  RbVmomi::VIM.VirtualPCNet32
@@ -560,7 +558,7 @@ module Vmpooler
560
558
  boottime = vm_object.runtime.bootTime if vm_object.runtime&.bootTime
561
559
  powerstate = vm_object.runtime.powerState if vm_object.runtime&.powerState
562
560
 
563
- hash = {
561
+ {
564
562
  'name' => vm_object.name,
565
563
  'hostname' => hostname,
566
564
  'template' => pool_configuration['template'],
@@ -568,8 +566,6 @@ module Vmpooler
568
566
  'boottime' => boottime,
569
567
  'powerstate' => powerstate
570
568
  }
571
-
572
- hash
573
569
  end
574
570
 
575
571
  # vSphere helper methods
@@ -794,7 +790,7 @@ module Vmpooler
794
790
  }
795
791
 
796
792
  folder_object = connection.searchIndex.FindByInventoryPath(propSpecs) # rubocop:disable Naming/VariableName
797
- return nil unless folder_object.class == RbVmomi::VIM::Folder
793
+ return nil unless folder_object.instance_of? RbVmomi::VIM::Folder
798
794
 
799
795
  folder_object
800
796
  end
@@ -810,9 +806,7 @@ module Vmpooler
810
806
  # the cpu or memory utilization is bigger than the limit param
811
807
  def get_host_utilization(host, model = nil, limit = 90)
812
808
  limit = @config[:config]['utilization_limit'] if @config[:config].key?('utilization_limit')
813
- if model
814
- return nil unless host_has_cpu_model?(host, model)
815
- end
809
+ return nil if model && !host_has_cpu_model?(host, model)
816
810
  return nil if host.runtime.inMaintenanceMode
817
811
  return nil unless host.overallStatus == 'green'
818
812
  return nil unless host.configIssue.empty?
@@ -821,9 +815,9 @@ module Vmpooler
821
815
  memory_utilization = memory_utilization_for host
822
816
 
823
817
  return nil if cpu_utilization.nil?
824
- return nil if cpu_utilization == 0.0
818
+ return nil if cpu_utilization.to_d == 0.0.to_d
825
819
  return nil if memory_utilization.nil?
826
- return nil if memory_utilization == 0.0
820
+ return nil if memory_utilization.to_d == 0.0.to_d
827
821
 
828
822
  return nil if cpu_utilization > limit
829
823
  return nil if memory_utilization > limit
@@ -838,8 +832,7 @@ module Vmpooler
838
832
  def get_host_cpu_arch_version(host)
839
833
  cpu_model = host.hardware.cpuPkg[0].description
840
834
  cpu_model_parts = cpu_model.split
841
- arch_version = cpu_model_parts[4]
842
- arch_version
835
+ cpu_model_parts[4]
843
836
  end
844
837
 
845
838
  def cpu_utilization_for(host)
@@ -931,8 +924,7 @@ module Vmpooler
931
924
  target_hosts = get_cluster_host_utilization(cluster_object)
932
925
  raise("There is no host candidate in vcenter that meets all the required conditions, check that the cluster has available hosts in a 'green' status, not in maintenance mode and not overloaded CPU and memory'") if target_hosts.empty?
933
926
 
934
- least_used_host = target_hosts.min[1]
935
- least_used_host
927
+ target_hosts.min[1]
936
928
  end
937
929
 
938
930
  def find_cluster(cluster, connection, datacentername)
@@ -979,11 +971,10 @@ module Vmpooler
979
971
  end
980
972
 
981
973
  def build_propSpecs(datacenter, folder, vmname) # rubocop:disable Naming/MethodName
982
- propSpecs = { # rubocop:disable Naming/VariableName
974
+ {
983
975
  entity => self,
984
976
  :inventoryPath => "#{datacenter}/vm/#{folder}/#{vmname}"
985
977
  }
986
- propSpecs # rubocop:disable Naming/VariableName
987
978
  end
988
979
 
989
980
  def find_vm(pool_name, vmname, connection)
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Vmpooler
4
- VERSION = '0.18.0'
4
+ VERSION = '1.1.0'
5
5
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: vmpooler
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.18.0
4
+ version: 1.1.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Puppet
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2020-10-26 00:00:00.000000000 Z
11
+ date: 2021-08-18 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: concurrent-ruby
@@ -66,104 +66,90 @@ dependencies:
66
66
  - - "~>"
67
67
  - !ruby/object:Gem::Version
68
68
  version: '1.10'
69
- - !ruby/object:Gem::Dependency
70
- name: opentelemetry-api
71
- requirement: !ruby/object:Gem::Requirement
72
- requirements:
73
- - - "~>"
74
- - !ruby/object:Gem::Version
75
- version: 0.7.0
76
- type: :runtime
77
- prerelease: false
78
- version_requirements: !ruby/object:Gem::Requirement
79
- requirements:
80
- - - "~>"
81
- - !ruby/object:Gem::Version
82
- version: 0.7.0
83
69
  - !ruby/object:Gem::Dependency
84
70
  name: opentelemetry-exporter-jaeger
85
71
  requirement: !ruby/object:Gem::Requirement
86
72
  requirements:
87
- - - "~>"
73
+ - - '='
88
74
  - !ruby/object:Gem::Version
89
- version: 0.7.0
75
+ version: 0.15.0
90
76
  type: :runtime
91
77
  prerelease: false
92
78
  version_requirements: !ruby/object:Gem::Requirement
93
79
  requirements:
94
- - - "~>"
80
+ - - '='
95
81
  - !ruby/object:Gem::Version
96
- version: 0.7.0
82
+ version: 0.15.0
97
83
  - !ruby/object:Gem::Dependency
98
84
  name: opentelemetry-instrumentation-concurrent_ruby
99
85
  requirement: !ruby/object:Gem::Requirement
100
86
  requirements:
101
- - - "~>"
87
+ - - '='
102
88
  - !ruby/object:Gem::Version
103
- version: 0.7.0
89
+ version: 0.15.0
104
90
  type: :runtime
105
91
  prerelease: false
106
92
  version_requirements: !ruby/object:Gem::Requirement
107
93
  requirements:
108
- - - "~>"
94
+ - - '='
109
95
  - !ruby/object:Gem::Version
110
- version: 0.7.0
96
+ version: 0.15.0
111
97
  - !ruby/object:Gem::Dependency
112
98
  name: opentelemetry-instrumentation-redis
113
99
  requirement: !ruby/object:Gem::Requirement
114
100
  requirements:
115
- - - "~>"
101
+ - - '='
116
102
  - !ruby/object:Gem::Version
117
- version: 0.7.0
103
+ version: 0.15.0
118
104
  type: :runtime
119
105
  prerelease: false
120
106
  version_requirements: !ruby/object:Gem::Requirement
121
107
  requirements:
122
- - - "~>"
108
+ - - '='
123
109
  - !ruby/object:Gem::Version
124
- version: 0.7.0
110
+ version: 0.15.0
125
111
  - !ruby/object:Gem::Dependency
126
112
  name: opentelemetry-instrumentation-sinatra
127
113
  requirement: !ruby/object:Gem::Requirement
128
114
  requirements:
129
- - - "~>"
115
+ - - '='
130
116
  - !ruby/object:Gem::Version
131
- version: 0.7.1
117
+ version: 0.15.0
132
118
  type: :runtime
133
119
  prerelease: false
134
120
  version_requirements: !ruby/object:Gem::Requirement
135
121
  requirements:
136
- - - "~>"
122
+ - - '='
137
123
  - !ruby/object:Gem::Version
138
- version: 0.7.1
124
+ version: 0.15.0
139
125
  - !ruby/object:Gem::Dependency
140
126
  name: opentelemetry-resource_detectors
141
127
  requirement: !ruby/object:Gem::Requirement
142
128
  requirements:
143
- - - "~>"
129
+ - - '='
144
130
  - !ruby/object:Gem::Version
145
- version: 0.7.0
131
+ version: 0.15.0
146
132
  type: :runtime
147
133
  prerelease: false
148
134
  version_requirements: !ruby/object:Gem::Requirement
149
135
  requirements:
150
- - - "~>"
136
+ - - '='
151
137
  - !ruby/object:Gem::Version
152
- version: 0.7.0
138
+ version: 0.15.0
153
139
  - !ruby/object:Gem::Dependency
154
140
  name: opentelemetry-sdk
155
141
  requirement: !ruby/object:Gem::Requirement
156
142
  requirements:
157
- - - "~>"
143
+ - - '='
158
144
  - !ruby/object:Gem::Version
159
- version: 0.7.0
145
+ version: 0.15.0
160
146
  type: :runtime
161
147
  prerelease: false
162
148
  version_requirements: !ruby/object:Gem::Requirement
163
149
  requirements:
164
- - - "~>"
150
+ - - '='
165
151
  - !ruby/object:Gem::Version
166
- version: 0.7.0
152
+ version: 0.15.0
167
153
  - !ruby/object:Gem::Dependency
168
154
  name: pickup
169
155
  requirement: !ruby/object:Gem::Requirement
@@ -198,14 +184,20 @@ dependencies:
198
184
  requirements:
199
185
  - - "~>"
200
186
  - !ruby/object:Gem::Version
201
- version: '4.3'
187
+ version: '5.0'
188
+ - - ">="
189
+ - !ruby/object:Gem::Version
190
+ version: 5.0.4
202
191
  type: :runtime
203
192
  prerelease: false
204
193
  version_requirements: !ruby/object:Gem::Requirement
205
194
  requirements:
206
195
  - - "~>"
207
196
  - !ruby/object:Gem::Version
208
- version: '4.3'
197
+ version: '5.0'
198
+ - - ">="
199
+ - !ruby/object:Gem::Version
200
+ version: 5.0.4
209
201
  - !ruby/object:Gem::Dependency
210
202
  name: rack
211
203
  requirement: !ruby/object:Gem::Requirement
@@ -384,16 +376,16 @@ dependencies:
384
376
  name: rubocop
385
377
  requirement: !ruby/object:Gem::Requirement
386
378
  requirements:
387
- - - "<"
379
+ - - "~>"
388
380
  - !ruby/object:Gem::Version
389
- version: '1.0'
381
+ version: 1.1.0
390
382
  type: :development
391
383
  prerelease: false
392
384
  version_requirements: !ruby/object:Gem::Requirement
393
385
  requirements:
394
- - - "<"
386
+ - - "~>"
395
387
  - !ruby/object:Gem::Version
396
- version: '1.0'
388
+ version: 1.1.0
397
389
  - !ruby/object:Gem::Dependency
398
390
  name: simplecov
399
391
  requirement: !ruby/object:Gem::Requirement