Blame SOURCES/bz1458153-01-give-back-orig.-master-behav.-resource-create.patch

a3a2ad
From fe7151898fed1b6383a49db26426c3f23c5ff7f2 Mon Sep 17 00:00:00 2001
f778fe
From: Ivan Devat <idevat@redhat.com>
f778fe
Date: Mon, 5 Jun 2017 17:13:41 +0200
f778fe
Subject: [PATCH] give back orig. --master behav. (resource create)
f778fe
f778fe
---
f778fe
 pcs/cli/common/parse_args.py           |   8 +-
f778fe
 pcs/cli/common/test/test_parse_args.py |  34 ++++++-
f778fe
 pcs/resource.py                        |  19 ++++
f778fe
 pcs/test/cib_resource/test_create.py   | 181 ++++++++++++++++++++++++++-------
f778fe
 pcs/test/test_constraints.py           |  28 ++---
f778fe
 pcs/test/test_resource.py              |  10 +-
f778fe
 pcs/utils.py                           |   7 ++
f778fe
 7 files changed, 228 insertions(+), 59 deletions(-)
f778fe
f778fe
diff --git a/pcs/cli/common/parse_args.py b/pcs/cli/common/parse_args.py
a3a2ad
index 70b926c0..d3151043 100644
f778fe
--- a/pcs/cli/common/parse_args.py
f778fe
+++ b/pcs/cli/common/parse_args.py
a3a2ad
@@ -299,7 +299,13 @@ def upgrade_args(arg_list):
f778fe
             and
f778fe
             args_without_options[:2] == ["resource", "create"]
f778fe
         ):
f778fe
-            upgraded_args.append("master")
f778fe
+            #upgraded_args.append("master")
f778fe
+
f778fe
+            #We do not replace flag --master with keyword "manster" here because
f778fe
+            #we want to give grace period to openstack that uses original
f778fe
+            #missbehaviour.
f778fe
+            #see https://bugzilla.redhat.com/show_bug.cgi?id=1458153
f778fe
+            upgraded_args.append(arg)
f778fe
         else:
f778fe
             upgraded_args.append(arg)
f778fe
     return upgraded_args
f778fe
diff --git a/pcs/cli/common/test/test_parse_args.py b/pcs/cli/common/test/test_parse_args.py
a3a2ad
index efe38d0e..900094c9 100644
f778fe
--- a/pcs/cli/common/test/test_parse_args.py
f778fe
+++ b/pcs/cli/common/test/test_parse_args.py
a3a2ad
@@ -486,9 +486,21 @@ class UpgradeArgs(TestCase):
f778fe
             upgrade_args(["first", "--cloneopt=1", "second"])
f778fe
         )
f778fe
 
f778fe
-    def test_upgrade_2dash_master_in_resource_create(self):
f778fe
-        self.assertEqual(
f778fe
-            ["resource", "create", "master", "second"],
f778fe
+    # def test_upgrade_2dash_master_in_resource_create(self):
f778fe
+    #     self.assertEqual(
f778fe
+    #         ["resource", "create", "master", "second"],
f778fe
+    #         upgrade_args(["resource", "create", "--master", "second"])
f778fe
+    #     )
f778fe
+
f778fe
+    def test_do_not_upgrade_2dash_master_in_resource_create__original_behaviour(
f778fe
+        self
f778fe
+    ):
f778fe
+        """
f778fe
+        downstream temporary behaviour
f778fe
+        fixes bz 1458153
f778fe
+        """
f778fe
+        self.assertEqual(
f778fe
+            ["resource", "create", "--master", "second"],
f778fe
             upgrade_args(["resource", "create", "--master", "second"])
f778fe
         )
f778fe
 
a3a2ad
@@ -498,10 +510,22 @@ class UpgradeArgs(TestCase):
f778fe
             upgrade_args(["first", "--master", "second"])
f778fe
         )
f778fe
 
f778fe
-    def test_upgrade_2dash_master_in_resource_create_with_complications(self):
f778fe
+    # def test_upgrade_2dash_master_in_resource_create_with_complications(self):
f778fe
+    #     self.assertEqual(
f778fe
+    #         [
f778fe
+    #             "-f", "path/to/file", "resource", "-V", "create", "master",
f778fe
+    #             "second"
f778fe
+    #         ],
f778fe
+    #         upgrade_args([
f778fe
+    #             "-f", "path/to/file", "resource", "-V", "create", "--master",
f778fe
+    #             "second"
f778fe
+    #         ])
f778fe
+    #     )
f778fe
+
f778fe
+    def test_no_upgrade_2dash_master_complications__original_behaviour(self):
f778fe
         self.assertEqual(
f778fe
             [
f778fe
-                "-f", "path/to/file", "resource", "-V", "create", "master",
f778fe
+                "-f", "path/to/file", "resource", "-V", "create", "--master",
f778fe
                 "second"
f778fe
             ],
f778fe
             upgrade_args([
f778fe
diff --git a/pcs/resource.py b/pcs/resource.py
a3a2ad
index 082bd9d1..6637f806 100644
f778fe
--- a/pcs/resource.py
f778fe
+++ b/pcs/resource.py
a3a2ad
@@ -384,6 +384,25 @@ def resource_create(lib, argv, modifiers):
f778fe
     ra_type = argv[1]
f778fe
 
f778fe
     parts = parse_create_args(argv[2:])
f778fe
+
f778fe
+    if modifiers["master"] and "master" in parts:
f778fe
+        raise error("you cannot specify both --master and master")
f778fe
+
f778fe
+    #This is for `pcs resource create`. Fix of the bug
f778fe
+    #https://bugzilla.redhat.com/show_bug.cgi?id=1378107
f778fe
+    #caused problems in openstack which uses `pcs resource create`
f778fe
+    #see https://bugzilla.redhat.com/show_bug.cgi?id=1458153
f778fe
+    #so we give back the original misbehavior of master here temporarily.
f778fe
+    #When user uses `--master` she gets the original behaviour. With `master`
f778fe
+    #she gets new behaviour.
f778fe
+    if modifiers["master"]:
f778fe
+        warn(
f778fe
+            "flag '--master' is deprecated, use keyword 'master' instead (see"
f778fe
+            " the usage)"
f778fe
+        )
f778fe
+        parts["master"] = parts["meta"]
f778fe
+        parts["meta"] = {}
f778fe
+
f778fe
     parts_sections = ["clone", "master", "bundle"]
f778fe
     defined_options = [opt for opt in parts_sections if opt in parts]
f778fe
     if modifiers["group"]:
f778fe
diff --git a/pcs/test/cib_resource/test_create.py b/pcs/test/cib_resource/test_create.py
a3a2ad
index cfb2e645..c554ec24 100644
f778fe
--- a/pcs/test/cib_resource/test_create.py
f778fe
+++ b/pcs/test/cib_resource/test_create.py
a3a2ad
@@ -233,7 +233,7 @@ class Success(ResourceTest):
f778fe
     def test_with_master(self):
f778fe
         self.assert_effect(
f778fe
             [
f778fe
-                "resource create R ocf:heartbeat:Dummy --no-default-ops --master",
f778fe
+                # "resource create R ocf:heartbeat:Dummy --no-default-ops --master",
f778fe
                 "resource create R ocf:heartbeat:Dummy --no-default-ops master",
f778fe
             ],
f778fe
             """<resources>
a3a2ad
@@ -654,7 +654,7 @@ class SuccessGroup(ResourceTest):
f778fe
 class SuccessMaster(ResourceTest):
f778fe
     def test_disable_is_on_master_element(self):
f778fe
         self.assert_effect(
f778fe
-            "resource create R ocf:heartbeat:Dummy --no-default-ops --disabled --master",
f778fe
+            "resource create R ocf:heartbeat:Dummy --no-default-ops --disabled master",
f778fe
             """<resources>
f778fe
                 <master id="R-master">
f778fe
                     <meta_attributes id="R-master-meta_attributes">
a3a2ad
@@ -675,13 +675,55 @@ class SuccessMaster(ResourceTest):
f778fe
             </resources>"""
f778fe
         )
f778fe
 
f778fe
-    def test_put_options_after_master_as_its_meta_fix_1(self):
f778fe
+    # def test_put_options_after_master_as_its_meta_fix_1(self):
f778fe
+    #     """
f778fe
+    #     fixes bz 1378107 (do not use master options as primitive options)
f778fe
+    #     """
f778fe
+    #     self.assert_effect(
f778fe
+    #         "resource create R ocf:heartbeat:Dummy state=a"
f778fe
+    #             " --master is-managed=false --force"
f778fe
+    #         ,
f778fe
+    #         """<resources>
f778fe
+    #             <master id="R-master">
f778fe
+    #                 
f778fe
+    #                     type="Dummy"
f778fe
+    #                 >
f778fe
+    #                     <instance_attributes id="R-instance_attributes">
f778fe
+    #                         
f778fe
+    #                             name="state" value="a"
f778fe
+    #                         />
f778fe
+    #                     </instance_attributes>
f778fe
+    #                     <operations>
f778fe
+    #                         
f778fe
+    #                             name="monitor" timeout="20"
f778fe
+    #                         />
f778fe
+    #                         
f778fe
+    #                             name="start" timeout="20"
f778fe
+    #                         />
f778fe
+    #                         
f778fe
+    #                             name="stop" timeout="20"
f778fe
+    #                         />
f778fe
+    #                     </operations>
f778fe
+    #                 </primitive>
f778fe
+    #                 <meta_attributes id="R-master-meta_attributes">
f778fe
+    #                     
f778fe
+    #                         name="is-managed" value="false"
f778fe
+    #                 />
f778fe
+    #                 </meta_attributes>
f778fe
+    #             </master>
f778fe
+    #         </resources>"""
f778fe
+    #     )
f778fe
+
f778fe
+    def test_put_options_after_master_as_primitive_options__original_behaviour(
f778fe
+        self
f778fe
+    ):
f778fe
         """
f778fe
-        fixes bz 1378107 (do not use master options as primitive options)
f778fe
+        downstream temporary behaviour
f778fe
+        fixes bz 1458153
f778fe
         """
f778fe
         self.assert_effect(
f778fe
             "resource create R ocf:heartbeat:Dummy state=a"
f778fe
-                " --master is-managed=false --force"
f778fe
+                " --master fake=false --force"
f778fe
             ,
f778fe
             """<resources>
f778fe
                 <master id="R-master">
a3a2ad
@@ -689,6 +731,9 @@ class SuccessMaster(ResourceTest):
f778fe
                         type="Dummy"
f778fe
                     >
f778fe
                         <instance_attributes id="R-instance_attributes">
f778fe
+                            
f778fe
+                                value="false"
f778fe
+                            />
f778fe
                             
f778fe
                                 name="state" value="a"
f778fe
                             />
a3a2ad
@@ -714,22 +759,58 @@ class SuccessMaster(ResourceTest):
f778fe
                             />
f778fe
                         </operations>
f778fe
                     </primitive>
f778fe
-                    <meta_attributes id="R-master-meta_attributes">
f778fe
-                        
f778fe
-                            name="is-managed" value="false"
f778fe
-                    />
f778fe
-                    </meta_attributes>
f778fe
                 </master>
f778fe
             </resources>"""
f778fe
-        )
f778fe
-
f778fe
-    def test_put_options_after_master_as_its_meta_fix_2(self):
f778fe
+            ,
f778fe
+            output="Warning: flag '--master' is deprecated, use keyword"
f778fe
+                " 'master' instead (see the usage)\n"
f778fe
+        )
f778fe
+
f778fe
+
f778fe
+    # def test_put_options_after_master_as_its_meta_fix_2(self):
f778fe
+    #     """
f778fe
+    #     fixes bz 1378107 (do not use master options as operations)
f778fe
+    #     """
f778fe
+    #     self.assert_effect(
f778fe
+    #         "resource create R ocf:heartbeat:Dummy state=a op monitor"
f778fe
+    #             " interval=10s --master is-managed=false --force"
f778fe
+    #             " --no-default-ops"
f778fe
+    #         ,
f778fe
+    #         """<resources>
f778fe
+    #             <master id="R-master">
f778fe
+    #                 
f778fe
+    #                     type="Dummy"
f778fe
+    #                 >
f778fe
+    #                     <instance_attributes id="R-instance_attributes">
f778fe
+    #                         
f778fe
+    #                             name="state" value="a"
f778fe
+    #                         />
f778fe
+    #                     </instance_attributes>
f778fe
+    #                     <operations>
f778fe
+    #                         
f778fe
+    #                             name="monitor"
f778fe
+    #                         />
f778fe
+    #                     </operations>
f778fe
+    #                 </primitive>
f778fe
+    #                 <meta_attributes id="R-master-meta_attributes">
f778fe
+    #                     
f778fe
+    #                         name="is-managed" value="false"
f778fe
+    #                 />
f778fe
+    #                 </meta_attributes>
f778fe
+    #             </master>
f778fe
+    #         </resources>"""
f778fe
+    #     )
f778fe
+
f778fe
+    def test_put_options_after_master_as_operation_opts__original_behaviour(
f778fe
+        self
f778fe
+    ):
f778fe
         """
f778fe
-        fixes bz 1378107 (do not use master options as operations)
f778fe
+        downstream temporary behaviour
f778fe
+        fixes bz 1458153
f778fe
         """
f778fe
         self.assert_effect(
f778fe
             "resource create R ocf:heartbeat:Dummy state=a op monitor"
f778fe
-                " interval=10s --master is-managed=false --force"
f778fe
+                " interval=10s --master timeout=3m --force"
f778fe
                 " --no-default-ops"
f778fe
             ,
f778fe
             """<resources>
a3a2ad
@@ -744,22 +825,53 @@ class SuccessMaster(ResourceTest):
f778fe
                         </instance_attributes>
f778fe
                         <operations>
f778fe
                             
f778fe
-                                name="monitor"
f778fe
+                                name="monitor" timeout="3m"
f778fe
                             />
f778fe
                         </operations>
f778fe
                     </primitive>
f778fe
-                    <meta_attributes id="R-master-meta_attributes">
f778fe
-                        
f778fe
-                            name="is-managed" value="false"
f778fe
-                    />
f778fe
-                    </meta_attributes>
f778fe
                 </master>
f778fe
             </resources>"""
f778fe
-        )
f778fe
-
f778fe
-    def test_do_not_steal_primitive_meta_options(self):
f778fe
+            ,
f778fe
+            output="Warning: flag '--master' is deprecated, use keyword"
f778fe
+                " 'master' instead (see the usage)\n"
f778fe
+        )
f778fe
+
f778fe
+    # def test_do_not_steal_primitive_meta_options(self):
f778fe
+    #     """
f778fe
+    #     fixes bz 1378107
f778fe
+    #     """
f778fe
+    #     self.assert_effect(
f778fe
+    #         "resource create R ocf:heartbeat:Dummy meta a=b --master b=c"
f778fe
+    #             " --no-default-ops"
f778fe
+    #         ,
f778fe
+    #         """<resources>
f778fe
+    #             <master id="R-master">
f778fe
+    #                 
f778fe
+    #                     type="Dummy"
f778fe
+    #                 >
f778fe
+    #                     <meta_attributes id="R-meta_attributes">
f778fe
+    #                         
f778fe
+    #                             value="b"
f778fe
+    #                         />
f778fe
+    #                     </meta_attributes>
f778fe
+    #                     <operations>
f778fe
+    #                         
f778fe
+    #                             name="monitor" timeout="20"
f778fe
+    #                         />
f778fe
+    #                     </operations>
f778fe
+    #                 </primitive>
f778fe
+    #                 <meta_attributes id="R-master-meta_attributes">
f778fe
+    #                     
f778fe
+    #                         value="c"
f778fe
+    #                     />
f778fe
+    #                 </meta_attributes>
f778fe
+    #             </master>
f778fe
+    #         </resources>"""
f778fe
+    #     )
f778fe
+    def test_steals_primitive_meta_options__original_behaviour(self):
f778fe
         """
f778fe
-        fixes bz 1378107
f778fe
+        downstream temporary behaviour
f778fe
+        fixes bz 1458153
f778fe
         """
f778fe
         self.assert_effect(
f778fe
             "resource create R ocf:heartbeat:Dummy meta a=b --master b=c"
a3a2ad
@@ -770,11 +882,6 @@ class SuccessMaster(ResourceTest):
f778fe
                     
f778fe
                         type="Dummy"
f778fe
                     >
f778fe
-                        <meta_attributes id="R-meta_attributes">
f778fe
-                            
f778fe
-                                value="b"
f778fe
-                            />
f778fe
-                        </meta_attributes>
f778fe
                         <operations>
f778fe
                             
f778fe
                                 name="monitor" timeout="20"
a3a2ad
@@ -782,18 +889,24 @@ class SuccessMaster(ResourceTest):
f778fe
                         </operations>
f778fe
                     </primitive>
f778fe
                     <meta_attributes id="R-master-meta_attributes">
f778fe
+                        
f778fe
+                            value="b"
f778fe
+                        />
f778fe
                         
f778fe
                             value="c"
f778fe
                         />
f778fe
                     </meta_attributes>
f778fe
                 </master>
f778fe
             </resources>"""
f778fe
+            ,
f778fe
+            output="Warning: flag '--master' is deprecated, use keyword"
f778fe
+                " 'master' instead (see the usage)\n"
f778fe
         )
f778fe
 
f778fe
     def test_takes_master_meta_attributes(self):
f778fe
         self.assert_effect(
f778fe
             "resource create --no-default-ops R ocf:heartbeat:IPaddr2"
f778fe
-                " ip=192.168.0.99 --master cidr_netmask=32"
f778fe
+                " ip=192.168.0.99 master cidr_netmask=32"
f778fe
             ,
f778fe
             """<resources>
f778fe
                 <master id="R-master">
a3a2ad
@@ -1041,7 +1154,7 @@ class FailOrWarn(ResourceTest):
f778fe
     def test_error_master_clone_combination(self):
f778fe
         self.assert_pcs_fail(
f778fe
             "resource create R ocf:heartbeat:Dummy --no-default-ops --clone"
f778fe
-                " --master"
f778fe
+                " master"
f778fe
             ,
f778fe
             "Error: you can specify only one of clone, master, bundle or"
f778fe
                 " --group\n"
a3a2ad
@@ -1049,7 +1162,7 @@ class FailOrWarn(ResourceTest):
f778fe
 
f778fe
     def test_error_master_group_combination(self):
f778fe
         self.assert_pcs_fail(
f778fe
-            "resource create R ocf:heartbeat:Dummy --no-default-ops --master"
f778fe
+            "resource create R ocf:heartbeat:Dummy --no-default-ops master"
f778fe
                 " --group G"
f778fe
             ,
f778fe
             "Error: you can specify only one of clone, master, bundle or"
a3a2ad
@@ -1067,7 +1180,7 @@ class FailOrWarn(ResourceTest):
f778fe
 
f778fe
     def test_error_bundle_master_combination(self):
f778fe
         self.assert_pcs_fail(
f778fe
-            "resource create R ocf:heartbeat:Dummy --no-default-ops --master"
f778fe
+            "resource create R ocf:heartbeat:Dummy --no-default-ops master"
f778fe
                 " bundle bundle_id"
f778fe
             ,
f778fe
             "Error: you can specify only one of clone, master, bundle or"
f778fe
diff --git a/pcs/test/test_constraints.py b/pcs/test/test_constraints.py
a3a2ad
index 9f0bc5d6..f5973410 100644
f778fe
--- a/pcs/test/test_constraints.py
f778fe
+++ b/pcs/test/test_constraints.py
a3a2ad
@@ -346,43 +346,43 @@ Ticket Constraints:
f778fe
 
f778fe
     def testColocationConstraints(self):
f778fe
         # see also BundleColocation
f778fe
-        line = "resource create M1 ocf:heartbeat:Dummy --master"
f778fe
+        line = "resource create M1 ocf:heartbeat:Dummy master"
f778fe
         output, returnVal = pcs(temp_cib, line)
f778fe
         assert returnVal == 0 and output == ""
f778fe
 
f778fe
-        line = "resource create M2 ocf:heartbeat:Dummy --master"
f778fe
+        line = "resource create M2 ocf:heartbeat:Dummy master"
f778fe
         output, returnVal = pcs(temp_cib, line)
f778fe
         assert returnVal == 0 and output == ""
f778fe
 
f778fe
-        line = "resource create M3 ocf:heartbeat:Dummy --master"
f778fe
+        line = "resource create M3 ocf:heartbeat:Dummy master"
f778fe
         output, returnVal = pcs(temp_cib, line)
f778fe
         assert returnVal == 0 and output == "",[returnVal, output]
f778fe
 
f778fe
-        line = "resource create M4 ocf:heartbeat:Dummy --master"
f778fe
+        line = "resource create M4 ocf:heartbeat:Dummy master"
f778fe
         output, returnVal = pcs(temp_cib, line)
f778fe
         assert returnVal == 0 and output == "",[returnVal, output]
f778fe
 
f778fe
-        line = "resource create M5 ocf:heartbeat:Dummy --master"
f778fe
+        line = "resource create M5 ocf:heartbeat:Dummy master"
f778fe
         output, returnVal = pcs(temp_cib, line)
f778fe
         assert returnVal == 0 and output == "",[returnVal, output]
f778fe
 
f778fe
-        line = "resource create M6 ocf:heartbeat:Dummy --master"
f778fe
+        line = "resource create M6 ocf:heartbeat:Dummy master"
f778fe
         output, returnVal = pcs(temp_cib, line)
f778fe
         assert returnVal == 0 and output == "",[returnVal, output]
f778fe
 
f778fe
-        line = "resource create M7 ocf:heartbeat:Dummy --master"
f778fe
+        line = "resource create M7 ocf:heartbeat:Dummy master"
f778fe
         output, returnVal = pcs(temp_cib, line)
f778fe
         assert returnVal == 0 and output == "",[returnVal, output]
f778fe
 
f778fe
-        line = "resource create M8 ocf:heartbeat:Dummy --master"
f778fe
+        line = "resource create M8 ocf:heartbeat:Dummy master"
f778fe
         output, returnVal = pcs(temp_cib, line)
f778fe
         assert returnVal == 0 and output == "",[returnVal, output]
f778fe
 
f778fe
-        line = "resource create M9 ocf:heartbeat:Dummy --master"
f778fe
+        line = "resource create M9 ocf:heartbeat:Dummy master"
f778fe
         output, returnVal = pcs(temp_cib, line)
f778fe
         assert returnVal == 0 and output == "",[returnVal, output]
f778fe
 
f778fe
-        line = "resource create M10 ocf:heartbeat:Dummy --master"
f778fe
+        line = "resource create M10 ocf:heartbeat:Dummy master"
f778fe
         output, returnVal = pcs(temp_cib, line)
f778fe
         assert returnVal == 0 and output == ""
f778fe
 
f778fe
@@ -929,7 +929,7 @@ Ticket Constraints:
f778fe
         assert returnVal == 1
f778fe
 
f778fe
     def testLocationBadRules(self):
f778fe
-        o,r = pcs("resource create stateful0 ocf:heartbeat:Dummy --master")
f778fe
+        o,r = pcs("resource create stateful0 ocf:heartbeat:Dummy master")
f778fe
         ac(o,"")
f778fe
         assert r == 0
f778fe
 
f778fe
@@ -950,7 +950,7 @@ Ticket Constraints:
f778fe
 """)
f778fe
         assert r == 0
f778fe
 
f778fe
-        o,r = pcs("resource create stateful1 ocf:heartbeat:Dummy --master")
f778fe
+        o,r = pcs("resource create stateful1 ocf:heartbeat:Dummy master")
f778fe
         ac(o,"")
f778fe
         assert r == 0
f778fe
 
f778fe
@@ -989,7 +989,7 @@ Ticket Constraints:
f778fe
         ac(o,"")
f778fe
         assert r == 0
f778fe
 
f778fe
-        o,r = pcs("resource create stateful1 ocf:pacemaker:Stateful --master")
f778fe
+        o,r = pcs("resource create stateful1 ocf:pacemaker:Stateful master")
f778fe
         ac(o, """\
f778fe
 Warning: changing a monitor operation interval from 10 to 11 to make the operation unique
f778fe
 """)
f778fe
@@ -1110,7 +1110,7 @@ Ticket Constraints:
f778fe
         self.assertEqual(0, returnVal)
f778fe
 
f778fe
         output, returnVal = pcs(
f778fe
-            "resource create stateful1 ocf:pacemaker:Stateful --master"
f778fe
+            "resource create stateful1 ocf:pacemaker:Stateful master"
f778fe
         )
f778fe
         ac(output, """\
f778fe
 Warning: changing a monitor operation interval from 10 to 11 to make the operation unique
f778fe
diff --git a/pcs/test/test_resource.py b/pcs/test/test_resource.py
a3a2ad
index bd596f64..d8f68c12 100644
f778fe
--- a/pcs/test/test_resource.py
f778fe
+++ b/pcs/test/test_resource.py
a3a2ad
@@ -2826,7 +2826,7 @@ Ticket Constraints:
f778fe
 
f778fe
         output, returnVal  = pcs(
f778fe
             temp_cib,
f778fe
-            "resource create --no-default-ops D2 ocf:heartbeat:Dummy --master"
f778fe
+            "resource create --no-default-ops D2 ocf:heartbeat:Dummy master"
f778fe
         )
f778fe
         assert returnVal == 0
f778fe
         assert output == "", [output]
a3a2ad
@@ -2919,7 +2919,7 @@ Warning: changing a monitor operation interval from 10 to 11 to make the operati
f778fe
         ac(o,"")
f778fe
         assert r == 0
f778fe
 
f778fe
-        o,r = pcs("resource create D3 ocf:heartbeat:Dummy --master")
f778fe
+        o,r = pcs("resource create D3 ocf:heartbeat:Dummy master")
f778fe
         ac(o,"")
f778fe
         assert r == 0
f778fe
 
a3a2ad
@@ -3133,7 +3133,7 @@ Warning: changing a monitor operation interval from 10 to 11 to make the operati
f778fe
 
f778fe
         output, returnVal = pcs(
f778fe
             temp_cib,
f778fe
-            "resource create --no-default-ops dummy ocf:heartbeat:Dummy --master"
f778fe
+            "resource create --no-default-ops dummy ocf:heartbeat:Dummy master"
f778fe
         )
f778fe
         ac(output, "")
f778fe
         self.assertEqual(0, returnVal)
a3a2ad
@@ -3727,7 +3727,7 @@ Error: Cannot remove more than one resource from cloned group
f778fe
         # However those test the pcs library. I'm leaving these tests here to
f778fe
         # test the cli part for now.
f778fe
         self.assert_pcs_success(
f778fe
-            "resource create --no-default-ops dummy ocf:pacemaker:Stateful --master",
f778fe
+            "resource create --no-default-ops dummy ocf:pacemaker:Stateful master",
f778fe
             "Warning: changing a monitor operation interval from 10 to 11 to make the operation unique\n"
f778fe
         )
f778fe
 
a3a2ad
@@ -4761,7 +4761,7 @@ class CloneMasterUpdate(unittest.TestCase, AssertPcsMixin):
f778fe
 
f778fe
     def test_no_op_allowed_in_master_update(self):
f778fe
         self.assert_pcs_success(
f778fe
-            "resource create dummy ocf:heartbeat:Dummy --master"
f778fe
+            "resource create dummy ocf:heartbeat:Dummy master"
f778fe
         )
f778fe
         self.assert_pcs_success("resource show dummy-master", outdent(
f778fe
             """\
f778fe
diff --git a/pcs/utils.py b/pcs/utils.py
a3a2ad
index 5b608239..9b46810f 100644
f778fe
--- a/pcs/utils.py
f778fe
+++ b/pcs/utils.py
a3a2ad
@@ -2861,6 +2861,13 @@ def get_modificators():
f778fe
         "start": "--start" in pcs_options,
f778fe
         "wait": pcs_options.get("--wait", False),
f778fe
         "watchdog": pcs_options.get("--watchdog", []),
f778fe
+
f778fe
+        #This is for `pcs resource create`. Fix of the bug
f778fe
+        #https://bugzilla.redhat.com/show_bug.cgi?id=1378107
f778fe
+        #caused problems in openstack which uses `pcs resource create`
f778fe
+        #see https://bugzilla.redhat.com/show_bug.cgi?id=1458153
f778fe
+        #so we give back the original misbehavior of master here temporarily.
f778fe
+        "master": "--master" in pcs_options,
f778fe
     }
f778fe
 
f778fe
 def exit_on_cmdline_input_errror(error, main_name, usage_name):
f778fe
-- 
a3a2ad
2.13.6
f778fe