summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLuiz Augusto von Dentz <luiz.von.dentz@intel.com>2012-06-08 12:54:09 +0300
committerJohan Hedberg <johan.hedberg@intel.com>2012-06-10 11:32:04 +0300
commit7b0aa717c531cb359e71b253b5dec62cd7d79035 (patch)
tree73108e4b58597a91928dd06be234b70e0e0ae7b2
parentf95d221ce951cf6867559ad8fb6ae04abe363a3f (diff)
downloadobexd-7b0aa717c531cb359e71b253b5dec62cd7d79035.tar.gz
test: Add progress support to opp-client
Print transfer progress when verbose mode is enabled.
-rwxr-xr-xtest/opp-client33
1 files changed, 29 insertions, 4 deletions
diff --git a/test/opp-client b/test/opp-client
index b7e434c..3d23dfb 100755
--- a/test/opp-client
+++ b/test/opp-client
@@ -14,12 +14,16 @@ def parse_options():
help="Pull vcard and store in FILE", metavar="FILE")
parser.add_option("-s", "--send", dest="send_file",
help="Send FILE", metavar="FILE")
+ parser.add_option("-v", "--verbose", action="store_true",
+ dest="verbose")
return parser.parse_args()
class OppClient:
- def __init__(self, session_path):
+ def __init__(self, session_path, verbose=False):
+ self.progress = 0
self.transfer_path = None
+ self.verbose = verbose
bus = dbus.SessionBus()
obj = bus.get_object("org.bluez.obex.client", session_path)
self.session = dbus.Interface(obj, "org.bluez.obex.Session")
@@ -32,11 +36,18 @@ class OppClient:
dbus_interface="org.bluez.obex.Transfer",
signal_name="Error",
path_keyword="path")
+ if self.verbose:
+ bus.add_signal_receiver(self.transfer_progress,
+ dbus_interface="org.bluez.obex.Transfer",
+ signal_name="PropertyChanged",
+ path_keyword="path")
def create_transfer_reply(self, reply):
(path, properties) = reply
self.transfer_path = path
- print "Transfer created: %s" % path
+ self.transfer_size = properties["Size"]
+ if self.verbose:
+ print "Transfer created: %s" % path
def error(self, err):
print err
@@ -45,7 +56,8 @@ class OppClient:
def transfer_complete(self, path):
if path != self.transfer_path:
return
- print "Transfer finished"
+ if self.verbose:
+ print "Transfer finished"
mainloop.quit()
def transfer_error(self, code, message, path):
@@ -54,6 +66,19 @@ class OppClient:
print "Transfer finished with error %s: %s" % (code, message)
mainloop.quit()
+ def transfer_progress(self, prop, value, path):
+ if path != self.transfer_path:
+ return
+
+ if prop != "Progress":
+ return
+
+ speed = (value - self.progress) / 1000
+ print "Transfer progress %d/%d at %d kBps" % (value,
+ self.transfer_size,
+ speed)
+ self.progress = value
+
def pull_business_card(self, filename):
self.opp.PullBusinessCard(os.path.abspath(filename),
reply_handler=self.create_transfer_reply,
@@ -85,7 +110,7 @@ if __name__ == '__main__':
print "Creating Session"
path = client.CreateSession(options.device, { "Target": "OPP" })
- opp_client = OppClient(path)
+ opp_client = OppClient(path, options.verbose)
if options.pull_to_file:
opp_client.pull_business_card(options.pull_to_file)