File: run_tests.py

package info (click to toggle)
mysql-gui-tools 5.0r14%2BopenSUSE-2.1
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 116,956 kB
  • ctags: 48,715
  • sloc: sql: 341,918; pascal: 276,698; ansic: 91,020; cpp: 90,451; objc: 33,236; sh: 29,481; yacc: 10,756; xml: 10,589; java: 10,079; php: 2,806; python: 2,092; makefile: 1,783; perl: 4
file content (45 lines) | stat: -rw-r--r-- 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)