Fixed incorrect MuranoPL names for some of Python-based methods
When method that was defined in Python get registered in MuranoPL it name changes according to yaql conventions (and thus report_error becomes reportError). However this translation was buggy because 1. It didn't respect dsl.name('name') decorator that was supposed to override default behavior 2. It didn't strip underscores from the right of the name as yaql usually does (that prevent from name collisions in Python) Because of those issues applications that relied on StatusReporter::report_error method became broken. This commit fixes both of the issues with name translation. Change-Id: I84d4bd4df1af5bbe150f89c096afd8c52ad3da1a Closes-Bug: #1493875
This commit is contained in:
parent
89403ed23f
commit
711e689408
@ -108,10 +108,15 @@ class MuranoPackage(dsl_types.MuranoPackage):
|
|||||||
method = getattr(cls, method_name)
|
method = getattr(cls, method_name)
|
||||||
if not inspect.ismethod(method):
|
if not inspect.ismethod(method):
|
||||||
continue
|
continue
|
||||||
m_class.add_method(
|
# TODO(slagun): update the code below to use yaql native
|
||||||
|
# method for this when https://review.openstack.org/#/c/220748/
|
||||||
|
# will get merged and Murano requirements bump to corresponding
|
||||||
|
# yaql version
|
||||||
|
method_name_alias = (getattr(
|
||||||
|
method, '__murano_name', None) or
|
||||||
yaql_integration.CONVENTION.convert_function_name(
|
yaql_integration.CONVENTION.convert_function_name(
|
||||||
method_name),
|
method_name.rstrip('_')))
|
||||||
method)
|
m_class.add_method(method_name_alias, method)
|
||||||
self._imported_types.add(cls)
|
self._imported_types.add(cls)
|
||||||
return m_class
|
return m_class
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user