From 2f83774d5b71227527dbce45ffd9674b1ae1cf58 Mon Sep 17 00:00:00 2001 From: Esdras Vidal Date: Tue, 11 Sep 2018 09:08:30 -0300 Subject: [PATCH] Fix Physical Disks save inventory --- .../ems_refresh/save_inventory_physical_infra.rb | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/app/models/ems_refresh/save_inventory_physical_infra.rb b/app/models/ems_refresh/save_inventory_physical_infra.rb index 4875d9c5466..5de5dc9e415 100644 --- a/app/models/ems_refresh/save_inventory_physical_infra.rb +++ b/app/models/ems_refresh/save_inventory_physical_infra.rb @@ -101,7 +101,7 @@ def save_physical_storages_inventory(ems, hashes, target = nil) h[:physical_chassis_id] = h.delete(:physical_chassis).try(:[], :id) end - child_keys = %i(computer_system asset_detail physical_disk canister) + child_keys = %i(computer_system asset_detail physical_disks canister) save_inventory_multi(ems.physical_storages, hashes, deletes, [:ems_ref], child_keys) store_ids_for_new_records(ems.physical_storages, hashes, :ems_ref) end @@ -115,11 +115,17 @@ def save_asset_detail_inventory(parent, hash) end # - # Saves the drive information of a storage + # Saves the disks information of a storage # - def save_physical_disk_inventory(parent, hash) - return if hash.nil? - save_inventory_single(:physical_disk, parent, hash) + def save_physical_disks_inventory(physical_storage, hashes) + return if hashes.nil? + + # Update the associated ids + hashes.each do |h| + h[:physical_storage_id] = h.delete(:physical_storage).try(:[], :id) + end + + save_inventory_multi(physical_storage.physical_disks, hashes, :use_association, [:physical_storage_id]) end #