From 8458734b91d1a65f1fb6834195a81433b635b383 Mon Sep 17 00:00:00 2001 From: Piotr Kliczewski Date: Wed, 6 Dec 2017 10:42:50 +0100 Subject: [PATCH] Targeting host fails When ever a host is targeted event parsing fail since it is not possible to build `vm_location`. We make sure that it is not calculated when targeting a host. Bug-Url: https://bugzilla.redhat.com/1520513 --- .../infra_manager/event_parsing/strategies/v4.rb | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/app/models/manageiq/providers/redhat/infra_manager/event_parsing/strategies/v4.rb b/app/models/manageiq/providers/redhat/infra_manager/event_parsing/strategies/v4.rb index 08649a96f..b6980f0d2 100644 --- a/app/models/manageiq/providers/redhat/infra_manager/event_parsing/strategies/v4.rb +++ b/app/models/manageiq/providers/redhat/infra_manager/event_parsing/strategies/v4.rb @@ -16,7 +16,7 @@ def self.event_to_hash(event, ems_id = nil) vm_ref = template?(event.name) ? ems_ref_from_object_in_event(event.template) : ems_ref_from_object_in_event(event.vm) # Build the event hash - { + hash = { :event_type => event.name, :source => 'RHEVM', :message => event.description, @@ -27,18 +27,23 @@ def self.event_to_hash(event, ems_id = nil) :vm_ems_ref => vm_ref, :host_ems_ref => ems_ref_from_object_in_event(event.host), :ems_cluster_ems_ref => ems_ref_from_object_in_event(event.cluster), - :vm_location => vm_location(event.data_center, vm_ref) } + + add_vm_location(hash, event.data_center, vm_ref) end - def self.vm_location(dc, vm_ref) + def self.add_vm_location(hash, dc, vm_ref) + return hash if vm_ref.nil? + uid_ems = ManageIQ::Providers::Redhat::InfraManager.extract_ems_ref_id(vm_ref) location = "#{uid_ems}.ovf" return location if dc.blank? dc_ref = ems_ref_from_object_in_event(dc) dc_uid = ManageIQ::Providers::Redhat::InfraManager.extract_ems_ref_id(dc_ref) - File.join('/rhev/data-center', dc_uid, 'mastersd/master/vms', uid_ems, location) + + hash[:vm_location] = File.join('/rhev/data-center', dc_uid, 'mastersd/master/vms', uid_ems, location) + hash end def self.ems_ref_from_object_in_event(data)