]> git.proxmox.com Git - pve-ha-manager.git/commitdiff
add service migrate/relocate to regression tests
authorThomas Lamprecht <t.lamprecht@proxmox.com>
Tue, 22 Dec 2015 07:52:37 +0000 (08:52 +0100)
committerDietmar Maurer <dietmar@proxmox.com>
Tue, 22 Dec 2015 09:00:58 +0000 (10:00 +0100)
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
src/PVE/HA/Sim/TestHardware.pm
src/test/test-service-command2/README [new file with mode: 0644]
src/test/test-service-command2/cmdlist [new file with mode: 0644]
src/test/test-service-command2/hardware_status [new file with mode: 0644]
src/test/test-service-command2/log.expect [new file with mode: 0644]
src/test/test-service-command2/manager_status [new file with mode: 0644]
src/test/test-service-command2/service_config [new file with mode: 0644]

index 3a4b37e71f8666c1dff3f51bfd0aa28b385991d1..6ba9404a8ebbaf30ec31e02741e850fcb6ea9e94 100644 (file)
@@ -88,6 +88,7 @@ sub log {
 # shutdown <node>
 # restart-lrm <node>
 # service <sid> <enabled|disabled>
+# service <sid> <migrate|relocate> <target>
 
 sub sim_hardware_cmd {
     my ($self, $cmdstr, $logid) = @_;
@@ -164,6 +165,13 @@ sub sim_hardware_cmd {
 
                $self->set_service_state($sid, $action);
 
+           } elsif ($action eq 'migrate' || $action eq 'relocate') {
+
+               die "sim_hardware_cmd: missing target node for '$action' command"
+                   if !$target;
+
+               $self->queue_crm_commands_nolock("$action $sid $target");
+
            } else {
                die "sim_hardware_cmd: unknown service action '$action' " .
                    "- not implemented\n"
diff --git a/src/test/test-service-command2/README b/src/test/test-service-command2/README
new file mode 100644 (file)
index 0000000..f8bffe3
--- /dev/null
@@ -0,0 +1 @@
+Test user triggered service migration.
diff --git a/src/test/test-service-command2/cmdlist b/src/test/test-service-command2/cmdlist
new file mode 100644 (file)
index 0000000..8c5a8ea
--- /dev/null
@@ -0,0 +1,4 @@
+[
+    [ "power node1 on", "power node2 on", "power node3 on"],
+    [ "service vm:103 migrate node1" ]
+]
diff --git a/src/test/test-service-command2/hardware_status b/src/test/test-service-command2/hardware_status
new file mode 100644 (file)
index 0000000..451beb1
--- /dev/null
@@ -0,0 +1,5 @@
+{
+  "node1": { "power": "off", "network": "off" },
+  "node2": { "power": "off", "network": "off" },
+  "node3": { "power": "off", "network": "off" }
+}
diff --git a/src/test/test-service-command2/log.expect b/src/test/test-service-command2/log.expect
new file mode 100644 (file)
index 0000000..397ccee
--- /dev/null
@@ -0,0 +1,34 @@
+info      0     hardware: starting simulation
+info     20      cmdlist: execute power node1 on
+info     20    node1/crm: status change startup => wait_for_quorum
+info     20    node1/lrm: status change startup => wait_for_agent_lock
+info     20      cmdlist: execute power node2 on
+info     20    node2/crm: status change startup => wait_for_quorum
+info     20    node2/lrm: status change startup => wait_for_agent_lock
+info     20      cmdlist: execute power node3 on
+info     20    node3/crm: status change startup => wait_for_quorum
+info     20    node3/lrm: status change startup => wait_for_agent_lock
+info     20    node1/crm: got lock 'ha_manager_lock'
+info     20    node1/crm: status change wait_for_quorum => master
+info     20    node1/crm: node 'node1': state changed from 'unknown' => 'online'
+info     20    node1/crm: node 'node2': state changed from 'unknown' => 'online'
+info     20    node1/crm: node 'node3': state changed from 'unknown' => 'online'
+info     20    node1/crm: adding new service 'vm:103' on node 'node3'
+info     22    node2/crm: status change wait_for_quorum => slave
+info     24    node3/crm: status change wait_for_quorum => slave
+info     25    node3/lrm: got lock 'ha_agent_node3_lock'
+info     25    node3/lrm: status change wait_for_agent_lock => active
+info     25    node3/lrm: starting service vm:103
+info     25    node3/lrm: service status vm:103 started
+info    120      cmdlist: execute service vm:103 migrate node1
+info    120    node1/crm: got crm command: migrate vm:103 node1
+info    120    node1/crm: migrate service 'vm:103' to node 'node1' (running)
+info    120    node1/crm: service 'vm:103': state changed from 'started' to 'migrate'  (node = node3, target = node1)
+info    125    node3/lrm: service vm:103 - start migrate to node 'node1'
+info    125    node3/lrm: service vm:103 - end migrate to node 'node1'
+info    140    node1/crm: service 'vm:103': state changed from 'migrate' to 'started'  (node = node1)
+info    141    node1/lrm: got lock 'ha_agent_node1_lock'
+info    141    node1/lrm: status change wait_for_agent_lock => active
+info    141    node1/lrm: starting service vm:103
+info    141    node1/lrm: service status vm:103 started
+info    720     hardware: exit simulation - done
diff --git a/src/test/test-service-command2/manager_status b/src/test/test-service-command2/manager_status
new file mode 100644 (file)
index 0000000..0967ef4
--- /dev/null
@@ -0,0 +1 @@
+{}
diff --git a/src/test/test-service-command2/service_config b/src/test/test-service-command2/service_config
new file mode 100644 (file)
index 0000000..c6860e7
--- /dev/null
@@ -0,0 +1,3 @@
+{
+    "vm:103": { "node": "node3", "state": "enabled" }
+}