##// END OF EJS Templates
rhg: handle null changelog and manifest revisions...
rhg: handle null changelog and manifest revisions Differential Revision: https://phab.mercurial-scm.org/D11650

File last commit:

r46434:c102b704 default
r49012:61ce70fd default
Show More
fsmonitor-run-tests.py
160 lines | 4.8 KiB | text/x-python | PythonLexer
/ tests / fsmonitor-run-tests.py
Gregory Szorc
global: use python3 in shebangs...
r46434 #!/usr/bin/env python3
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769
# fsmonitor-run-tests.py - Run Mercurial tests with fsmonitor enabled
#
# Copyright 2017 Facebook, Inc.
#
# This software may be used and distributed according to the terms of the
# GNU General Public License version 2 or any later version.
#
# This is a wrapper around run-tests.py that spins up an isolated instance of
# Watchman and runs the Mercurial tests against it. This ensures that the global
# version of Watchman isn't affected by anything this test does.
from __future__ import absolute_import
from __future__ import print_function
import argparse
import contextlib
import json
import os
import shutil
import subprocess
import sys
import tempfile
import uuid
osenvironb = getattr(os, 'environb', os.environ)
if sys.version_info > (3, 5, 0):
PYTHON3 = True
Augie Fackler
formatting: blacken the codebase...
r43346 xrange = range # we use xrange in one place, and we'd rather not use range
Manuel Jacob
tests: rename _bytespath() to _sys2bytes() and _strpath() to _sys2str()...
r44935 def _sys2bytes(p):
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769 return p.encode('utf-8')
Augie Fackler
formatting: blacken the codebase...
r43346
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769 elif sys.version_info >= (3, 0, 0):
Augie Fackler
formatting: blacken the codebase...
r43346 print(
'%s is only supported on Python 3.5+ and 2.7, not %s'
% (sys.argv[0], '.'.join(str(v) for v in sys.version_info[:3]))
)
sys.exit(70) # EX_SOFTWARE from `man 3 sysexit`
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769 else:
PYTHON3 = False
# In python 2.x, path operations are generally done using
# bytestrings by default, so we don't have to do any extra
# fiddling there. We define the wrapper functions anyway just to
# help keep code consistent between platforms.
Manuel Jacob
tests: rename _bytespath() to _sys2bytes() and _strpath() to _sys2str()...
r44935 def _sys2bytes(p):
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769 return p
Augie Fackler
formatting: blacken the codebase...
r43346
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769 def getparser():
"""Obtain the argument parser used by the CLI."""
parser = argparse.ArgumentParser(
description='Run tests with fsmonitor enabled.',
Augie Fackler
formatting: blacken the codebase...
r43346 epilog='Unrecognized options are passed to run-tests.py.',
)
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769 # - keep these sorted
# - none of these options should conflict with any in run-tests.py
Augie Fackler
formatting: blacken the codebase...
r43346 parser.add_argument(
'--keep-fsmonitor-tmpdir',
action='store_true',
help='keep temporary directory with fsmonitor state',
)
parser.add_argument(
'--watchman',
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769 help='location of watchman binary (default: watchman in PATH)',
Augie Fackler
formatting: blacken the codebase...
r43346 default='watchman',
)
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769
return parser
Augie Fackler
formatting: blacken the codebase...
r43346
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769 @contextlib.contextmanager
def watchman(args):
basedir = tempfile.mkdtemp(prefix='hg-fsmonitor')
try:
# Much of this configuration is borrowed from Watchman's test harness.
cfgfile = os.path.join(basedir, 'config.json')
# TODO: allow setting a config
with open(cfgfile, 'w') as f:
f.write(json.dumps({}))
logfile = os.path.join(basedir, 'log')
clilogfile = os.path.join(basedir, 'cli-log')
if os.name == 'nt':
sockfile = '\\\\.\\pipe\\watchman-test-%s' % uuid.uuid4().hex
else:
sockfile = os.path.join(basedir, 'sock')
pidfile = os.path.join(basedir, 'pid')
statefile = os.path.join(basedir, 'state')
argv = [
args.watchman,
Augie Fackler
formatting: blacken the codebase...
r43346 '--sockname',
sockfile,
'--logfile',
logfile,
'--pidfile',
pidfile,
'--statefile',
statefile,
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769 '--foreground',
Augie Fackler
formatting: blacken the codebase...
r43346 '--log-level=2', # debug logging for watchman
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769 ]
envb = osenvironb.copy()
Manuel Jacob
tests: rename _bytespath() to _sys2bytes() and _strpath() to _sys2str()...
r44935 envb[b'WATCHMAN_CONFIG_FILE'] = _sys2bytes(cfgfile)
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769 with open(clilogfile, 'wb') as f:
proc = subprocess.Popen(
Augie Fackler
formatting: blacken the codebase...
r43346 argv, env=envb, stdin=None, stdout=f, stderr=f
)
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769 try:
yield sockfile
finally:
proc.terminate()
proc.kill()
finally:
if args.keep_fsmonitor_tmpdir:
print('fsmonitor dir available at %s' % basedir)
else:
shutil.rmtree(basedir, ignore_errors=True)
Augie Fackler
formatting: blacken the codebase...
r43346
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769 def run():
parser = getparser()
args, runtestsargv = parser.parse_known_args()
with watchman(args) as sockfile:
Manuel Jacob
tests: rename _bytespath() to _sys2bytes() and _strpath() to _sys2str()...
r44935 osenvironb[b'WATCHMAN_SOCK'] = _sys2bytes(sockfile)
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769 # Indicate to hghave that we're running with fsmonitor enabled.
osenvironb[b'HGFSMONITOR_TESTS'] = b'1'
runtestdir = os.path.dirname(__file__)
runtests = os.path.join(runtestdir, 'run-tests.py')
blacklist = os.path.join(runtestdir, 'blacklists', 'fsmonitor')
runtestsargv.insert(0, runtests)
Augie Fackler
formatting: blacken the codebase...
r43346 runtestsargv.extend(
[
'--extra-config',
'extensions.fsmonitor=',
# specify fsmonitor.mode=paranoid always in order to force
# fsmonitor extension execute "paranoid" code path
#
# TODO: make fsmonitor-run-tests.py accept specific options
'--extra-config',
'fsmonitor.mode=paranoid',
'--blacklist',
blacklist,
]
)
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769
return subprocess.call(runtestsargv)
Augie Fackler
formatting: blacken the codebase...
r43346
Siddharth Agarwal
tests: add a wrapper to run fsmonitor tests...
r32769 if __name__ == '__main__':
sys.exit(run())