vmpooler 0.16.2 → 0.18.2

Sign up to get free protection for your applications and to get access to all the features.
@@ -5,9 +5,6 @@ module Vmpooler
5
5
  class DummyStatsd < Metrics
6
6
  attr_reader :server, :port, :prefix
7
7
 
8
- def initialize(*)
9
- end
10
-
11
8
  def increment(*)
12
9
  true
13
10
  end
@@ -7,6 +7,7 @@ module Vmpooler
7
7
  class Graphite < Metrics
8
8
  attr_reader :server, :port, :prefix
9
9
 
10
+ # rubocop:disable Lint/MissingSuper
10
11
  def initialize(logger, params = {})
11
12
  raise ArgumentError, "Graphite server is required. Config: #{params.inspect}" if params['server'].nil? || params['server'].empty?
12
13
 
@@ -15,6 +16,7 @@ module Vmpooler
15
16
  @prefix = params['prefix'] || 'vmpooler'
16
17
  @logger = logger
17
18
  end
19
+ # rubocop:enable Lint/MissingSuper
18
20
 
19
21
  def increment(label)
20
22
  log label, 1
@@ -23,6 +23,7 @@ module Vmpooler
23
23
  @p_metrics = {}
24
24
  @torun = []
25
25
 
26
+ # rubocop:disable Lint/MissingSuper
26
27
  def initialize(logger, params = {})
27
28
  @prefix = params['prefix'] || 'vmpooler'
28
29
  @prometheus_prefix = params['prometheus_prefix'] || 'vmpooler'
@@ -32,6 +33,7 @@ module Vmpooler
32
33
  # Setup up prometheus registry and data structures
33
34
  @prometheus = Prometheus::Client.registry
34
35
  end
36
+ # rubocop:enable Lint/MissingSuper
35
37
 
36
38
  =begin # rubocop:disable Style/BlockComments
37
39
  The Metrics table is used to register metrics and translate/interpret the incoming metrics.
@@ -8,6 +8,7 @@ module Vmpooler
8
8
  class Statsd < Metrics
9
9
  attr_reader :server, :port, :prefix
10
10
 
11
+ # rubocop:disable Lint/MissingSuper
11
12
  def initialize(logger, params = {})
12
13
  raise ArgumentError, "Statsd server is required. Config: #{params.inspect}" if params['server'].nil? || params['server'].empty?
13
14
 
@@ -17,21 +18,22 @@ module Vmpooler
17
18
  @server = ::Statsd.new(host, @port)
18
19
  @logger = logger
19
20
  end
21
+ # rubocop:enable Lint/MissingSuper
20
22
 
21
23
  def increment(label)
22
- server.increment(prefix + '.' + label)
24
+ server.increment("#{prefix}.#{label}")
23
25
  rescue StandardError => e
24
26
  @logger.log('s', "[!] Failure incrementing #{prefix}.#{label} on statsd server [#{server}:#{port}]: #{e}")
25
27
  end
26
28
 
27
29
  def gauge(label, value)
28
- server.gauge(prefix + '.' + label, value)
30
+ server.gauge("#{prefix}.#{label}", value)
29
31
  rescue StandardError => e
30
32
  @logger.log('s', "[!] Failure updating gauge #{prefix}.#{label} on statsd server [#{server}:#{port}]: #{e}")
31
33
  end
32
34
 
33
35
  def timing(label, duration)
34
- server.timing(prefix + '.' + label, duration)
36
+ server.timing("#{prefix}.#{label}", duration)
35
37
  rescue StandardError => e
36
38
  @logger.log('s', "[!] Failure updating timing #{prefix}.#{label} on statsd server [#{server}:#{port}]: #{e}")
37
39
  end
@@ -108,7 +108,7 @@ module Vmpooler
108
108
  $logger.log('d', "[!] [#{pool}] '#{vm}' no longer exists. Removing from pending.")
109
109
  end
110
110
 
111
- def fail_pending_vm(vm, pool, timeout, redis, exists = true)
111
+ def fail_pending_vm(vm, pool, timeout, redis, exists: true)
112
112
  clone_stamp = redis.hget("vmpooler__vm__#{vm}", 'clone')
113
113
 
114
114
  time_since_clone = (Time.now - Time.parse(clone_stamp)) / 60
@@ -117,7 +117,7 @@ module Vmpooler
117
117
  request_id = redis.hget("vmpooler__vm__#{vm}", 'request_id')
118
118
  pool_alias = redis.hget("vmpooler__vm__#{vm}", 'pool_alias') if request_id
119
119
  redis.multi
120
- redis.smove('vmpooler__pending__' + pool, 'vmpooler__completed__' + pool, vm)
120
+ redis.smove("vmpooler__pending__#{pool}", "vmpooler__completed__#{pool}", vm)
121
121
  redis.zadd('vmpooler__odcreate__task', 1, "#{pool_alias}:#{pool}:1:#{request_id}") if request_id
122
122
  redis.exec
123
123
  $metrics.increment("errors.markedasfailed.#{pool}")
@@ -133,15 +133,16 @@ module Vmpooler
133
133
  end
134
134
 
135
135
  def move_pending_vm_to_ready(vm, pool, redis, request_id = nil)
136
- clone_time = redis.hget('vmpooler__vm__' + vm, 'clone')
136
+ clone_time = redis.hget("vmpooler__vm__#{vm}", 'clone')
137
137
  finish = format('%<time>.2f', time: Time.now - Time.parse(clone_time))
138
138
 
139
139
  if request_id
140
140
  ondemandrequest_hash = redis.hgetall("vmpooler__odrequest__#{request_id}")
141
- if ondemandrequest_hash['status'] == 'failed'
141
+ case ondemandrequest_hash['status']
142
+ when 'failed'
142
143
  move_vm_queue(pool, vm, 'pending', 'completed', redis, "moved to completed queue. '#{request_id}' could not be filled in time")
143
144
  return nil
144
- elsif ondemandrequest_hash['status'] == 'deleted'
145
+ when 'deleted'
145
146
  move_vm_queue(pool, vm, 'pending', 'completed', redis, "moved to completed queue. '#{request_id}' has been deleted")
146
147
  return nil
147
148
  end
@@ -160,11 +161,11 @@ module Vmpooler
160
161
  move_vm_queue(pool, vm, 'pending', 'running', redis)
161
162
  check_ondemand_request_ready(request_id, redis)
162
163
  else
163
- redis.smove('vmpooler__pending__' + pool, 'vmpooler__ready__' + pool, vm)
164
+ redis.smove("vmpooler__pending__#{pool}", "vmpooler__ready__#{pool}", vm)
164
165
  end
165
166
 
166
167
  redis.pipelined do
167
- redis.hset('vmpooler__boot__' + Date.today.to_s, pool + ':' + vm, finish) # maybe remove as this is never used by vmpooler itself?
168
+ redis.hset("vmpooler__boot__#{Date.today}", "#{pool}:#{vm}", finish) # maybe remove as this is never used by vmpooler itself?
168
169
  redis.hset("vmpooler__vm__#{vm}", 'ready', Time.now)
169
170
 
170
171
  # last boot time is displayed in API, and used by alarming script
@@ -203,11 +204,11 @@ module Vmpooler
203
204
 
204
205
  mutex.synchronize do
205
206
  @redis.with_metrics do |redis|
206
- check_stamp = redis.hget('vmpooler__vm__' + vm, 'check')
207
+ check_stamp = redis.hget("vmpooler__vm__#{vm}", 'check')
207
208
  last_checked_too_soon = ((Time.now - Time.parse(check_stamp)).to_i < $config[:config]['vm_checktime'] * 60) if check_stamp
208
209
  break if check_stamp && last_checked_too_soon
209
210
 
210
- redis.hset('vmpooler__vm__' + vm, 'check', Time.now)
211
+ redis.hset("vmpooler__vm__#{vm}", 'check', Time.now)
211
212
  # Check if the hosts TTL has expired
212
213
  # if 'boottime' is nil, set bootime to beginning of unix epoch, forces TTL to be assumed expired
213
214
  boottime = redis.hget("vmpooler__vm__#{vm}", 'ready')
@@ -217,7 +218,7 @@ module Vmpooler
217
218
  boottime = Time.at(0)
218
219
  end
219
220
  if (Time.now - boottime).to_i > ttl * 60
220
- redis.smove('vmpooler__ready__' + pool_name, 'vmpooler__completed__' + pool_name, vm)
221
+ redis.smove("vmpooler__ready__#{pool_name}", "vmpooler__completed__#{pool_name}", vm)
221
222
 
222
223
  $logger.log('d', "[!] [#{pool_name}] '#{vm}' reached end of TTL after #{ttl} minutes, removed from 'ready' queue")
223
224
  return nil
@@ -256,7 +257,7 @@ module Vmpooler
256
257
  return if hostname.empty?
257
258
  return if hostname == vm
258
259
 
259
- redis.smove('vmpooler__ready__' + pool_name, 'vmpooler__completed__' + pool_name, vm)
260
+ redis.smove("vmpooler__ready__#{pool_name}", "vmpooler__completed__#{pool_name}", vm)
260
261
  $logger.log('d', "[!] [#{pool_name}] '#{vm}' has mismatched hostname #{hostname}, removed from 'ready' queue")
261
262
  true
262
263
  end
@@ -280,7 +281,7 @@ module Vmpooler
280
281
  catch :stop_checking do
281
282
  @redis.with_metrics do |redis|
282
283
  # Check that VM is within defined lifetime
283
- checkouttime = redis.hget('vmpooler__active__' + pool, vm)
284
+ checkouttime = redis.hget("vmpooler__active__#{pool}", vm)
284
285
  if checkouttime
285
286
  time_since_checkout = Time.now - Time.parse(checkouttime)
286
287
  running = time_since_checkout / 60 / 60
@@ -289,19 +290,15 @@ module Vmpooler
289
290
  move_vm_queue(pool, vm, 'running', 'completed', redis, "reached end of TTL after #{ttl} hours")
290
291
  throw :stop_checking
291
292
  end
293
+ else
294
+ move_vm_queue(pool, vm, 'running', 'completed', redis, 'is listed as running, but has no checkouttime data. Removing from running')
292
295
  end
293
296
 
294
- if provider.vm_ready?(pool, vm)
295
- throw :stop_checking
296
- else
297
- host = provider.get_vm(pool, vm)
297
+ throw :stop_checking if provider.vm_ready?(pool, vm)
298
298
 
299
- if host
300
- throw :stop_checking
301
- else
302
- move_vm_queue(pool, vm, 'running', 'completed', redis, 'is no longer in inventory, removing from running')
303
- end
304
- end
299
+ throw :stop_checking if provider.get_vm(pool, vm)
300
+
301
+ move_vm_queue(pool, vm, 'running', 'completed', redis, 'is no longer in inventory, removing from running')
305
302
  end
306
303
  end
307
304
  end
@@ -345,7 +342,7 @@ module Vmpooler
345
342
  adjective = @name_generator.adjective(max: 14 - noun.length)
346
343
  random_name = [adjective, noun].join('-')
347
344
  hostname = $config[:config]['prefix'] + random_name
348
- available = redis.hlen('vmpooler__vm__' + hostname) == 0
345
+ available = redis.hlen("vmpooler__vm__#{hostname}") == 0
349
346
 
350
347
  [hostname, available]
351
348
  end
@@ -399,12 +396,12 @@ module Vmpooler
399
396
  @redis.with_metrics do |redis|
400
397
  # Add VM to Redis inventory ('pending' pool)
401
398
  redis.multi
402
- redis.sadd('vmpooler__pending__' + pool_name, new_vmname)
403
- redis.hset('vmpooler__vm__' + new_vmname, 'clone', Time.now)
404
- redis.hset('vmpooler__vm__' + new_vmname, 'template', pool_name) # This value is used to represent the pool.
405
- redis.hset('vmpooler__vm__' + new_vmname, 'pool', pool_name)
406
- redis.hset('vmpooler__vm__' + new_vmname, 'request_id', request_id) if request_id
407
- redis.hset('vmpooler__vm__' + new_vmname, 'pool_alias', pool_alias) if pool_alias
399
+ redis.sadd("vmpooler__pending__#{pool_name}", new_vmname)
400
+ redis.hset("vmpooler__vm__#{new_vmname}", 'clone', Time.now)
401
+ redis.hset("vmpooler__vm__#{new_vmname}", 'template', pool_name) # This value is used to represent the pool.
402
+ redis.hset("vmpooler__vm__#{new_vmname}", 'pool', pool_name)
403
+ redis.hset("vmpooler__vm__#{new_vmname}", 'request_id', request_id) if request_id
404
+ redis.hset("vmpooler__vm__#{new_vmname}", 'pool_alias', pool_alias) if pool_alias
408
405
  redis.exec
409
406
  end
410
407
 
@@ -416,8 +413,8 @@ module Vmpooler
416
413
 
417
414
  @redis.with_metrics do |redis|
418
415
  redis.pipelined do
419
- redis.hset('vmpooler__clone__' + Date.today.to_s, pool_name + ':' + new_vmname, finish)
420
- redis.hset('vmpooler__vm__' + new_vmname, 'clone_time', finish)
416
+ redis.hset("vmpooler__clone__#{Date.today}", "#{pool_name}:#{new_vmname}", finish)
417
+ redis.hset("vmpooler__vm__#{new_vmname}", 'clone_time', finish)
421
418
  end
422
419
  end
423
420
  $logger.log('s', "[+] [#{pool_name}] '#{new_vmname}' cloned in #{finish} seconds")
@@ -460,18 +457,18 @@ module Vmpooler
460
457
  mutex.synchronize do
461
458
  @redis.with_metrics do |redis|
462
459
  redis.pipelined do
463
- redis.hdel('vmpooler__active__' + pool, vm)
464
- redis.hset('vmpooler__vm__' + vm, 'destroy', Time.now)
460
+ redis.hdel("vmpooler__active__#{pool}", vm)
461
+ redis.hset("vmpooler__vm__#{vm}", 'destroy', Time.now)
465
462
 
466
463
  # Auto-expire metadata key
467
- redis.expire('vmpooler__vm__' + vm, ($config[:redis]['data_ttl'].to_i * 60 * 60))
464
+ redis.expire("vmpooler__vm__#{vm}", ($config[:redis]['data_ttl'].to_i * 60 * 60))
468
465
  end
469
466
 
470
467
  start = Time.now
471
468
 
472
469
  provider.destroy_vm(pool, vm)
473
470
 
474
- redis.srem('vmpooler__completed__' + pool, vm)
471
+ redis.srem("vmpooler__completed__#{pool}", vm)
475
472
 
476
473
  finish = format('%<time>.2f', time: Time.now - start)
477
474
  $logger.log('s', "[-] [#{pool}] '#{vm}' destroyed in #{finish} seconds")
@@ -607,10 +604,10 @@ module Vmpooler
607
604
 
608
605
  if result
609
606
  @redis.with_metrics do |redis|
610
- rdisks = redis.hget('vmpooler__vm__' + vm_name, 'disk')
607
+ rdisks = redis.hget("vmpooler__vm__#{vm_name}", 'disk')
611
608
  disks = rdisks ? rdisks.split(':') : []
612
609
  disks.push("+#{disk_size}gb")
613
- redis.hset('vmpooler__vm__' + vm_name, 'disk', disks.join(':'))
610
+ redis.hset("vmpooler__vm__#{vm_name}", 'disk', disks.join(':'))
614
611
  end
615
612
 
616
613
  $logger.log('s', "[+] [disk_manager] '#{vm_name}' attached #{disk_size}gb disk in #{finish} seconds")
@@ -642,7 +639,7 @@ module Vmpooler
642
639
 
643
640
  if result
644
641
  @redis.with_metrics do |redis|
645
- redis.hset('vmpooler__vm__' + vm_name, 'snapshot:' + snapshot_name, Time.now.to_s)
642
+ redis.hset("vmpooler__vm__#{vm_name}", "snapshot:#{snapshot_name}", Time.now.to_s)
646
643
  end
647
644
  $logger.log('s', "[+] [snapshot_manager] '#{vm_name}' snapshot created in #{finish} seconds")
648
645
  else
@@ -701,7 +698,7 @@ module Vmpooler
701
698
 
702
699
  def get_pool_name_for_vm(vm_name, redis)
703
700
  # the 'template' is a bad name. Should really be 'poolname'
704
- redis.hget('vmpooler__vm__' + vm_name, 'template')
701
+ redis.hget("vmpooler__vm__#{vm_name}", 'template')
705
702
  end
706
703
 
707
704
  # @param pool_name [String] - the name of the pool
@@ -871,16 +868,12 @@ module Vmpooler
871
868
 
872
869
  if options[:clone_target_change]
873
870
  clone_target = redis.hget('vmpooler__config__clone_target}', options[:poolname])
874
- if clone_target
875
- break unless clone_target == initial_clone_target
876
- end
871
+ break if clone_target && clone_target != initial_clone_target
877
872
  end
878
873
 
879
874
  if options[:pool_template_change]
880
875
  configured_template = redis.hget('vmpooler__config__template', options[:poolname])
881
- if configured_template
882
- break unless initial_template == configured_template
883
- end
876
+ break if configured_template && initial_template != configured_template
884
877
  end
885
878
 
886
879
  if options[:pool_reset]
@@ -974,21 +967,17 @@ module Vmpooler
974
967
  def sync_pool_template(pool)
975
968
  @redis.with_metrics do |redis|
976
969
  pool_template = redis.hget('vmpooler__config__template', pool['name'])
977
- if pool_template
978
- pool['template'] = pool_template unless pool['template'] == pool_template
979
- end
970
+ pool['template'] = pool_template if pool_template && pool['template'] != pool_template
980
971
  end
981
972
  end
982
973
 
983
974
  def prepare_template(pool, provider, redis)
984
- if $config[:config]['create_template_delta_disks']
985
- unless redis.sismember('vmpooler__template__deltas', pool['template'])
986
- begin
987
- provider.create_template_delta_disks(pool)
988
- redis.sadd('vmpooler__template__deltas', pool['template'])
989
- rescue StandardError => e
990
- $logger.log('s', "[!] [#{pool['name']}] failed while preparing a template with an error. As a result vmpooler could not create the template delta disks. Either a template delta disk already exists, or the template delta disk creation failed. The error is: #{e}")
991
- end
975
+ if $config[:config]['create_template_delta_disks'] && !redis.sismember('vmpooler__template__deltas', pool['template'])
976
+ begin
977
+ provider.create_template_delta_disks(pool)
978
+ redis.sadd('vmpooler__template__deltas', pool['template'])
979
+ rescue StandardError => e
980
+ $logger.log('s', "[!] [#{pool['name']}] failed while preparing a template with an error. As a result vmpooler could not create the template delta disks. Either a template delta disk already exists, or the template delta disk creation failed. The error is: #{e}")
992
981
  end
993
982
  end
994
983
  redis.hset('vmpooler__template__prepared', pool['name'], pool['template'])
@@ -1139,15 +1128,15 @@ module Vmpooler
1139
1128
  mutex.synchronize do
1140
1129
  @redis.with_metrics do |redis|
1141
1130
  provider.vms_in_pool(pool['name']).each do |vm|
1142
- if !redis.sismember('vmpooler__running__' + pool['name'], vm['name']) &&
1143
- !redis.sismember('vmpooler__ready__' + pool['name'], vm['name']) &&
1144
- !redis.sismember('vmpooler__pending__' + pool['name'], vm['name']) &&
1145
- !redis.sismember('vmpooler__completed__' + pool['name'], vm['name']) &&
1146
- !redis.sismember('vmpooler__discovered__' + pool['name'], vm['name']) &&
1147
- !redis.sismember('vmpooler__migrating__' + pool['name'], vm['name'])
1131
+ if !redis.sismember("vmpooler__running__#{pool['name']}", vm['name']) &&
1132
+ !redis.sismember("vmpooler__ready__#{pool['name']}", vm['name']) &&
1133
+ !redis.sismember("vmpooler__pending__#{pool['name']}", vm['name']) &&
1134
+ !redis.sismember("vmpooler__completed__#{pool['name']}", vm['name']) &&
1135
+ !redis.sismember("vmpooler__discovered__#{pool['name']}", vm['name']) &&
1136
+ !redis.sismember("vmpooler__migrating__#{pool['name']}", vm['name'])
1148
1137
 
1149
1138
  pool_check_response[:discovered_vms] += 1
1150
- redis.sadd('vmpooler__discovered__' + pool['name'], vm['name'])
1139
+ redis.sadd("vmpooler__discovered__#{pool['name']}", vm['name'])
1151
1140
 
1152
1141
  $logger.log('s', "[?] [#{pool['name']}] '#{vm['name']}' added to 'discovered' queue")
1153
1142
  end
@@ -1168,7 +1157,7 @@ module Vmpooler
1168
1157
  redis.smembers("vmpooler__running__#{pool_name}").each do |vm|
1169
1158
  if inventory[vm]
1170
1159
  begin
1171
- vm_lifetime = redis.hget('vmpooler__vm__' + vm, 'lifetime') || $config[:config]['vm_lifetime'] || 12
1160
+ vm_lifetime = redis.hget("vmpooler__vm__#{vm}", 'lifetime') || $config[:config]['vm_lifetime'] || 12
1172
1161
  pool_check_response[:checked_running_vms] += 1
1173
1162
  check_running_vm(vm, pool_name, vm_lifetime, provider)
1174
1163
  rescue StandardError => e
@@ -1210,7 +1199,7 @@ module Vmpooler
1210
1199
  $logger.log('d', "[!] [#{pool_name}] _check_pool failed with an error while evaluating pending VMs: #{e}")
1211
1200
  end
1212
1201
  else
1213
- fail_pending_vm(vm, pool_name, pool_timeout, redis, false)
1202
+ fail_pending_vm(vm, pool_name, pool_timeout, redis, exists: false)
1214
1203
  end
1215
1204
  end
1216
1205
  end
@@ -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