File: coot_unittest.py

package info (click to toggle)
coot 1.1.18%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 219,964 kB
  • sloc: cpp: 495,934; python: 35,043; ansic: 26,143; lisp: 22,768; sh: 13,186; makefile: 2,746; awk: 441; xml: 245; csh: 14
file content (95 lines) | stat: -rw-r--r-- 3,144 bytes parent folder | download | duplicates (2)
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
#    coot_unittest.py
#    Copyright (C) 2007  Bernhard Lohkamp
#    Copyright (C) 2007, 2008  Bernhard Lohkamp, The University of York
#
#    This program is free software: you can redistribute it and/or modify
#    it under the terms of the GNU General Public License as published by
#    the Free Software Foundation, either version 3 of the License, or
#    (at your option) any later version.
#
#    This program is distributed in the hope that it will be useful,
#    but WITHOUT ANY WARRANTY; without even the implied warranty of
#    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
#    GNU General Public License for more details.
#
#    You should have received a copy of the GNU General Public License
#    along with this program.  If not, see <http://www.gnu.org/licenses/>.

import unittest, os
import inspect
import sys
import coot
import coot_utils

def get_this_dir():
    pass


# get directory of this file and execute tests found in this dir
fn = inspect.getfile(get_this_dir)
current_dir = os.path.dirname(fn)

# load_file = os.path.join(current_dir, "begin.py")
# load_file = os.path.normpath(load_file)
# if (os.path.isfile(load_file)):
#     exec(compile(open(load_file, "rb").read(), load_file, 'exec'), globals())

import coot_testing_utils # it used to be "begin.py" but that is not a good name now.

log = StreamIO(sys.stderr, sys.stdout)

result = unittest.TextTestRunner(stream=log, verbosity=2).run(suite)

if (unittest_output):
    print("\n")
    print(unittest_output.getvalue())
    unittest_output.close()
else:
    print("BL ERROR:: no unittest output")

if (have_test_skip):
    print("\nUnittest skip exists!")
    if (result.skipped):
        print("...with the following skipping message(s):")
        for skipped in result.skipped:
            print("   ", skipped[1])
        print("\n")
    else:
        print("No tests skipped")
else:
    print("\nUnitest skip does not exist!")
    if (skipped_tests):
        print("The following tests were skipped and marked as passed:")
        for test in skipped_tests:
            print("   ", test)
        print("\n")

# finish off closing all maps (maybe use end.py file?!)
list(map(coot.close_molecule, coot_utils.molecule_number_list()))

# some garbage collection. Not sure if this will really shed light into
# reference counting e.g.
print("\nFINALLY collect some GARBAGE\n")
import gc
import inspect
gc.enable()
gc.set_debug(gc.DEBUG_LEAK)
print("BL INFO:: no of collected carbage items %s\n" %gc.collect())
all_garbage = gc.garbage
print("BL DEBUG:: list of garbage items:\n")
for garb in all_garbage:
    print("    ", garb)
print("\nDetailed information for functions:\n")
for garb in all_garbage:
    if inspect.isfunction(garb) and not inspect.isbuiltin(garb):
        print("  BL INFO:: garbage item and location:")
        print("    %s" %garb)
        print("    %s" %gc.get_referents(garb)[0])
        print()

# cheating?! We only exit Coot if we are not in graphics mode
if (coot.use_graphics_interface_state() == 0):
    if (result.wasSuccessful()):
        coot.coot_real_exit(0)
    else:
        coot.coot_real_exit(1)