Welcome to mirror list, hosted at ThFree Co, Russian Federation.

run_desktop_tests.py - github.com/mapsme/omim.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: b94c31d074cf049135b348003242af7beb0a3ac3 (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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
#!/usr/bin/env python

"""
This script is mainly for running autotests on the build server, however, it 
can also be used by engineers to run the tests locally on their machines.

It takes as optional parameters the path to the folder containing the test 
executables (which must have names ending in _tests), and a list of tests that 
need to be skipped, this list must be comma separated and contain no spaces. E.g.:

./run_desktop_tests.py -f ./omim-build-release -e drape_tests,some_other_tests

The script outputs the console output of the tests. It also checks the error 
code of each test suite, and after all the tests are executed, it prints the 
list of the failed tests, passed tests, skipped tests and tests that could not 
be found, i.e. the tests that were specified in the skip list, but do not exist.
"""

from __future__ import print_function

import getopt
from os import listdir
from os.path import isfile, join
import os
import socket
import subprocess
import sys
import testserver
import urllib2


tests_path = ""
workspace_path = "./omim-build-release/out/release"
skiplist = []
logfile = "testlog.log"

PORT = 34568

def print_pretty(result, tests):
    if len(tests) == 0:
        return

    print("")
    print(result.upper())

    for test in tests:
        print("- {}".format(test))


def usage():
    print("""
Possbile options:

-h --help   : print this help

-f --folder : specify the folder where the tests reside (absolute path or relative to the location of this script)

-e --exclude: list of tests to exclude, comma separated, no spaces allowed

-o --output : resulting log file. Default testlog.log


Example

./run_desktop_tests.py -f /Users/Jenkins/Home/jobs/Multiplatform/workspace/omim-build-release/out/release -e drape_tests,some_other_tests -o my_log_file.log
""")


def set_global_vars():
    try:
        opts, args = getopt.getopt(sys.argv[1:], "he:f:o:",
                                   ["help", "exclude=", "folder=", "output="])
    except getopt.GetoptError as err:
        print(str(err))
        usage()
        sys.exit(2)

    for option, argument in opts:
        if option in ("-h", "--help"):
            usage()
            sys.exit()
        if option in ("-o", "--output"):
            global logfile
            logfile = argument
        elif option in ("-e", "--exclude"):
            exclude_tests = argument.split(",")
            for exclude_test in exclude_tests:
                global skiplist
                skiplist.append(exclude_test)
        elif option in ("-f", "--folder"):
            global workspace_path
            workspace_path = argument
        else:
            assert False, "unhandled option"


def start_server():
    server = testserver.TestServer()
    server.start_serving()


def stop_server():
    try:
        urllib2.urlopen('http://localhost:{port}/kill'.format(port=PORT), timeout=5)
    except (urllib2.URLError, socket.timeout):
        print("Failed to stop the server...")


def run_tests():
    tests_path = "{workspace_path}".format(workspace_path=workspace_path)

    failed = []
    passed = []
    skipped = []

    server = None
    for file in listdir(tests_path):

        if not file.endswith("_tests"):
            continue
        if file in skiplist:
            print("===== Skipping {} =====".format(file))
            skipped.append(file)
            continue

        if file == "platform_tests":
            start_server()
        
        process = subprocess.Popen("{tests_path}/{file} 2>> {logfile}".
                                   format(tests_path=tests_path, file=file, logfile=logfile),
            shell=True,
            stdout=subprocess.PIPE)

        process.wait()

        if file == "platform_tests":
            stop_server()

        if process.returncode > 0:
            failed.append(file)
        else:
            passed.append(file)

    return {"failed": failed, "passed": passed, "skipped": skipped}


def rm_log_file():
    try:
        os.remove(logfile)
    except OSError:
        pass


def main():
    set_global_vars()

    rm_log_file()
    
    results = run_tests()

    print_pretty("failed", results["failed"])
    print_pretty("skipped", results["skipped"])
    print_pretty("passed", results["passed"])

    not_found = filter(lambda x: x not in results["skipped"], skiplist)

    print_pretty("not found", not_found)


if (__name__ == "__main__"):
    main()