##// END OF EJS Templates
logcmdutil: rewrite jsonchangeset printer to be backed by jsonformatter...
logcmdutil: rewrite jsonchangeset printer to be backed by jsonformatter This is a bit slower than the original implementation, but I don't think that would actually matter. It's still faster than full templating. $ hg log -Tjson -r0:5000 --time > /dev/null (orig) time: real 1.550 secs (user 1.500+0.000 sys 0.040+0.000) (new) time: real 1.810 secs (user 1.740+0.000 sys 0.070+0.000) cf. $ hg log -Tdefault -r0:5000 --time > /dev/null time: real 4.980 secs (user 4.850+0.000 sys 0.130+0.000) $ hg log -r0:5000 --time > /dev/null time: real 2.340 secs (user 2.220+0.000 sys 0.100+0.000) $ hg log -r0:5000 -q --time > /dev/null time: real 0.750 secs (user 0.670+0.000 sys 0.070+0.000) The test output changes because keys are sorted alphabetically.

File last commit:

r36757:f4a508f4 default
r37790:814151cd default
Show More
blackbox-readonly-dispatch.py
38 lines | 1.1 KiB | text/x-python | PythonLexer
/ tests / blackbox-readonly-dispatch.py
Yuya Nishihara
py3: make blackbox-readonly-dispatch.py use ui instead of print()
r36756 from __future__ import absolute_import
timeless
tests: divorce blackbox test from test-dispatch.py...
r28406 import os
from mercurial import (
dispatch,
Yuya Nishihara
py3: make blackbox-readonly-dispatch.py use ui instead of print()
r36756 ui as uimod,
timeless
tests: divorce blackbox test from test-dispatch.py...
r28406 )
def testdispatch(cmd):
"""Simple wrapper around dispatch.dispatch()
Prints command and result value, but does not handle quoting.
"""
Yuya Nishihara
py3: make blackbox-readonly-dispatch.py use ui instead of print()
r36756 ui = uimod.ui.load()
Yuya Nishihara
py3: byte-stringify blackbox-readonly-dispatch.py...
r36757 ui.status(b"running: %s\n" % cmd)
Yuya Nishihara
py3: make blackbox-readonly-dispatch.py use ui instead of print()
r36756 req = dispatch.request(cmd.split(), ui)
timeless
tests: divorce blackbox test from test-dispatch.py...
r28406 result = dispatch.dispatch(req)
Yuya Nishihara
py3: byte-stringify blackbox-readonly-dispatch.py...
r36757 ui.status(b"result: %r\n" % result)
timeless
tests: divorce blackbox test from test-dispatch.py...
r28406
# create file 'foo', add and commit
Yuya Nishihara
py3: byte-stringify blackbox-readonly-dispatch.py...
r36757 f = open(b'foo', 'wb')
f.write(b'foo\n')
timeless
tests: divorce blackbox test from test-dispatch.py...
r28406 f.close()
Yuya Nishihara
py3: byte-stringify blackbox-readonly-dispatch.py...
r36757 testdispatch(b"--debug add foo")
testdispatch(b"--debug commit -m commit1 -d 2000-01-01 foo")
timeless
tests: divorce blackbox test from test-dispatch.py...
r28406
# append to file 'foo' and commit
Yuya Nishihara
py3: byte-stringify blackbox-readonly-dispatch.py...
r36757 f = open(b'foo', 'ab')
f.write(b'bar\n')
timeless
tests: divorce blackbox test from test-dispatch.py...
r28406 f.close()
# remove blackbox.log directory (proxy for readonly log file)
Yuya Nishihara
py3: byte-stringify blackbox-readonly-dispatch.py...
r36757 os.rmdir(b".hg/blackbox.log")
timeless
tests: divorce blackbox test from test-dispatch.py...
r28406 # replace it with the real blackbox.log file
Yuya Nishihara
py3: byte-stringify blackbox-readonly-dispatch.py...
r36757 os.rename(b".hg/blackbox.log-", b".hg/blackbox.log")
testdispatch(b"--debug commit -m commit2 -d 2000-01-02 foo")
timeless
tests: divorce blackbox test from test-dispatch.py...
r28406
# check 88803a69b24 (fancyopts modified command table)
Yuya Nishihara
py3: byte-stringify blackbox-readonly-dispatch.py...
r36757 testdispatch(b"--debug log -r 0")
testdispatch(b"--debug log -r tip")