Blame SOURCES/bz1459503-01-OSP-workarounds-not-compatible-wi.patch

be1b1f
From bbb137919a73cffdb635ed77d7f2b2e35f2cd056 Mon Sep 17 00:00:00 2001
f778fe
From: Ivan Devat <idevat@redhat.com>
f778fe
Date: Wed, 7 Jun 2017 14:36:05 +0200
be1b1f
Subject: [PATCH 2/5] squash bz1459503 OSP workarounds not compatible wi
f778fe
f778fe
reuse existing pcmk authkey during setup
f778fe
f778fe
show only warn if `resource create` creates remote
f778fe
---
f778fe
 pcs/cluster.py                       | 10 +++++++++-
f778fe
 pcs/lib/commands/resource.py         |  6 ++++--
f778fe
 pcs/test/cib_resource/test_create.py | 13 ++++++-------
f778fe
 pcs/test/test_resource.py            | 24 ++++++++++++------------
f778fe
 4 files changed, 31 insertions(+), 22 deletions(-)
f778fe
f778fe
diff --git a/pcs/cluster.py b/pcs/cluster.py
be1b1f
index e8c94ab8..c2af8a8f 100644
f778fe
--- a/pcs/cluster.py
f778fe
+++ b/pcs/cluster.py
be1b1f
@@ -517,13 +517,21 @@ def cluster_setup(argv):
f778fe
         print("Destroying cluster on nodes: {0}...".format(
f778fe
             ", ".join(primary_addr_list)
f778fe
         ))
f778fe
+
f778fe
+        try:
f778fe
+            pcmk_authkey_content = (
f778fe
+                open(settings.pacemaker_authkey_file, "rb").read()
f778fe
+            )
f778fe
+        except EnvironmentError as e:
f778fe
+            pcmk_authkey_content = generate_key()
f778fe
+
f778fe
         destroy_cluster(primary_addr_list)
f778fe
         print()
f778fe
 
f778fe
         try:
f778fe
             file_definitions = {}
f778fe
             file_definitions.update(
f778fe
-                node_communication_format.pcmk_authkey_file(generate_key())
f778fe
+                node_communication_format.pcmk_authkey_file(pcmk_authkey_content)
f778fe
             )
f778fe
             if modifiers["encryption"] == "1":
f778fe
                 file_definitions.update(
f778fe
diff --git a/pcs/lib/commands/resource.py b/pcs/lib/commands/resource.py
be1b1f
index 5637113c..6d59e8f9 100644
f778fe
--- a/pcs/lib/commands/resource.py
f778fe
+++ b/pcs/lib/commands/resource.py
be1b1f
@@ -76,7 +76,8 @@ def _validate_remote_connection(
f778fe
     report_list.append(
f778fe
         reports.get_problem_creator(
f778fe
             report_codes.FORCE_NOT_SUITABLE_COMMAND,
f778fe
-            allow_not_suitable_command
f778fe
+            is_forced=True,
f778fe
+            # allow_not_suitable_command
f778fe
         )(reports.use_command_node_add_remote)
f778fe
     )
f778fe
 
be1b1f
@@ -106,7 +107,8 @@ def _validate_guest_change(
f778fe
     report_list.append(
f778fe
         reports.get_problem_creator(
f778fe
             report_codes.FORCE_NOT_SUITABLE_COMMAND,
f778fe
-            allow_not_suitable_command
f778fe
+            is_forced=True
f778fe
+            # allow_not_suitable_command
f778fe
         )(create_report)
f778fe
     )
f778fe
 
f778fe
diff --git a/pcs/test/cib_resource/test_create.py b/pcs/test/cib_resource/test_create.py
be1b1f
index e5f9dd4d..8a445f09 100644
f778fe
--- a/pcs/test/cib_resource/test_create.py
f778fe
+++ b/pcs/test/cib_resource/test_create.py
be1b1f
@@ -1583,11 +1583,10 @@ class FailOrWarnGroup(ResourceTest):
f778fe
         )
f778fe
 
f778fe
     def test_fail_when_on_pacemaker_remote_attempt(self):
f778fe
-        self.assert_pcs_fail(
f778fe
+        self.assert_pcs_success(
f778fe
             "resource create R2 ocf:pacemaker:remote",
f778fe
-            "Error: this command is not sufficient for creating a remote"
f778fe
-                " connection, use 'pcs cluster node add-remote'"
f778fe
-                ", use --force to override\n"
f778fe
+            "Warning: this command is not sufficient for creating a remote"
f778fe
+                " connection, use 'pcs cluster node add-remote'\n"
f778fe
         )
f778fe
 
f778fe
     def test_warn_when_on_pacemaker_remote_attempt(self):
be1b1f
@@ -1687,10 +1686,10 @@ class FailOrWarnGroup(ResourceTest):
f778fe
         )
f778fe
 
f778fe
     def test_fail_when_on_pacemaker_remote_guest_attempt(self):
f778fe
-        self.assert_pcs_fail(
f778fe
+        self.assert_pcs_success(
f778fe
             "resource create R2 ocf:heartbeat:Dummy meta remote-node=HOST",
f778fe
-            "Error: this command is not sufficient for creating a guest node,"
f778fe
-            " use 'pcs cluster node add-guest', use --force to override\n"
f778fe
+            "Warning: this command is not sufficient for creating a guest node,"
f778fe
+            " use 'pcs cluster node add-guest'\n"
f778fe
         )
f778fe
 
f778fe
     def test_warn_when_on_pacemaker_remote_guest_attempt(self):
f778fe
diff --git a/pcs/test/test_resource.py b/pcs/test/test_resource.py
be1b1f
index 7828efb4..8397df76 100644
f778fe
--- a/pcs/test/test_resource.py
f778fe
+++ b/pcs/test/test_resource.py
be1b1f
@@ -5126,10 +5126,10 @@ class ResourceUpdateSpcialChecks(unittest.TestCase, AssertPcsMixin):
f778fe
         self.assert_pcs_success(
f778fe
             "resource create R ocf:heartbeat:Dummy",
f778fe
         )
f778fe
-        self.assert_pcs_fail(
f778fe
+        self.assert_pcs_success(
f778fe
             "resource update R meta remote-node=HOST",
f778fe
-            "Error: this command is not sufficient for creating a guest node,"
f778fe
-            " use 'pcs cluster node add-guest', use --force to override\n"
f778fe
+            "Warning: this command is not sufficient for creating a guest node,"
f778fe
+            " use 'pcs cluster node add-guest'\n"
f778fe
         )
f778fe
     def test_update_warn_on_pacemaker_guest_attempt(self):
f778fe
         self.assert_pcs_success(
be1b1f
@@ -5148,10 +5148,10 @@ class ResourceUpdateSpcialChecks(unittest.TestCase, AssertPcsMixin):
f778fe
             "Warning: this command is not sufficient for creating a guest node,"
f778fe
             " use 'pcs cluster node add-guest'\n"
f778fe
         )
f778fe
-        self.assert_pcs_fail(
f778fe
+        self.assert_pcs_success(
f778fe
             "resource update R meta remote-node=",
f778fe
-            "Error: this command is not sufficient for removing a guest node,"
f778fe
-            " use 'pcs cluster node remove-guest', use --force to override\n"
f778fe
+            "Warning: this command is not sufficient for removing a guest node,"
f778fe
+            " use 'pcs cluster node remove-guest'\n"
f778fe
         )
f778fe
 
f778fe
     def test_update_warn_on_pacemaker_guest_attempt_remove(self):
be1b1f
@@ -5172,10 +5172,10 @@ class ResourceUpdateSpcialChecks(unittest.TestCase, AssertPcsMixin):
f778fe
         self.assert_pcs_success(
f778fe
             "resource create R ocf:heartbeat:Dummy",
f778fe
         )
f778fe
-        self.assert_pcs_fail(
f778fe
+        self.assert_pcs_success(
f778fe
             "resource meta R remote-node=HOST",
f778fe
-            "Error: this command is not sufficient for creating a guest node,"
f778fe
-            " use 'pcs cluster node add-guest', use --force to override\n"
f778fe
+            "Warning: this command is not sufficient for creating a guest node,"
f778fe
+            " use 'pcs cluster node add-guest'\n"
f778fe
         )
f778fe
 
f778fe
     def test_meta_warn_on_pacemaker_guest_attempt(self):
be1b1f
@@ -5196,10 +5196,10 @@ class ResourceUpdateSpcialChecks(unittest.TestCase, AssertPcsMixin):
f778fe
             "Warning: this command is not sufficient for creating a guest node,"
f778fe
             " use 'pcs cluster node add-guest'\n"
f778fe
         )
f778fe
-        self.assert_pcs_fail(
f778fe
+        self.assert_pcs_success(
f778fe
             "resource meta R remote-node=",
f778fe
-            "Error: this command is not sufficient for removing a guest node,"
f778fe
-            " use 'pcs cluster node remove-guest', use --force to override\n"
f778fe
+            "Warning: this command is not sufficient for removing a guest node,"
f778fe
+            " use 'pcs cluster node remove-guest'\n"
f778fe
         )
f778fe
 
f778fe
     def test_meta_warn_on_pacemaker_guest_attempt_remove(self):
f778fe
-- 
a3a2ad
2.13.6
f778fe