summaryrefslogtreecommitdiff
path: root/tests/estress/client.py
blob: f39b953bdbe48a9bb52a5aec8b054245e4165a05 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#!/usr/bin/env python2.5
#
# Copyright (C) 2009, Nokia <ivan.frade@nokia.com>
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
# 02110-1301, USA.
#

import gobject
import gtk
import time
import dbus
import getopt
import sys

TRACKER = 'org.freedesktop.Tracker1'
TRACKER_OBJ = '/org/freedesktop/Tracker1/Resources'

SPARQL_QUERY = """
    SELECT ?entry ?title ?date ?isRead WHERE {
      ?entry a nmo:FeedMessage ;
         nie:title ?title ;
         nie:contentLastModified ?date .
    OPTIONAL {
       ?entry nmo:isRead ?isRead.
    }
    } ORDER BY DESC(?date) LIMIT %s
"""

bus = dbus.SessionBus ()
obj = bus.get_object (TRACKER, TRACKER_OBJ)
iface = dbus.Interface (obj, "org.freedesktop.Tracker1.Resources")

def run_query ():
    start = time.time ()
    results = iface.SparqlQuery (SPARQL_QUERY % ("10"))
    end = time.time ()
    print int (time.time()), "%f" % (end - start)
    return True

def exit_cb ():
    sys.exit (0)

def usage ():
    print "Usage:"
    print "  client.py [OPTION...] - Run periodically a query on tracker"
    print ""
    print "Help Options:"
    print "  -h, --help             Show help options"
    print ""
    print "Application Options:"
    print "  -p, --period=NUM       Time (in sec) between queries"
    print "  -t, --timeout=NUM      Switch off the program after NUM seconds"
    print ""


if __name__ == "__main__":

    opts, args = getopt.getopt(sys.argv[1:],
                               "p:t:h",
                               ["period", "timeout", "help"])
    period = 1
    timeout = 0

    for o, a in opts:
        if o in ["-p", "--period"]:
            period = int (a)
        if o in ["-t", "--timeout"]:
            timeout = int (a)
        if o in ["-h", "--help"]:
            usage ()
            sys.exit (0)
            
    
    gobject.timeout_add (period * 1000, run_query)
    if (timeout > 0):
        gobject.timeout_add (timeout *1000, exit_cb)
    gtk.main ()