sources for conftesthandle.py [rev. unknown]
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
import py
defaultconftestpath = py.magic.autopath().dirpath('defaultconftest.py')
class Conftest(object):
    """ the single place for accessing values and interacting 
        towards conftest modules from py.test objects. 
        Note that triggering Conftest instances to import 
        conftest.py files may result in added cmdline options. 
        XXX
    """ 
    def __init__(self, path=None):
        self._path2confmods = {}
        if path is not None:
            self.setinitial([path])
    def setinitial(self, args):
        """ return a Conftest object initialized with a path obtained
            from looking at the first (usually cmdline) argument that points
            to an existing file object. 
            XXX note: conftest files may add command line options
            and we thus have no completely safe way of determining
            which parts of the arguments are actually related to options. 
        """
        current = py.path.local()
        for arg in args + [current]:
            anchor = current.join(arg, abs=1)
            if anchor.check(): # we found some file object 
                #print >>py.std.sys.stderr, "initializing conftest from", anchor
                # conftest-lookups without a path actually mean 
                # lookups with our initial path. 
                self._path2confmods[None] = self.getconftestmodules(anchor)
                #print " -> ", conftest._path2confmods
                break
    def getconftestmodules(self, path):
        """ return a list of imported conftest modules for the given path.  """ 
        try:
            clist = self._path2confmods[path]
        except KeyError:
            dp = path.dirpath()
            if dp == path: 
                return [importconfig(defaultconftestpath)]
            clist = self.getconftestmodules(dp)
            conftestpath = path.join("conftest.py")
            if conftestpath.check(file=1):
                clist.append(importconfig(conftestpath))
            self._path2confmods[path] = clist
        # be defensive: avoid changes from caller side to
        # affect us by always returning a copy of the actual list 
        return clist[:]
    def rget(self, name, path=None):
        mod, value = self.rget_with_confmod(name, path)
        return value
    def rget_with_confmod(self, name, path=None):
        modules = self.getconftestmodules(path)
        modules.reverse()
        for mod in modules:
            try:
                return mod, getattr(mod, name)
            except AttributeError:
                continue
        raise KeyError, name
def importconfig(configpath):
    # We could have used caching here, but it's redundant since
    # they're cached on path anyway, so we use it only when doing rget_path
    assert configpath.check(), configpath
    if not configpath.dirpath('__init__.py').check(file=1): 
        # HACK: we don't want any "globally" imported conftest.py, 
        #       prone to conflicts and subtle problems 
        modname = str(configpath).replace('.', configpath.sep)
        mod = configpath.pyimport(modname=modname)
    else:
        mod = configpath.pyimport()
    return mod