~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/test_setup.py

  • Committer: Alexander Belchenko
  • Date: 2006-07-31 16:12:57 UTC
  • mto: (1711.2.111 jam-integration)
  • mto: This revision was merged to the branch mainline in revision 1906.
  • Revision ID: bialix@ukr.net-20060731161257-91a231523255332c
new official bzr.ico

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005, 2006 Canonical Ltd
 
1
# Copyright (C) 2005, 2006 by Canonical Ltd
2
2
#
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
14
14
# along with this program; if not, write to the Free Software
15
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
16
 
17
 
"""Test for setup.py build process"""
 
17
""" test for setup.py build process """
18
18
 
19
19
import os
20
20
import sys
21
21
import subprocess
22
22
import shutil
23
 
import tempfile
24
23
from tempfile import TemporaryFile
25
24
 
26
 
import bzrlib
27
 
from bzrlib.tests import TestCase, TestSkipped
 
25
from bzrlib.tests import TestCase
28
26
import bzrlib.osutils as osutils
29
27
 
30
 
# XXX: This clobbers the build directory in the real source tree; it'd be nice
31
 
# to avoid that.
32
 
#
33
 
# TODO: Run bzr from the installed copy to see if it works.  Really we need to
34
 
# run something that exercises every module, just starting it may not detect
35
 
# some missing modules.
36
 
#
37
 
# TODO: Check that the version numbers are in sync.  (Or avoid this...)
 
28
# TODO: ideally run this in a separate directory, so as not to clobber the
 
29
# real build directory
38
30
 
39
31
class TestSetup(TestCase):
40
32
 
41
 
    def test_build_and_install(self):
 
33
    def test_build(self):
42
34
        """ test cmd `python setup.py build`
43
35
 
44
36
        This tests that the build process and man generator run correctly.
45
37
        It also can catch new subdirectories that weren't added to setup.py.
46
38
        """
47
 
        if not os.path.isfile('setup.py'):
48
 
            raise TestSkipped('There is no setup.py file in current directory')
49
 
        try:
50
 
            import distutils.sysconfig
51
 
            makefile_path = distutils.sysconfig.get_makefile_filename()
52
 
            if not os.path.exists(makefile_path):
53
 
                raise TestSkipped('You must have the python Makefile installed to run this test.'
54
 
                                  ' Usually this can be found by installing "python-dev"')
55
 
        except ImportError:
56
 
            raise TestSkipped('You must have distutils installed to run this test.'
57
 
                              ' Usually this can be found by installing "python-dev"')
58
39
        self.log('test_build running in %s' % os.getcwd())
59
 
        install_dir = tempfile.mkdtemp()
60
 
        # setup.py must be run from the root source directory, but the tests
61
 
        # are not necessarily invoked from there
62
 
        self.source_dir = os.path.dirname(os.path.dirname(bzrlib.__file__))
63
40
        try:
64
 
            self.run_setup(['clean'])
65
 
            # build is implied by install
66
 
            ## self.run_setup(['build'])
67
 
            self.run_setup(['install', '--prefix', install_dir])
68
 
            self.run_setup(['clean'])
 
41
            # run setup.py build as subproces and catch return code
 
42
            out_file = TemporaryFile()
 
43
            err_file = TemporaryFile()
 
44
            p = subprocess.Popen([sys.executable, 'setup.py', 'build'],
 
45
                                 stdout=out_file, stderr=err_file)
 
46
            s = p.communicate()
 
47
            self.assertEqual(0, p.returncode, '`python setup.py build` fails')
69
48
        finally:
70
 
            osutils.rmtree(install_dir)
71
 
 
72
 
    def run_setup(self, args):
73
 
        args = [sys.executable, './setup.py', ] + args
74
 
        self.log('source base directory: %s', self.source_dir)
75
 
        self.log('args: %r', args)
76
 
        p = subprocess.Popen(args,
77
 
                             cwd=self.source_dir,
78
 
                             stdout=self._log_file,
79
 
                             stderr=self._log_file,
80
 
                             )
81
 
        s = p.communicate()
82
 
        self.assertEqual(0, p.returncode,
83
 
                         'invocation of %r failed' % args)
 
49
            if os.path.exists('build'):
 
50
                osutils.rmtree(u'build')