Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/tests/sugar/shell.py
blob: 255786e74f589dc01d4f24575f983612eb083dcb (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
94
import logging
import sys
import time
import traceback

import tree

ACTIVITIES_WITH_OBJECT_CHOOSER = ["Read"]


def build_activities_list():
    root = tree.get_root()
    shell = root.find_child(name="main.py", 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="main.py", 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="main.py", 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