Show More
@@ -1338,13 +1338,13 b' class TestRunner(object):' | |||
|
1338 | 1338 | |
|
1339 | 1339 | def __init__(self): |
|
1340 | 1340 | self.options = None |
|
1341 | self.testdir = None | |
|
1342 | self.hgtmp = None | |
|
1343 | self.inst = None | |
|
1344 | self.bindir = None | |
|
1345 | self.tmpbinddir = None | |
|
1346 | self.pythondir = None | |
|
1347 | self.coveragefile = None | |
|
1341 | self._testdir = None | |
|
1342 | self._hgtmp = None | |
|
1343 | self._installdir = None | |
|
1344 | self._bindir = None | |
|
1345 | self._tmpbinddir = None | |
|
1346 | self._pythondir = None | |
|
1347 | self._coveragefile = None | |
|
1348 | 1348 | self._createdfiles = [] |
|
1349 | 1349 | self._hgpath = None |
|
1350 | 1350 | |
@@ -1382,7 +1382,7 b' class TestRunner(object):' | |||
|
1382 | 1382 | return val |
|
1383 | 1383 | tests.sort(key=sortkey) |
|
1384 | 1384 | |
|
1385 | self.testdir = os.environ['TESTDIR'] = os.getcwd() | |
|
1385 | self._testdir = os.environ['TESTDIR'] = os.getcwd() | |
|
1386 | 1386 | |
|
1387 | 1387 | if 'PYTHONHASHSEED' not in os.environ: |
|
1388 | 1388 | # use a random python hash seed all the time |
@@ -1412,41 +1412,41 b' class TestRunner(object):' | |||
|
1412 | 1412 | # in all lowercase, which causes troubles with paths (issue3490) |
|
1413 | 1413 | d = os.getenv('TMP') |
|
1414 | 1414 | tmpdir = tempfile.mkdtemp('', 'hgtests.', d) |
|
1415 | self.hgtmp = os.environ['HGTMP'] = os.path.realpath(tmpdir) | |
|
1415 | self._hgtmp = os.environ['HGTMP'] = os.path.realpath(tmpdir) | |
|
1416 | 1416 | |
|
1417 | 1417 | if self.options.with_hg: |
|
1418 | self.inst = None | |
|
1419 | self.bindir = os.path.dirname(os.path.realpath( | |
|
1418 | self._installdir = None | |
|
1419 | self._bindir = os.path.dirname(os.path.realpath( | |
|
1420 | 1420 | self.options.with_hg)) |
|
1421 | self.tmpbindir = os.path.join(self.hgtmp, 'install', 'bin') | |
|
1422 | os.makedirs(self.tmpbindir) | |
|
1421 | self._tmpbindir = os.path.join(self._hgtmp, 'install', 'bin') | |
|
1422 | os.makedirs(self._tmpbindir) | |
|
1423 | 1423 | |
|
1424 | 1424 | # This looks redundant with how Python initializes sys.path from |
|
1425 | 1425 | # the location of the script being executed. Needed because the |
|
1426 | 1426 | # "hg" specified by --with-hg is not the only Python script |
|
1427 | 1427 | # executed in the test suite that needs to import 'mercurial' |
|
1428 | 1428 | # ... which means it's not really redundant at all. |
|
1429 | self.pythondir = self.bindir | |
|
1429 | self._pythondir = self._bindir | |
|
1430 | 1430 | else: |
|
1431 | self.inst = os.path.join(self.hgtmp, "install") | |
|
1432 |
self.bindir = os.environ["BINDIR"] = |
|
|
1433 | "bin") | |
|
1434 | self.tmpbindir = self.bindir | |
|
1435 | self.pythondir = os.path.join(self.inst, "lib", "python") | |
|
1431 | self._installdir = os.path.join(self._hgtmp, "install") | |
|
1432 | self._bindir = os.environ["BINDIR"] = \ | |
|
1433 | os.path.join(self._installdir, "bin") | |
|
1434 | self._tmpbindir = self._bindir | |
|
1435 | self._pythondir = os.path.join(self._installdir, "lib", "python") | |
|
1436 | 1436 | |
|
1437 | os.environ["BINDIR"] = self.bindir | |
|
1437 | os.environ["BINDIR"] = self._bindir | |
|
1438 | 1438 | os.environ["PYTHON"] = PYTHON |
|
1439 | 1439 | |
|
1440 | path = [self.bindir] + os.environ["PATH"].split(os.pathsep) | |
|
1441 | if self.tmpbindir != self.bindir: | |
|
1442 | path = [self.tmpbindir] + path | |
|
1440 | path = [self._bindir] + os.environ["PATH"].split(os.pathsep) | |
|
1441 | if self._tmpbindir != self._bindir: | |
|
1442 | path = [self._tmpbindir] + path | |
|
1443 | 1443 | os.environ["PATH"] = os.pathsep.join(path) |
|
1444 | 1444 | |
|
1445 | 1445 | # Include TESTDIR in PYTHONPATH so that out-of-tree extensions |
|
1446 | 1446 | # can run .../tests/run-tests.py test-foo where test-foo |
|
1447 | 1447 | # adds an extension to HGRC. Also include run-test.py directory to |
|
1448 | 1448 | # import modules like heredoctest. |
|
1449 | pypath = [self.pythondir, self.testdir, | |
|
1449 | pypath = [self._pythondir, self._testdir, | |
|
1450 | 1450 | os.path.abspath(os.path.dirname(__file__))] |
|
1451 | 1451 | # We have to augment PYTHONPATH, rather than simply replacing |
|
1452 | 1452 | # it, in case external libraries are only available via current |
@@ -1457,10 +1457,10 b' class TestRunner(object):' | |||
|
1457 | 1457 | pypath.append(oldpypath) |
|
1458 | 1458 | os.environ[IMPL_PATH] = os.pathsep.join(pypath) |
|
1459 | 1459 | |
|
1460 | self.coveragefile = os.path.join(self.testdir, '.coverage') | |
|
1460 | self._coveragefile = os.path.join(self._testdir, '.coverage') | |
|
1461 | 1461 | |
|
1462 | vlog("# Using TESTDIR", self.testdir) | |
|
1463 | vlog("# Using HGTMP", self.hgtmp) | |
|
1462 | vlog("# Using TESTDIR", self._testdir) | |
|
1463 | vlog("# Using HGTMP", self._hgtmp) | |
|
1464 | 1464 | vlog("# Using PATH", os.environ["PATH"]) |
|
1465 | 1465 | vlog("# Using", IMPL_PATH, os.environ[IMPL_PATH]) |
|
1466 | 1466 | |
@@ -1491,7 +1491,7 b' class TestRunner(object):' | |||
|
1491 | 1491 | |
|
1492 | 1492 | def _runtests(self, tests): |
|
1493 | 1493 | try: |
|
1494 | if self.inst: | |
|
1494 | if self._installdir: | |
|
1495 | 1495 | self._installhg() |
|
1496 | 1496 | self._checkhglib("Testing") |
|
1497 | 1497 | else: |
@@ -1512,7 +1512,7 b' class TestRunner(object):' | |||
|
1512 | 1512 | failed = False |
|
1513 | 1513 | warned = False |
|
1514 | 1514 | |
|
1515 | suite = TestSuite(self.testdir, | |
|
1515 | suite = TestSuite(self._testdir, | |
|
1516 | 1516 | jobs=self.options.jobs, |
|
1517 | 1517 | whitelist=self.options.whitelisted, |
|
1518 | 1518 | blacklist=self.options.blacklist, |
@@ -1551,8 +1551,8 b' class TestRunner(object):' | |||
|
1551 | 1551 | testcls = cls |
|
1552 | 1552 | break |
|
1553 | 1553 | |
|
1554 | refpath = os.path.join(self.testdir, test) | |
|
1555 | tmpdir = os.path.join(self.hgtmp, 'child%d' % count) | |
|
1554 | refpath = os.path.join(self._testdir, test) | |
|
1555 | tmpdir = os.path.join(self._hgtmp, 'child%d' % count) | |
|
1556 | 1556 | |
|
1557 | 1557 | return testcls(refpath, tmpdir, |
|
1558 | 1558 | keeptmpdir=self.options.keep_tmpdir, |
@@ -1569,8 +1569,8 b' class TestRunner(object):' | |||
|
1569 | 1569 | if self.options.keep_tmpdir: |
|
1570 | 1570 | return |
|
1571 | 1571 | |
|
1572 | vlog("# Cleaning up HGTMP", self.hgtmp) | |
|
1573 | shutil.rmtree(self.hgtmp, True) | |
|
1572 | vlog("# Cleaning up HGTMP", self._hgtmp) | |
|
1573 | shutil.rmtree(self._hgtmp, True) | |
|
1574 | 1574 | for f in self._createdfiles: |
|
1575 | 1575 | try: |
|
1576 | 1576 | os.remove(f) |
@@ -1584,7 +1584,7 b' class TestRunner(object):' | |||
|
1584 | 1584 | if getattr(os, 'symlink', None): |
|
1585 | 1585 | vlog("# Making python executable in test path a symlink to '%s'" % |
|
1586 | 1586 | sys.executable) |
|
1587 | mypython = os.path.join(self.tmpbindir, pyexename) | |
|
1587 | mypython = os.path.join(self._tmpbindir, pyexename) | |
|
1588 | 1588 | try: |
|
1589 | 1589 | if os.readlink(mypython) == sys.executable: |
|
1590 | 1590 | return |
@@ -1640,9 +1640,9 b' class TestRunner(object):' | |||
|
1640 | 1640 | ' --install-scripts="%(bindir)s" %(nohome)s >%(logfile)s 2>&1' |
|
1641 | 1641 | % {'exe': sys.executable, 'py3': py3, 'pure': pure, |
|
1642 | 1642 | 'compiler': compiler, |
|
1643 | 'base': os.path.join(self.hgtmp, "build"), | |
|
1644 | 'prefix': self.inst, 'libdir': self.pythondir, | |
|
1645 | 'bindir': self.bindir, | |
|
1643 | 'base': os.path.join(self._hgtmp, "build"), | |
|
1644 | 'prefix': self._installdir, 'libdir': self._pythondir, | |
|
1645 | 'bindir': self._bindir, | |
|
1646 | 1646 | 'nohome': nohome, 'logfile': installerrs}) |
|
1647 | 1647 | vlog("# Running", cmd) |
|
1648 | 1648 | if os.system(cmd) == 0: |
@@ -1654,22 +1654,22 b' class TestRunner(object):' | |||
|
1654 | 1654 | print line, |
|
1655 | 1655 | f.close() |
|
1656 | 1656 | sys.exit(1) |
|
1657 | os.chdir(self.testdir) | |
|
1657 | os.chdir(self._testdir) | |
|
1658 | 1658 | |
|
1659 | 1659 | self._usecorrectpython() |
|
1660 | 1660 | |
|
1661 | 1661 | if self.options.py3k_warnings and not self.options.anycoverage: |
|
1662 | 1662 | vlog("# Updating hg command to enable Py3k Warnings switch") |
|
1663 | f = open(os.path.join(self.bindir, 'hg'), 'r') | |
|
1663 | f = open(os.path.join(self._bindir, 'hg'), 'r') | |
|
1664 | 1664 | lines = [line.rstrip() for line in f] |
|
1665 | 1665 | lines[0] += ' -3' |
|
1666 | 1666 | f.close() |
|
1667 | f = open(os.path.join(self.bindir, 'hg'), 'w') | |
|
1667 | f = open(os.path.join(self._bindir, 'hg'), 'w') | |
|
1668 | 1668 | for line in lines: |
|
1669 | 1669 | f.write(line + '\n') |
|
1670 | 1670 | f.close() |
|
1671 | 1671 | |
|
1672 | hgbat = os.path.join(self.bindir, 'hg.bat') | |
|
1672 | hgbat = os.path.join(self._bindir, 'hg.bat') | |
|
1673 | 1673 | if os.path.isfile(hgbat): |
|
1674 | 1674 | # hg.bat expects to be put in bin/scripts while run-tests.py |
|
1675 | 1675 | # installation layout put it in bin/ directly. Fix it |
@@ -1686,20 +1686,20 b' class TestRunner(object):' | |||
|
1686 | 1686 | print 'WARNING: cannot fix hg.bat reference to python.exe' |
|
1687 | 1687 | |
|
1688 | 1688 | if self.options.anycoverage: |
|
1689 | custom = os.path.join(self.testdir, 'sitecustomize.py') | |
|
1690 | target = os.path.join(self.pythondir, 'sitecustomize.py') | |
|
1689 | custom = os.path.join(self._testdir, 'sitecustomize.py') | |
|
1690 | target = os.path.join(self._pythondir, 'sitecustomize.py') | |
|
1691 | 1691 | vlog('# Installing coverage trigger to %s' % target) |
|
1692 | 1692 | shutil.copyfile(custom, target) |
|
1693 | rc = os.path.join(self.testdir, '.coveragerc') | |
|
1693 | rc = os.path.join(self._testdir, '.coveragerc') | |
|
1694 | 1694 | vlog('# Installing coverage rc to %s' % rc) |
|
1695 | 1695 | os.environ['COVERAGE_PROCESS_START'] = rc |
|
1696 | fn = os.path.join(self.inst, '..', '.coverage') | |
|
1696 | fn = os.path.join(self._installdir, '..', '.coverage') | |
|
1697 | 1697 | os.environ['COVERAGE_FILE'] = fn |
|
1698 | 1698 | |
|
1699 | 1699 | def _checkhglib(self, verb): |
|
1700 | 1700 | """Ensure that the 'mercurial' package imported by python is |
|
1701 | 1701 | the one we expect it to be. If not, print a warning to stderr.""" |
|
1702 | expecthg = os.path.join(self.pythondir, 'mercurial') | |
|
1702 | expecthg = os.path.join(self._pythondir, 'mercurial') | |
|
1703 | 1703 | actualhg = self._gethgpath() |
|
1704 | 1704 | if os.path.abspath(actualhg) != os.path.abspath(expecthg): |
|
1705 | 1705 | sys.stderr.write('warning: %s with unexpected mercurial lib: %s\n' |
@@ -1722,7 +1722,7 b' class TestRunner(object):' | |||
|
1722 | 1722 | |
|
1723 | 1723 | def _outputcoverage(self): |
|
1724 | 1724 | vlog('# Producing coverage report') |
|
1725 | os.chdir(self.pythondir) | |
|
1725 | os.chdir(self._pythondir) | |
|
1726 | 1726 | |
|
1727 | 1727 | def covrun(*args): |
|
1728 | 1728 | cmd = 'coverage %s' % ' '.join(args) |
@@ -1731,14 +1731,14 b' class TestRunner(object):' | |||
|
1731 | 1731 | |
|
1732 | 1732 | covrun('-c') |
|
1733 | 1733 | omit = ','.join(os.path.join(x, '*') for x in |
|
1734 | [self.bindir, self.testdir]) | |
|
1734 | [self._bindir, self._testdir]) | |
|
1735 | 1735 | covrun('-i', '-r', '"--omit=%s"' % omit) # report |
|
1736 | 1736 | if self.options.htmlcov: |
|
1737 | htmldir = os.path.join(self.testdir, 'htmlcov') | |
|
1737 | htmldir = os.path.join(self._testdir, 'htmlcov') | |
|
1738 | 1738 | covrun('-i', '-b', '"--directory=%s"' % htmldir, |
|
1739 | 1739 | '"--omit=%s"' % omit) |
|
1740 | 1740 | if self.options.annotate: |
|
1741 | adir = os.path.join(self.testdir, 'annotated') | |
|
1741 | adir = os.path.join(self._testdir, 'annotated') | |
|
1742 | 1742 | if not os.path.isdir(adir): |
|
1743 | 1743 | os.mkdir(adir) |
|
1744 | 1744 | covrun('-i', '-a', '"--directory=%s"' % adir, '"--omit=%s"' % omit) |
General Comments 0
You need to be logged in to leave comments.
Login now