[Pacemaker] Patch for bugzilla 2541: Shell should warn if parameter uniqueness is violated

Holger Teutsch holger.teutsch at web.de
Thu Mar 10 19:08:20 CET 2011


Hi Dejan,
On Thu, 2011-03-10 at 10:14 +0100, Dejan Muhamedagic wrote:
> Hi Holger,
> 
> On Wed, Mar 09, 2011 at 07:58:02PM +0100, Holger Teutsch wrote:
> > Hi Dejan,
> > 
> > On Wed, 2011-03-09 at 14:00 +0100, Dejan Muhamedagic wrote:
> > > Hi Holger,
> > 

> > 
> > In order to show the intention of the arguments clearer:
> > 
> > Instead of
> > 
> >     def _verify(self, set_obj_semantic, set_obj_all = None):
> >         if not set_obj_all:
> >             set_obj_all = set_obj_semantic
> >         rc1 = set_obj_all.verify()
> >         if user_prefs.check_frequency != "never":
> >             rc2 = set_obj_semantic.semantic_check(set_obj_all)
> >         else:
> >             rc2 = 0
> >         return rc1 and rc2 <= 1
> >     def verify(self,cmd):
> >         "usage: verify"
> >         if not cib_factory.is_cib_sane():
> >             return False
> >         return self._verify(mkset_obj("xml"))
> > 
> > This way (always passing both args):
> > 
> >     def _verify(self, set_obj_semantic, set_obj_all):
> >         rc1 = set_obj_all.verify()
> >         if user_prefs.check_frequency != "never":
> >             rc2 = set_obj_semantic.semantic_check(set_obj_all)
> >         else:
> >             rc2 = 0
> >         return rc1 and rc2 <= 1
> >     def verify(self,cmd):
> >         "usage: verify"
> >         if not cib_factory.is_cib_sane():
> >             return False
> > 	set_obj_all = mkset_obj("xml")
> >         return self._verify(set_obj_all, set_obj_all)

See patch set_obj_all.diff

> 
> > > My only remaining concern is performance. Though the meta-data is
> > > cached, perhaps it will pay off to save the RAInfo instance with
> > > the element. But we can worry about that later.
> > > 
> > 
> > I can work on this as next step.
> 
> I'll do some testing on really big configurations and try to
> gauge the impact.

OK

> 
> The patch makes some regression tests blow:
> 
> +  File "/usr/lib64/python2.6/site-packages/crm/ui.py", line 1441, in verify
> +    return self._verify(mkset_obj("xml"))
> +  File "/usr/lib64/python2.6/site-packages/crm/ui.py", line 1433, in _verify
> +    rc2 = set_obj_semantic.semantic_check(set_obj_all)
> +  File "/usr/lib64/python2.6/site-packages/crm/cibconfig.py", line 294, in semantic_check
> +    rc = self.__check_unique_clash(set_obj_all)
> +  File "/usr/lib64/python2.6/site-packages/crm/cibconfig.py", line 274, in __check_unique_clash
> +    process_primitive(node, clash_dict)
> +  File "/usr/lib64/python2.6/site-packages/crm/cibconfig.py", line 259, in process_primitive
> +    if ra_params[ name ]['unique'] == '1':
> +KeyError: 'OCF_CHECK_LEVEL'
> 
> Can't recall why OCF_CHECK_LEVEL appears here. There must be some
> good explanation :)

The good explanation is: Not only params are in <instance_atributes ...>
but OCF_CHECK_LEVEL as well within <operations ...>

The latest version no longer blows the test -> semantic_check.diff

Regards
Holger
-------------- next part --------------
A non-text attachment was scrubbed...
Name: set_obj_all.diff
Type: text/x-patch
Size: 2047 bytes
Desc: not available
URL: <http://oss.clusterlabs.org/pipermail/pacemaker/attachments/20110310/efb7efd5/attachment-0002.bin>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: semantic_check.diff
Type: text/x-patch
Size: 3391 bytes
Desc: not available
URL: <http://oss.clusterlabs.org/pipermail/pacemaker/attachments/20110310/efb7efd5/attachment-0003.bin>


More information about the Pacemaker mailing list