summaryrefslogtreecommitdiffstats
path: root/ipatests/ipa-run-tests
blob: 2b61d3c87cea728377441d3ab305a3433ed859a9 (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
#!/usr/bin/python

# Authors:
#   Petr Viktorin <pviktori@redhat.com>
#   Jason Gerard DeRose <jderose@redhat.com>
#
# Copyright (C) 2008-2013  Red Hat
# see file 'COPYING' for use and warranty information
#
# 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/>.

"""Nose wrapper for running an installed (not in-tree) IPA test suite

Any command-line arguments are passed directly to Nose.
Note that any relative paths given will be based on the ipatests module's path
"""

import sys
import os
from os import path
import logging

import nose

from ipapython.ipa_log_manager import log_mgr
import ipatests
from ipatests.beakerlib_plugin import BeakerLibPlugin
from ipatests.order_plugin import OrderTests

cmd = [
    sys.argv[0],
    '--with-doctest',
    '--doctest-tests',
    '--with-ordered-tests',
    '--exclude=plugins',
    '--nologcapture',
    '--logging-filter=-paramiko',
    '--where', os.path.dirname(ipatests.__file__),
]
cmd += sys.argv[1:]


# This must be set so ipalib.api gets initialized property for tests:
os.environ['IPA_UNIT_TEST_MODE'] = 'cli_test'


# Forward IPA logging to a normal Python logger. Nose's logcapture plugin
# can't work with IPA-managed loggers
class LogHandler(logging.Handler):
    name = 'forwarding log handler'
    logger = logging.getLogger('IPA')

    def emit(self, record):
        self.logger.log(record.levelno, self.format(record))

if 'console' in log_mgr.handlers:
    log_mgr.remove_handler('console')
log_mgr.configure(
    {
        'default_level': 'DEBUG',
        'handlers': [{'log_handler': LogHandler(),
                      'format': '[%(name)s] %(message)s',
                      'level': 'debug'},
                     {'level': 'debug',
                      'name': 'console',
                      'stream': sys.stderr}]},
    configure_state='tests')


nose.main(argv=cmd, addplugins=[BeakerLibPlugin(), OrderTests()])