From 4739570e4543e9cb2cb429fcf4a7bb3d5e05a0ce Mon Sep 17 00:00:00 2001 From: Marcel Holtmann Date: Sat, 24 Nov 2012 19:14:27 +0100 Subject: test: Allow DisplayText to be interrupted by incoming calls --- test/test-stk-menu | 32 ++++++++++++++++++++++++++------ 1 file changed, 26 insertions(+), 6 deletions(-) (limited to 'test') diff --git a/test/test-stk-menu b/test/test-stk-menu index 215b0bc6..d3f3ad81 100755 --- a/test/test-stk-menu +++ b/test/test-stk-menu @@ -22,10 +22,23 @@ class Busy(dbus.DBusException): class StkAgent(dbus.service.Object): exit_on_release = True + timeout_id = 0 + timeout_reply_handler = None def set_exit_on_release(self, exit_on_release): self.exit_on_release = exit_on_release + def timeout_callback(self): + self.timeout_id = 0 + self.timeout_reply_handler() + return False + + def call_added(self, path, properties): + print "call added %s" % (path) + if (self.timeout_id > 0): + gobject.source_remove(self.timeout_id) + self.timeout_callback() + @dbus.service.method("org.ofono.SimToolkitAgent", in_signature="", out_signature="") def Release(self): @@ -80,7 +93,9 @@ class StkAgent(dbus.service.Object): if (seconds > 0): print "Waiting for %d seconds" % (seconds) - gobject.timeout_add_seconds(seconds, lambda: reply_func()) + self.timeout_reply_handler = reply_func + self.timeout_id = gobject.timeout_add_seconds(seconds, + self.timeout_callback) @dbus.service.method("org.ofono.SimToolkitAgent", in_signature="sysyyb", out_signature="s") @@ -285,11 +300,12 @@ if __name__ == '__main__': modems = manager.GetModems() for path, properties in modems: - if "org.ofono.SimToolkit" not in properties["Interfaces"]: - continue - - stk = dbus.Interface(bus.get_object('org.ofono', path), - 'org.ofono.SimToolkit') + if "org.ofono.SimToolkit" in properties["Interfaces"]: + stk = dbus.Interface(bus.get_object('org.ofono', path), + 'org.ofono.SimToolkit') + if "org.ofono.VoiceCallManager" in properties["Interfaces"]: + vcm = dbus.Interface(bus.get_object('org.ofono', path), + 'org.ofono.VoiceCallManager') stk.connect_to_signal("PropertyChanged", property_changed) @@ -311,12 +327,16 @@ if __name__ == '__main__': path = "/test/agent" agent = StkAgent(bus, path) + vcm.connect_to_signal("CallAdded", agent.call_added) + select = int(raw_input("Enter Selection: ")) stk.SelectItem(select, path) elif mode == 'agent': path = "/test/agent" agent = StkAgent(bus, path) + vcm.connect_to_signal("CallAdded", agent.call_added) + stk.RegisterAgent(path) print "Default Agent registered - Waiting for STK command..." -- cgit v1.2.3