From 81e8e7d00010700a305f47b67667a5655c479141 Mon Sep 17 00:00:00 2001 From: Fiona Ebner Date: Fri, 14 Apr 2023 14:38:28 +0200 Subject: [PATCH] sim: hardware: commands: make it possible to add already running service Will be used in a test for balance on start, where it should make a difference if the service is running or not. Signed-off-by: Fiona Ebner Signed-off-by: Thomas Lamprecht --- src/PVE/HA/Sim/Hardware.pm | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/src/PVE/HA/Sim/Hardware.pm b/src/PVE/HA/Sim/Hardware.pm index 5b023ef..0018208 100644 --- a/src/PVE/HA/Sim/Hardware.pm +++ b/src/PVE/HA/Sim/Hardware.pm @@ -171,7 +171,7 @@ sub set_service_state { } sub add_service { - my ($self, $sid, $opts) = @_; + my ($self, $sid, $opts, $running) = @_; my $conf = $self->read_service_config(); die "resource ID '$sid' already defined\n" if $conf->{$sid}; @@ -181,6 +181,10 @@ sub add_service { $self->write_service_config($conf); + my $ss = $self->read_service_status($opts->{node}); + $ss->{$sid} = $running; + $self->write_service_status($opts->{node}, $ss); + return $conf; } @@ -563,7 +567,7 @@ sub get_cfs_state { # service # service stop # service lock/unlock [lockname] -# service add [] +# service add [] [] # service delete sub sim_hardware_cmd { my ($self, $cmdstr, $logid) = @_; @@ -691,8 +695,11 @@ sub sim_hardware_cmd { $self->queue_crm_commands_nolock("$action $sid $param"); } elsif ($action eq 'add') { - - $self->add_service($sid, {state => $params[1] || 'started', node => $param}); + $self->add_service( + $sid, + {state => $params[1] || 'started', node => $param}, + $params[2] || 0, + ); } elsif ($action eq 'delete') { -- 2.39.2