File: run_tests.py

package info (click to toggle)
mysql-query-browser 1.2.5beta-3
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 63,792 kB
  • ctags: 46,485
  • sloc: pascal: 249,299; ansic: 80,111; cpp: 72,467; sh: 25,271; objc: 20,015; yacc: 10,755; java: 9,917; xml: 4,580; php: 2,806; python: 1,566; sql: 1,563; makefile: 1,452; perl: 3
file content (45 lines) | stat: -rwxr-xr-x 961 bytes parent folder | download | duplicates (4)
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
#!/usr/bin/python

import time
import sys
import os
import signal


timeout=int(sys.argv[1])

args=["./test_all", "--host=gui-srva", "--port=1111"]+sys.argv[1:]

pid= os.spawnv(os.P_NOWAIT, args[0], args)

TEST_STATUS=None


print time.ctime()+": waiting for command for %i seconds..."%timeout
c= 0
while c < timeout:
    p, s= os.waitpid(pid, os.WNOHANG)
    if p != 0:
        break

    time.sleep(1)
    c+= 1

if c == timeout:
    print time.ctime()+": test program has timedout. Killing process..."
    TEST_STATUS=False
    os.kill(pid, signal.SIGTERM)
else:
    if os.WIFSIGNALED(s):
        print time.ctime()+": test program terminated with signal", os.WTERMSIG(s)
        TEST_STATUS=False
    else:
        print time.ctime()+": test program finished with status", os.WEXITSTATUS(s)
        TEST_STATUS=s==0

if not TEST_STATUS:
    print "::The test suite has FAILED."
    sys.exit(1)
else:
    print "::The test suite has PASSED."
    sys.exit(0)