annotate tests/with_hg.py @ 179:c4c0efb37187

protocol: add the abilty to trace the protocol between the client and server This is useful when debugging issues with driving hg via hglib where output and error messages can be lost. Call setprotocoltrace with the name of a trace function or None. If the trace function is None no tracing is done. The trace function is called with the direction, the channel-identified and its data.
author Barry A. Scott <barry@barrys-emacs.org>
date Tue, 18 Oct 2016 17:45:17 +0100
parents f4f636ecca3e
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
75
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
1 import os
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
2 from nose.plugins import Plugin
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
3
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
4 class WithHgPlugin(Plugin):
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
5 name = 'with-hg'
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
6 enabled = False
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
7
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
8 def options(self, parser, env):
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
9 Plugin.options(self, parser, env)
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
10 parser.add_option('--with-hg',
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
11 action='store',
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
12 type='string',
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
13 metavar='HG',
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
14 dest='with_hg',
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
15 help='test using specified hg script.')
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
16
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
17 def configure(self, options, conf):
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
18 Plugin.configure(self, options, conf)
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
19 if options.with_hg:
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
20 self.enabled = True
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
21 self.hgpath = os.path.realpath(options.with_hg)
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
22
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
23 def begin(self):
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
24 import hglib
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
25
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
26 p = hglib.util.popen([self.hgpath, 'version'])
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
27 p.communicate()
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
28
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
29 if p.returncode:
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
30 raise ValueError("custom hg %r doesn't look like Mercurial"
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
31 % self.hgpath)
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
32
f4f636ecca3e tests: add a nose plugin that allows specifying a custom hg to run tests
Idan Kamara <idankk86@gmail.com>
parents:
diff changeset
33 hglib.HGPATH = self.hgpath