~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/test_setup.py

  • Committer: Canonical.com Patch Queue Manager
  • Date: 2010-12-02 14:58:47 UTC
  • mfrom: (5554.1.3 trunk)
  • Revision ID: pqm@pqm.ubuntu.com-20101202145847-fw822sd3nyhvrwmi
(vila) Merge 2.2 into trunk including fix for bug #583667 and bug
        #681885 (Vincent Ladeuil)

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005, 2006, 2008-2011 Canonical Ltd
 
1
# Copyright (C) 2005, 2006, 2008, 2009, 2010 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
16
16
 
17
17
"""Test for setup.py build process"""
18
18
 
19
 
from distutils import version
20
19
import os
21
20
import sys
22
21
import subprocess
 
22
import shutil
 
23
from tempfile import TemporaryFile
23
24
 
24
25
import bzrlib
25
 
from bzrlib import tests
 
26
from bzrlib.tests import TestCase, TestSkipped
 
27
import bzrlib.osutils as osutils
26
28
 
 
29
# XXX: This clobbers the build directory in the real source tree; it'd be nice
 
30
# to avoid that.
 
31
#
27
32
# TODO: Run bzr from the installed copy to see if it works.  Really we need to
28
33
# run something that exercises every module, just starting it may not detect
29
34
# some missing modules.
30
35
#
31
36
# TODO: Check that the version numbers are in sync.  (Or avoid this...)
32
37
 
33
 
class TestSetup(tests.TestCaseInTempDir):
 
38
class TestSetup(TestCase):
34
39
 
35
40
    def test_build_and_install(self):
36
41
        """ test cmd `python setup.py build`
42
47
        # are not necessarily invoked from there
43
48
        self.source_dir = os.path.dirname(os.path.dirname(bzrlib.__file__))
44
49
        if not os.path.isfile(os.path.join(self.source_dir, 'setup.py')):
45
 
            self.skip(
 
50
            raise TestSkipped(
46
51
                'There is no setup.py file adjacent to the bzrlib directory')
47
52
        try:
48
53
            import distutils.sysconfig
49
54
            makefile_path = distutils.sysconfig.get_makefile_filename()
50
55
            if not os.path.exists(makefile_path):
51
 
                self.skip(
 
56
                raise TestSkipped(
52
57
                    'You must have the python Makefile installed to run this'
53
58
                    ' test. Usually this can be found by installing'
54
59
                    ' "python-dev"')
55
60
        except ImportError:
56
 
            self.skip(
 
61
            raise TestSkipped(
57
62
                'You must have distutils installed to run this test.'
58
63
                ' Usually this can be found by installing "python-dev"')
59
 
        self.log('test_build running from %s' % self.source_dir)
60
 
        build_dir = os.path.join(self.test_dir, "build")
61
 
        install_dir = os.path.join(self.test_dir, "install")
62
 
        self.run_setup([
63
 
            'build', '-b', build_dir,
64
 
            'install', '--root', install_dir])
65
 
        # Install layout is platform dependant
66
 
        self.assertPathExists(install_dir)
67
 
        self.run_setup(['clean', '-b', build_dir])
 
64
        self.log('test_build running in %s' % os.getcwd())
 
65
        root_dir = osutils.mkdtemp()
 
66
        try:
 
67
            self.run_setup(['clean'])
 
68
            # build is implied by install
 
69
            ## self.run_setup(['build'])
 
70
            self.run_setup(['install', '--root', root_dir])
 
71
            self.run_setup(['clean'])
 
72
        finally:
 
73
            osutils.rmtree(root_dir)
68
74
 
69
75
    def run_setup(self, args):
70
76
        args = [sys.executable, './setup.py', ] + args
80
86
        self.log('stderr: %r', stderr)
81
87
        self.assertEqual(0, p.returncode,
82
88
                         'invocation of %r failed' % args)
83
 
 
84
 
 
85
 
class TestDistutilsVersion(tests.TestCase):
86
 
 
87
 
    def test_version_with_string(self):
88
 
        # We really care about two pyrex specific versions and our ability to
89
 
        # detect them
90
 
        lv = version.LooseVersion
91
 
        self.assertTrue(lv("0.9.4.1") < lv('0.17.beta1'))
92
 
        self.assertTrue(lv("0.9.6.3") < lv('0.10'))