touch-packages team mailing list archive
-
touch-packages team
-
Mailing list archive
-
Message #11564
[Bug 1348399] Re: Autopilot does not honor the object cache when creating the root introspection object
** Changed in: autopilot
Status: Fix Committed => Fix Released
--
You received this bug notification because you are a member of Ubuntu
Touch seeded packages, which is subscribed to autopilot in Ubuntu.
https://bugs.launchpad.net/bugs/1348399
Title:
Autopilot does not honor the object cache when creating the root
introspection object
Status in Autopilot:
Fix Released
Status in “autopilot” package in Ubuntu:
Fix Released
Bug description:
Currently, if a user defines a custom proxy class for the node at the
root of the introspection tree, it does not get returned by the
launch_* methods.
The reason for this is that, in _search.py, the
_get_proxy_bases_from_introspection_xml does this:
---
def _get_proxy_bases_from_introspection_xml(introspection_xml):
bases = [ApplicationProxyObject]
---
and ApplicationProxyObject is defined (just a few lines further down)
as:
---
class ApplicationProxyObject(ap_dbus.DBusIntrospectionObject):
---
So, the root proxy object will never pick up any CPC's in the object
registry. To fix this, let's make ApplicationProxyObject a simple
mixin class:
---
class ApplicationProxyObject(object):
"""A class that better supports query data from an application."""
def __init__(self):
self._process = None
---
and then use the existing methods defined in
autopilot.introspection._object_registry to get the appropriate proxy
class:
---
def _get_proxy_bases_from_introspection_xml(introspection_xml):
bases = [ call_to_get_proxy_class(...), ApplicationProxyObject]
---
I'm too lazy to figure out what the exact call should be, but I'm sure
it exists in the _object_registry module. This will probably involve
changing the _get_proxy_bases_from_introspection_xml function to take
some additional parameters, or some refactoring to pass in the base
class.
The test case for this should be:
Write a simple Qml app script, and define a custom proxy class for the
root node. Assert that:
* When launching the app, we get an instance of the CPC, not a generated class.
* When calling the get_root_instance call on any other proxy object, we get an instance of the CPC, not a generated class.
To manage notifications about this bug go to:
https://bugs.launchpad.net/autopilot/+bug/1348399/+subscriptions