From df210c38d00b363fd86fdc6c18087a1eea66faa8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jos=C3=A9=20Iv=C3=A1n=20L=C3=B3pez=20Gonz=C3=A1lez?= Date: Fri, 20 Dec 2024 13:01:27 +0000 Subject: [PATCH] storage: recover config if needed --- service/lib/agama/manager.rb | 43 ++++++++++++++++++++++-------------- 1 file changed, 27 insertions(+), 16 deletions(-) diff --git a/service/lib/agama/manager.rb b/service/lib/agama/manager.rb index 3874d4b71d..69ef425dd8 100644 --- a/service/lib/agama/manager.rb +++ b/service/lib/agama/manager.rb @@ -83,30 +83,19 @@ def startup_phase service_status.idle end - def locale=(locale) - service_status.busy - change_process_locale(locale) - users.update_issues - start_progress_with_descriptions( - _("Load software translations"), - _("Load storage translations") - ) - progress.step { software.locale = locale } - progress.step { storage.locale = locale } - ensure - service_status.idle - finish_progress - end - # Runs the config phase def config_phase service_status.busy + first_time = installation_phase.startup? installation_phase.config start_progress_with_descriptions( _("Analyze disks"), _("Configure software") ) - progress.step { storage.probe } + # FIXME: hot-fix for bsc#1234711, see {#probe_and_recover_storage}. In autoinstallation, the + # storage config could be applied before probing. In that case, the config has to be + # recovered. + progress.step { first_time ? probe_and_recover_storage : storage.probe } progress.step { software.probe } logger.info("Config phase done") @@ -159,6 +148,21 @@ def install_phase end # rubocop:enable Metrics/AbcSize + def locale=(locale) + service_status.busy + change_process_locale(locale) + users.update_issues + start_progress_with_descriptions( + _("Load software translations"), + _("Load storage translations") + ) + progress.step { software.locale = locale } + progress.step { storage.locale = locale } + ensure + service_status.idle + finish_progress + end + # Software client # # @return [DBus::Clients::Software] @@ -273,5 +277,12 @@ def iguana? # @return [ServiceStatusRecorder] attr_reader :service_status_recorder + + # Probes storage and recover the current config, if any. + def probe_and_recover_storage + storage_config = storage.config + storage.probe + storage.config = storage_config unless storage_config.empty? + end end end