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
94
|
import logging
import sys
import time
import traceback
import tree
ACTIVITIES_WITH_OBJECT_CHOOSER = ["Read", "Jukebox"]
def build_activities_list():
root = tree.get_root()
shell = root.find_child(name="sugar-session", role_name="application")
activities = []
table = shell.find_child(role_name="table")
cells = table.find_children(role_name="table cell")
for row in [cells[i:i + 5] for i in range(0, len(cells), 5)]:
activity_name = row[2].text
activities.append(activity_name)
activities.sort()
return activities
def launch_and_stop_activity(activity_name):
logging.info("Launching %s" % activity_name)
root = tree.get_root()
shell = root.find_child(name="sugar-session", role_name="application")
table = shell.find_child(role_name="table")
cells = table.find_children(role_name="table cell")
for row in [cells[i:i + 5] for i in range(0, len(cells), 5)]:
name = row[2].name
icon = row[1]
if name == activity_name:
icon.do_action("activate")
logging.info("Stopping %s" % activity_name)
if activity_name in ACTIVITIES_WITH_OBJECT_CHOOSER:
close_button = shell.find_child(name="Close",
role_name="push button")
close_button.do_action("click")
activity = root.find_child(name="sugar-activity",
role_name="application")
stop_buttons = activity.find_children(name="Stop",
role_name="push button")
stop_buttons[-1].do_action("click")
activity = root.find_child(name="sugar-activity",
role_name="application",
expect_none=True)
if activity is not None:
raise RuntimeError
def go_to_list_view():
root = tree.get_root()
shell = root.find_child(name="sugar-session", role_name="application")
done_button = shell.find_child(name="Done", role_name="push button")
done_button.do_action("click")
radio_button = shell.find_child(name="List view", role_name="radio button")
radio_button.do_action("click")
def main():
format = "%(created)f %(message)s"
logging.basicConfig(format=format)
logging.root.setLevel(logging.DEBUG)
logging.info("Start test")
go_to_list_view()
for activity in build_activities_list():
launch_and_stop_activity(activity)
try:
main()
except:
logging.error(traceback.format_exc())
logging.error("\n%s" % tree.get_root().dump())
raise
|