test-extension.t
917 lines
| 28.3 KiB
| text/troff
|
Tads3Lexer
/ tests / test-extension.t
Adrian Buehlmann
|
r12191 | Test basic extension support | ||
$ cat > foobar.py <<EOF | ||||
> import os | ||||
Gregory Szorc
|
r21254 | > from mercurial import cmdutil, commands | ||
> cmdtable = {} | ||||
> command = cmdutil.command(cmdtable) | ||||
Adrian Buehlmann
|
r12191 | > def uisetup(ui): | ||
> ui.write("uisetup called\\n") | ||||
> def reposetup(ui, repo): | ||||
> ui.write("reposetup called for %s\\n" % os.path.basename(repo.root)) | ||||
> ui.write("ui %s= repo.ui\\n" % (ui == repo.ui and "=" or "!")) | ||||
Gregory Szorc
|
r21254 | > @command('foo', [], 'hg foo') | ||
Adrian Buehlmann
|
r12191 | > def foo(ui, *args, **kwargs): | ||
> ui.write("Foo\\n") | ||||
Gregory Szorc
|
r21773 | > @command('bar', [], 'hg bar', norepo=True) | ||
Adrian Buehlmann
|
r12191 | > def bar(ui, *args, **kwargs): | ||
> ui.write("Bar\\n") | ||||
> EOF | ||||
$ abspath=`pwd`/foobar.py | ||||
$ mkdir barfoo | ||||
$ cp foobar.py barfoo/__init__.py | ||||
$ barfoopath=`pwd`/barfoo | ||||
$ hg init a | ||||
$ cd a | ||||
$ echo foo > file | ||||
$ hg add file | ||||
$ hg commit -m 'add file' | ||||
$ echo '[extensions]' >> $HGRCPATH | ||||
$ echo "foobar = $abspath" >> $HGRCPATH | ||||
$ hg foo | ||||
uisetup called | ||||
reposetup called for a | ||||
ui == repo.ui | ||||
Foo | ||||
$ cd .. | ||||
$ hg clone a b | ||||
uisetup called | ||||
reposetup called for a | ||||
ui == repo.ui | ||||
reposetup called for b | ||||
ui == repo.ui | ||||
updating to branch default | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg bar | ||||
uisetup called | ||||
Bar | ||||
$ echo 'foobar = !' >> $HGRCPATH | ||||
module/__init__.py-style | ||||
$ echo "barfoo = $barfoopath" >> $HGRCPATH | ||||
$ cd a | ||||
$ hg foo | ||||
uisetup called | ||||
reposetup called for a | ||||
ui == repo.ui | ||||
Foo | ||||
$ echo 'barfoo = !' >> $HGRCPATH | ||||
Check that extensions are loaded in phases: | ||||
$ cat > foo.py <<EOF | ||||
> import os | ||||
> name = os.path.basename(__file__).rsplit('.', 1)[0] | ||||
> print "1) %s imported" % name | ||||
> def uisetup(ui): | ||||
> print "2) %s uisetup" % name | ||||
> def extsetup(): | ||||
> print "3) %s extsetup" % name | ||||
> def reposetup(ui, repo): | ||||
> print "4) %s reposetup" % name | ||||
> EOF | ||||
$ cp foo.py bar.py | ||||
$ echo 'foo = foo.py' >> $HGRCPATH | ||||
$ echo 'bar = bar.py' >> $HGRCPATH | ||||
Command with no output, we just want to see the extensions loaded: | ||||
$ hg paths | ||||
1) foo imported | ||||
1) bar imported | ||||
2) foo uisetup | ||||
2) bar uisetup | ||||
3) foo extsetup | ||||
3) bar extsetup | ||||
4) foo reposetup | ||||
4) bar reposetup | ||||
Check hgweb's load order: | ||||
$ cat > hgweb.cgi <<EOF | ||||
> #!/usr/bin/env python | ||||
> from mercurial import demandimport; demandimport.enable() | ||||
> from mercurial.hgweb import hgweb | ||||
> from mercurial.hgweb import wsgicgi | ||||
> application = hgweb('.', 'test repo') | ||||
> wsgicgi.launch(application) | ||||
> EOF | ||||
Mads Kiilerich
|
r18646 | $ REQUEST_METHOD='GET' PATH_INFO='/' SCRIPT_NAME='' QUERY_STRING='' \ | ||
> SERVER_PORT='80' SERVER_NAME='localhost' python hgweb.cgi \ | ||||
Adrian Buehlmann
|
r12191 | > | grep '^[0-9]) ' # ignores HTML output | ||
1) foo imported | ||||
1) bar imported | ||||
2) foo uisetup | ||||
2) bar uisetup | ||||
3) foo extsetup | ||||
3) bar extsetup | ||||
4) foo reposetup | ||||
4) bar reposetup | ||||
4) foo reposetup | ||||
4) bar reposetup | ||||
$ echo 'foo = !' >> $HGRCPATH | ||||
$ echo 'bar = !' >> $HGRCPATH | ||||
FUJIWARA Katsunori
|
r19932 | Check "from __future__ import absolute_import" support for external libraries | ||
FUJIWARA Katsunori
|
r20001 | #if windows | ||
$ PATHSEP=";" | ||||
#else | ||||
$ PATHSEP=":" | ||||
#endif | ||||
$ export PATHSEP | ||||
FUJIWARA Katsunori
|
r19932 | $ mkdir $TESTTMP/libroot | ||
$ echo "s = 'libroot/ambig.py'" > $TESTTMP/libroot/ambig.py | ||||
$ mkdir $TESTTMP/libroot/mod | ||||
$ touch $TESTTMP/libroot/mod/__init__.py | ||||
$ echo "s = 'libroot/mod/ambig.py'" > $TESTTMP/libroot/mod/ambig.py | ||||
#if absimport | ||||
$ cat > $TESTTMP/libroot/mod/ambigabs.py <<EOF | ||||
> from __future__ import absolute_import | ||||
> import ambig # should load "libroot/ambig.py" | ||||
> s = ambig.s | ||||
> EOF | ||||
$ cat > loadabs.py <<EOF | ||||
> import mod.ambigabs as ambigabs | ||||
> def extsetup(): | ||||
> print 'ambigabs.s=%s' % ambigabs.s | ||||
> EOF | ||||
FUJIWARA Katsunori
|
r20001 | $ (PYTHONPATH=${PYTHONPATH}${PATHSEP}${TESTTMP}/libroot; hg --config extensions.loadabs=loadabs.py root) | ||
FUJIWARA Katsunori
|
r19932 | ambigabs.s=libroot/ambig.py | ||
FUJIWARA Katsunori
|
r20003 | $TESTTMP/a (glob) | ||
FUJIWARA Katsunori
|
r19932 | #endif | ||
#if no-py3k | ||||
$ cat > $TESTTMP/libroot/mod/ambigrel.py <<EOF | ||||
> import ambig # should load "libroot/mod/ambig.py" | ||||
> s = ambig.s | ||||
> EOF | ||||
$ cat > loadrel.py <<EOF | ||||
> import mod.ambigrel as ambigrel | ||||
> def extsetup(): | ||||
> print 'ambigrel.s=%s' % ambigrel.s | ||||
> EOF | ||||
FUJIWARA Katsunori
|
r20001 | $ (PYTHONPATH=${PYTHONPATH}${PATHSEP}${TESTTMP}/libroot; hg --config extensions.loadrel=loadrel.py root) | ||
FUJIWARA Katsunori
|
r19932 | ambigrel.s=libroot/mod/ambig.py | ||
FUJIWARA Katsunori
|
r20003 | $TESTTMP/a (glob) | ||
FUJIWARA Katsunori
|
r19932 | #endif | ||
FUJIWARA Katsunori
|
r19933 | Check absolute/relative import of extension specific modules | ||
$ mkdir $TESTTMP/extroot | ||||
$ cat > $TESTTMP/extroot/bar.py <<EOF | ||||
> s = 'this is extroot.bar' | ||||
> EOF | ||||
$ mkdir $TESTTMP/extroot/sub1 | ||||
$ cat > $TESTTMP/extroot/sub1/__init__.py <<EOF | ||||
> s = 'this is extroot.sub1.__init__' | ||||
> EOF | ||||
$ cat > $TESTTMP/extroot/sub1/baz.py <<EOF | ||||
> s = 'this is extroot.sub1.baz' | ||||
> EOF | ||||
$ cat > $TESTTMP/extroot/__init__.py <<EOF | ||||
> s = 'this is extroot.__init__' | ||||
> import foo | ||||
> def extsetup(ui): | ||||
> ui.write('(extroot) ', foo.func(), '\n') | ||||
> EOF | ||||
$ cat > $TESTTMP/extroot/foo.py <<EOF | ||||
> # test absolute import | ||||
> buf = [] | ||||
> def func(): | ||||
> # "not locals" case | ||||
> import extroot.bar | ||||
> buf.append('import extroot.bar in func(): %s' % extroot.bar.s) | ||||
> return '\n(extroot) '.join(buf) | ||||
> # "fromlist == ('*',)" case | ||||
> from extroot.bar import * | ||||
> buf.append('from extroot.bar import *: %s' % s) | ||||
> # "not fromlist" and "if '.' in name" case | ||||
> import extroot.sub1.baz | ||||
> buf.append('import extroot.sub1.baz: %s' % extroot.sub1.baz.s) | ||||
> # "not fromlist" and NOT "if '.' in name" case | ||||
> import extroot | ||||
> buf.append('import extroot: %s' % extroot.s) | ||||
> # NOT "not fromlist" and NOT "level != -1" case | ||||
> from extroot.bar import s | ||||
> buf.append('from extroot.bar import s: %s' % s) | ||||
> EOF | ||||
$ hg --config extensions.extroot=$TESTTMP/extroot root | ||||
(extroot) from extroot.bar import *: this is extroot.bar | ||||
(extroot) import extroot.sub1.baz: this is extroot.sub1.baz | ||||
(extroot) import extroot: this is extroot.__init__ | ||||
(extroot) from extroot.bar import s: this is extroot.bar | ||||
(extroot) import extroot.bar in func(): this is extroot.bar | ||||
FUJIWARA Katsunori
|
r20003 | $TESTTMP/a (glob) | ||
FUJIWARA Katsunori
|
r19933 | |||
#if no-py3k | ||||
FUJIWARA Katsunori
|
r20002 | $ rm "$TESTTMP"/extroot/foo.* | ||
FUJIWARA Katsunori
|
r19933 | $ cat > $TESTTMP/extroot/foo.py <<EOF | ||
> # test relative import | ||||
> buf = [] | ||||
> def func(): | ||||
> # "not locals" case | ||||
> import bar | ||||
> buf.append('import bar in func(): %s' % bar.s) | ||||
> return '\n(extroot) '.join(buf) | ||||
> # "fromlist == ('*',)" case | ||||
> from bar import * | ||||
> buf.append('from bar import *: %s' % s) | ||||
> # "not fromlist" and "if '.' in name" case | ||||
> import sub1.baz | ||||
> buf.append('import sub1.baz: %s' % sub1.baz.s) | ||||
> # "not fromlist" and NOT "if '.' in name" case | ||||
> import sub1 | ||||
> buf.append('import sub1: %s' % sub1.s) | ||||
> # NOT "not fromlist" and NOT "level != -1" case | ||||
> from bar import s | ||||
> buf.append('from bar import s: %s' % s) | ||||
> EOF | ||||
$ hg --config extensions.extroot=$TESTTMP/extroot root | ||||
(extroot) from bar import *: this is extroot.bar | ||||
(extroot) import sub1.baz: this is extroot.sub1.baz | ||||
(extroot) import sub1: this is extroot.sub1.__init__ | ||||
(extroot) from bar import s: this is extroot.bar | ||||
(extroot) import bar in func(): this is extroot.bar | ||||
FUJIWARA Katsunori
|
r20003 | $TESTTMP/a (glob) | ||
FUJIWARA Katsunori
|
r19933 | #endif | ||
Adrian Buehlmann
|
r12191 | $ cd .. | ||
Mads Kiilerich
|
r17014 | hide outer repo | ||
$ hg init | ||||
Adrian Buehlmann
|
r12191 | $ cat > empty.py <<EOF | ||
> '''empty cmdtable | ||||
> ''' | ||||
> cmdtable = {} | ||||
> EOF | ||||
$ emptypath=`pwd`/empty.py | ||||
$ echo "empty = $emptypath" >> $HGRCPATH | ||||
$ hg help empty | ||||
empty extension - empty cmdtable | ||||
no commands defined | ||||
Augie Fackler
|
r21849 | |||
Adrian Buehlmann
|
r12191 | $ echo 'empty = !' >> $HGRCPATH | ||
$ cat > debugextension.py <<EOF | ||||
> '''only debugcommands | ||||
> ''' | ||||
Gregory Szorc
|
r21254 | > from mercurial import cmdutil | ||
> cmdtable = {} | ||||
> command = cmdutil.command(cmdtable) | ||||
> @command('debugfoobar', [], 'hg debugfoobar') | ||||
Adrian Buehlmann
|
r12191 | > def debugfoobar(ui, repo, *args, **opts): | ||
> "yet another debug command" | ||||
> pass | ||||
Gregory Szorc
|
r21254 | > @command('foo', [], 'hg foo') | ||
Adrian Buehlmann
|
r12191 | > def foo(ui, repo, *args, **opts): | ||
> """yet another foo command | ||||
> This command has been DEPRECATED since forever. | ||||
> """ | ||||
> pass | ||||
> EOF | ||||
$ debugpath=`pwd`/debugextension.py | ||||
$ echo "debugextension = $debugpath" >> $HGRCPATH | ||||
$ hg help debugextension | ||||
debugextension extension - only debugcommands | ||||
no commands defined | ||||
Augie Fackler
|
r21849 | |||
Adrian Buehlmann
|
r12191 | $ hg --verbose help debugextension | ||
debugextension extension - only debugcommands | ||||
list of commands: | ||||
Olav Reinert
|
r16853 | foo yet another foo command | ||
Adrian Buehlmann
|
r12191 | |||
Matt Mackall
|
r22117 | global options ([+] can be repeated): | ||
Matt Mackall
|
r15145 | |||
-R --repository REPO repository root directory or name of overlay bundle | ||||
file | ||||
--cwd DIR change working directory | ||||
-y --noninteractive do not prompt, automatically pick the first choice for | ||||
all prompts | ||||
-q --quiet suppress output | ||||
-v --verbose enable additional output | ||||
--config CONFIG [+] set/override config option (use 'section.name=value') | ||||
--debug enable debugging output | ||||
--debugger start debugger | ||||
--encoding ENCODE set the charset encoding (default: ascii) | ||||
--encodingmode MODE set the charset encoding mode (default: strict) | ||||
--traceback always print a traceback on exception | ||||
--time time how long the command takes | ||||
--profile print command execution profile | ||||
--version output version information and exit | ||||
-h --help display help and exit | ||||
Pierre-Yves David
|
r18267 | --hidden consider hidden changesets | ||
Adrian Buehlmann
|
r12191 | |||
Augie Fackler
|
r21849 | |||
Adrian Buehlmann
|
r12191 | $ hg --debug help debugextension | ||
debugextension extension - only debugcommands | ||||
list of commands: | ||||
Olav Reinert
|
r16853 | debugfoobar yet another debug command | ||
foo yet another foo command | ||||
Adrian Buehlmann
|
r12191 | |||
Matt Mackall
|
r22117 | global options ([+] can be repeated): | ||
Matt Mackall
|
r15145 | |||
-R --repository REPO repository root directory or name of overlay bundle | ||||
file | ||||
--cwd DIR change working directory | ||||
-y --noninteractive do not prompt, automatically pick the first choice for | ||||
all prompts | ||||
-q --quiet suppress output | ||||
-v --verbose enable additional output | ||||
--config CONFIG [+] set/override config option (use 'section.name=value') | ||||
--debug enable debugging output | ||||
--debugger start debugger | ||||
--encoding ENCODE set the charset encoding (default: ascii) | ||||
--encodingmode MODE set the charset encoding mode (default: strict) | ||||
--traceback always print a traceback on exception | ||||
--time time how long the command takes | ||||
--profile print command execution profile | ||||
--version output version information and exit | ||||
-h --help display help and exit | ||||
Pierre-Yves David
|
r18267 | --hidden consider hidden changesets | ||
Augie Fackler
|
r21849 | |||
Adrian Buehlmann
|
r12191 | $ echo 'debugextension = !' >> $HGRCPATH | ||
Henri Wiechers
|
r14284 | Extension module help vs command help: | ||
$ echo 'extdiff =' >> $HGRCPATH | ||||
$ hg help extdiff | ||||
hg extdiff [OPT]... [FILE]... | ||||
use external program to diff repository (or selected files) | ||||
Show differences between revisions for the specified files, using an | ||||
external program. The default program used is diff, with default options | ||||
"-Npru". | ||||
To select a different program, use the -p/--program option. The program | ||||
will be passed the names of two directories to compare. To pass additional | ||||
options to the program, use -o/--option. These will be passed before the | ||||
names of the directories to compare. | ||||
When two revision arguments are given, then changes are shown between | ||||
those revisions. If only one revision is specified then that revision is | ||||
compared to the working directory, and, when no revisions are specified, | ||||
the working directory files are compared to its parent. | ||||
Matt Mackall
|
r22112 | (use "hg help -e extdiff" to show help for the extdiff extension) | ||
Martin Geisler
|
r14285 | |||
Matt Mackall
|
r22117 | options ([+] can be repeated): | ||
Henri Wiechers
|
r14284 | |||
Matt Mackall
|
r15145 | -p --program CMD comparison program to run | ||
-o --option OPT [+] pass option to comparison program | ||||
-r --rev REV [+] revision | ||||
-c --change REV change made by revision | ||||
-I --include PATTERN [+] include names matching the given patterns | ||||
-X --exclude PATTERN [+] exclude names matching the given patterns | ||||
Henri Wiechers
|
r14284 | |||
Matt Mackall
|
r22110 | (some details hidden, use --verbose to show complete help) | ||
Henri Wiechers
|
r14284 | |||
Augie Fackler
|
r21849 | |||
Henri Wiechers
|
r14284 | $ hg help --extension extdiff | ||
extdiff extension - command to allow external programs to compare revisions | ||||
The extdiff Mercurial extension allows you to use external programs to compare | ||||
revisions, or revision with working directory. The external diff programs are | ||||
called with a configurable set of options and two non-option arguments: paths | ||||
to directories containing snapshots of files to compare. | ||||
Javi Merino
|
r14327 | The extdiff extension also allows you to configure new diff commands, so you | ||
do not need to type "hg extdiff -p kdiff3" always. | ||||
Henri Wiechers
|
r14284 | |||
[extdiff] | ||||
# add new command that runs GNU diff(1) in 'context diff' mode | ||||
cdiff = gdiff -Nprc5 | ||||
## or the old way: | ||||
#cmd.cdiff = gdiff | ||||
#opts.cdiff = -Nprc5 | ||||
Matt Harbison
|
r23150 | # add new command called meld, runs meld (no need to name twice). If | ||
# the meld executable is not available, the meld tool in [merge-tools] | ||||
# will be used, if available | ||||
Henri Wiechers
|
r14284 | meld = | ||
# add new command called vimdiff, runs gvimdiff with DirDiff plugin | ||||
# (see http://www.vim.org/scripts/script.php?script_id=102) Non | ||||
# English user, be sure to put "let g:DirDiffDynamicDiffText = 1" in | ||||
# your .vimrc | ||||
Thomas Arendsen Hein
|
r16242 | vimdiff = gvim -f "+next" \ | ||
"+execute 'DirDiff' fnameescape(argv(0)) fnameescape(argv(1))" | ||||
Henri Wiechers
|
r14284 | |||
Tool arguments can include variables that are expanded at runtime: | ||||
$parent1, $plabel1 - filename, descriptive label of first parent | ||||
$child, $clabel - filename, descriptive label of child revision | ||||
$parent2, $plabel2 - filename, descriptive label of second parent | ||||
$root - repository root | ||||
$parent is an alias for $parent1. | ||||
The extdiff extension will look in your [diff-tools] and [merge-tools] | ||||
sections for diff tool arguments, when none are specified in [extdiff]. | ||||
[extdiff] | ||||
kdiff3 = | ||||
[diff-tools] | ||||
kdiff3.diffargs=--L1 '$plabel1' --L2 '$clabel' $parent $child | ||||
You can use -I/-X and list of file or directory names like normal "hg diff" | ||||
command. The extdiff extension makes snapshots of only needed files, so | ||||
running the external diff program will actually be pretty fast (at least | ||||
faster than having to compare the entire tree). | ||||
list of commands: | ||||
Olav Reinert
|
r16853 | extdiff use external program to diff repository (or selected files) | ||
Henri Wiechers
|
r14284 | |||
Matt Mackall
|
r22118 | (use "hg help -v extdiff" to show built-in aliases and global options) | ||
Henri Wiechers
|
r14284 | |||
Augie Fackler
|
r21849 | |||
Henri Wiechers
|
r14284 | $ echo 'extdiff = !' >> $HGRCPATH | ||
Martin Geisler
|
r14286 | Test help topic with same name as extension | ||
$ cat > multirevs.py <<EOF | ||||
Gregory Szorc
|
r21254 | > from mercurial import cmdutil, commands | ||
> cmdtable = {} | ||||
> command = cmdutil.command(cmdtable) | ||||
Martin Geisler
|
r14286 | > """multirevs extension | ||
> Big multi-line module docstring.""" | ||||
Gregory Szorc
|
r21773 | > @command('multirevs', [], 'ARG', norepo=True) | ||
Martin Geisler
|
r14286 | > def multirevs(ui, repo, arg, *args, **opts): | ||
> """multirevs command""" | ||||
> pass | ||||
> EOF | ||||
$ echo "multirevs = multirevs.py" >> $HGRCPATH | ||||
$ hg help multirevs | ||||
Specifying Multiple Revisions | ||||
Dan Villiom Podlaski Christiansen
|
r18748 | """"""""""""""""""""""""""""" | ||
Martin Geisler
|
r14286 | |||
When Mercurial accepts more than one revision, they may be specified | ||||
individually, or provided as a topologically continuous range, separated | ||||
by the ":" character. | ||||
The syntax of range notation is [BEGIN]:[END], where BEGIN and END are | ||||
revision identifiers. Both BEGIN and END are optional. If BEGIN is not | ||||
specified, it defaults to revision number 0. If END is not specified, it | ||||
defaults to the tip. The range ":" thus means "all revisions". | ||||
If BEGIN is greater than END, revisions are treated in reverse order. | ||||
A range acts as a closed interval. This means that a range of 3:5 gives 3, | ||||
4 and 5. Similarly, a range of 9:6 gives 9, 8, 7, and 6. | ||||
use "hg help -c multirevs" to see help for the multirevs command | ||||
Augie Fackler
|
r21849 | |||
Martin Geisler
|
r14286 | $ hg help -c multirevs | ||
hg multirevs ARG | ||||
multirevs command | ||||
Matt Mackall
|
r22110 | (some details hidden, use --verbose to show complete help) | ||
Martin Geisler
|
r14286 | |||
Augie Fackler
|
r21849 | |||
Martin Geisler
|
r14286 | $ hg multirevs | ||
hg multirevs: invalid arguments | ||||
hg multirevs ARG | ||||
multirevs command | ||||
Matt Mackall
|
r22111 | (use "hg multirevs -h" to show more help) | ||
Martin Geisler
|
r14286 | [255] | ||
Augie Fackler
|
r21849 | |||
Martin Geisler
|
r14286 | $ echo "multirevs = !" >> $HGRCPATH | ||
Martin Geisler
|
r12399 | Issue811: Problem loading extensions twice (by site and by user) | ||
Adrian Buehlmann
|
r12191 | |||
$ debugpath=`pwd`/debugissue811.py | ||||
$ cat > debugissue811.py <<EOF | ||||
> '''show all loaded extensions | ||||
> ''' | ||||
Gregory Szorc
|
r21254 | > from mercurial import cmdutil, commands, extensions | ||
> cmdtable = {} | ||||
> command = cmdutil.command(cmdtable) | ||||
Gregory Szorc
|
r21773 | > @command('debugextensions', [], 'hg debugextensions', norepo=True) | ||
Adrian Buehlmann
|
r12191 | > def debugextensions(ui): | ||
> "yet another debug command" | ||||
> ui.write("%s\n" % '\n'.join([x for x, y in extensions.extensions()])) | ||||
> EOF | ||||
Yuya Nishihara
|
r23172 | $ cat <<EOF >> $HGRCPATH | ||
> debugissue811 = $debugpath | ||||
> mq = | ||||
> strip = | ||||
> hgext.mq = | ||||
> hgext/mq = | ||||
> EOF | ||||
Adrian Buehlmann
|
r12191 | |||
Show extensions: | ||||
Pierre-Yves David
|
r19822 | (note that mq force load strip, also checking it's not loaded twice) | ||
Adrian Buehlmann
|
r12191 | |||
$ hg debugextensions | ||||
debugissue811 | ||||
Pierre-Yves David
|
r19822 | strip | ||
Adrian Buehlmann
|
r12191 | mq | ||
Disabled extension commands: | ||||
FUJIWARA Katsunori
|
r19777 | $ ORGHGRCPATH=$HGRCPATH | ||
Adrian Buehlmann
|
r12191 | $ HGRCPATH= | ||
$ export HGRCPATH | ||||
$ hg help email | ||||
'email' is provided by the following extension: | ||||
Olav Reinert
|
r15861 | patchbomb command to send changesets as (a series of) patch emails | ||
Adrian Buehlmann
|
r12191 | |||
Matt Mackall
|
r22113 | (use "hg help extensions" for information on enabling extensions) | ||
Augie Fackler
|
r21849 | |||
Adrian Buehlmann
|
r12191 | $ hg qdel | ||
hg: unknown command 'qdel' | ||||
'qdelete' is provided by the following extension: | ||||
Olav Reinert
|
r15861 | mq manage a stack of patches | ||
Adrian Buehlmann
|
r12191 | |||
Matt Mackall
|
r22113 | (use "hg help extensions" for information on enabling extensions) | ||
Matt Mackall
|
r12316 | [255] | ||
Augie Fackler
|
r21849 | |||
Adrian Buehlmann
|
r12191 | $ hg churn | ||
hg: unknown command 'churn' | ||||
'churn' is provided by the following extension: | ||||
Olav Reinert
|
r15861 | churn command to display statistics about repository history | ||
Adrian Buehlmann
|
r12191 | |||
Matt Mackall
|
r22113 | (use "hg help extensions" for information on enabling extensions) | ||
Matt Mackall
|
r12316 | [255] | ||
Adrian Buehlmann
|
r12191 | |||
Augie Fackler
|
r21849 | |||
Adrian Buehlmann
|
r12191 | Disabled extensions: | ||
$ hg help churn | ||||
churn extension - command to display statistics about repository history | ||||
Matt Mackall
|
r22113 | (use "hg help extensions" for information on enabling extensions) | ||
Augie Fackler
|
r21849 | |||
Adrian Buehlmann
|
r12191 | $ hg help patchbomb | ||
patchbomb extension - command to send changesets as (a series of) patch emails | ||||
Matt Mackall
|
r22113 | (use "hg help extensions" for information on enabling extensions) | ||
Adrian Buehlmann
|
r12191 | |||
Augie Fackler
|
r21849 | |||
Adrian Buehlmann
|
r12191 | Broken disabled extension and command: | ||
$ mkdir hgext | ||||
$ echo > hgext/__init__.py | ||||
$ cat > hgext/broken.py <<EOF | ||||
> "broken extension' | ||||
> EOF | ||||
$ cat > path.py <<EOF | ||||
> import os, sys | ||||
> sys.path.insert(0, os.environ['HGEXTPATH']) | ||||
> EOF | ||||
$ HGEXTPATH=`pwd` | ||||
$ export HGEXTPATH | ||||
$ hg --config extensions.path=./path.py help broken | ||||
broken extension - (no help text available) | ||||
Matt Mackall
|
r22113 | (use "hg help extensions" for information on enabling extensions) | ||
Adrian Buehlmann
|
r12191 | |||
Augie Fackler
|
r21849 | |||
Mads Kiilerich
|
r13191 | $ cat > hgext/forest.py <<EOF | ||
> cmdtable = None | ||||
> EOF | ||||
Adrian Buehlmann
|
r12191 | $ hg --config extensions.path=./path.py help foo > /dev/null | ||
Mads Kiilerich
|
r15447 | warning: error finding commands in $TESTTMP/hgext/forest.py (glob) | ||
Pierre-Yves David
|
r21289 | abort: no such help topic: foo | ||
(try "hg help --keyword foo") | ||||
Matt Mackall
|
r12316 | [255] | ||
Augie Fackler
|
r16744 | |||
$ cat > throw.py <<EOF | ||||
> from mercurial import cmdutil, commands | ||||
> cmdtable = {} | ||||
> command = cmdutil.command(cmdtable) | ||||
> class Bogon(Exception): pass | ||||
Gregory Szorc
|
r21773 | > @command('throw', [], 'hg throw', norepo=True) | ||
Augie Fackler
|
r16744 | > def throw(ui, **opts): | ||
> """throws an exception""" | ||||
> raise Bogon() | ||||
> EOF | ||||
No declared supported version, extension complains: | ||||
$ hg --config extensions.throw=throw.py throw 2>&1 | egrep '^\*\*' | ||||
** Unknown exception encountered with possibly-broken third-party extension throw | ||||
** which supports versions unknown of Mercurial. | ||||
** Please disable throw and try your action again. | ||||
** If that fixes the bug please report it to the extension author. | ||||
** Python * (glob) | ||||
** Mercurial Distributed SCM * (glob) | ||||
** Extensions loaded: throw | ||||
Pierre-Yves David
|
r18224 | empty declaration of supported version, extension complains: | ||
$ echo "testedwith = ''" >> throw.py | ||||
$ hg --config extensions.throw=throw.py throw 2>&1 | egrep '^\*\*' | ||||
** Unknown exception encountered with possibly-broken third-party extension throw | ||||
** which supports versions unknown of Mercurial. | ||||
** Please disable throw and try your action again. | ||||
** If that fixes the bug please report it to the extension author. | ||||
** Python * (glob) | ||||
** Mercurial Distributed SCM (*) (glob) | ||||
** Extensions loaded: throw | ||||
Augie Fackler
|
r16744 | If the extension specifies a buglink, show that: | ||
$ echo 'buglink = "http://example.com/bts"' >> throw.py | ||||
$ rm -f throw.pyc throw.pyo | ||||
$ hg --config extensions.throw=throw.py throw 2>&1 | egrep '^\*\*' | ||||
** Unknown exception encountered with possibly-broken third-party extension throw | ||||
** which supports versions unknown of Mercurial. | ||||
** Please disable throw and try your action again. | ||||
** If that fixes the bug please report it to http://example.com/bts | ||||
** Python * (glob) | ||||
** Mercurial Distributed SCM (*) (glob) | ||||
** Extensions loaded: throw | ||||
If the extensions declare outdated versions, accuse the older extension first: | ||||
Thomas Arendsen Hein
|
r17227 | $ echo "from mercurial import util" >> older.py | ||
$ echo "util.version = lambda:'2.2'" >> older.py | ||||
Augie Fackler
|
r16744 | $ echo "testedwith = '1.9.3'" >> older.py | ||
$ echo "testedwith = '2.1.1'" >> throw.py | ||||
$ rm -f throw.pyc throw.pyo | ||||
$ hg --config extensions.throw=throw.py --config extensions.older=older.py \ | ||||
> throw 2>&1 | egrep '^\*\*' | ||||
** Unknown exception encountered with possibly-broken third-party extension older | ||||
** which supports versions 1.9.3 of Mercurial. | ||||
** Please disable older and try your action again. | ||||
** If that fixes the bug please report it to the extension author. | ||||
** Python * (glob) | ||||
Thomas Arendsen Hein
|
r17228 | ** Mercurial Distributed SCM (version 2.2) | ||
** Extensions loaded: throw, older | ||||
One extension only tested with older, one only with newer versions: | ||||
$ echo "util.version = lambda:'2.1.0'" >> older.py | ||||
$ rm -f older.pyc older.pyo | ||||
$ hg --config extensions.throw=throw.py --config extensions.older=older.py \ | ||||
> throw 2>&1 | egrep '^\*\*' | ||||
** Unknown exception encountered with possibly-broken third-party extension older | ||||
** which supports versions 1.9.3 of Mercurial. | ||||
** Please disable older and try your action again. | ||||
** If that fixes the bug please report it to the extension author. | ||||
** Python * (glob) | ||||
** Mercurial Distributed SCM (version 2.1.0) | ||||
** Extensions loaded: throw, older | ||||
Older extension is tested with current version, the other only with newer: | ||||
$ echo "util.version = lambda:'1.9.3'" >> older.py | ||||
$ rm -f older.pyc older.pyo | ||||
$ hg --config extensions.throw=throw.py --config extensions.older=older.py \ | ||||
> throw 2>&1 | egrep '^\*\*' | ||||
** Unknown exception encountered with possibly-broken third-party extension throw | ||||
** which supports versions 2.1.1 of Mercurial. | ||||
** Please disable throw and try your action again. | ||||
** If that fixes the bug please report it to http://example.com/bts | ||||
** Python * (glob) | ||||
** Mercurial Distributed SCM (version 1.9.3) | ||||
Augie Fackler
|
r16744 | ** Extensions loaded: throw, older | ||
Declare the version as supporting this hg version, show regular bts link: | ||||
Augie Fackler
|
r22947 | $ hgver=`$PYTHON -c 'from mercurial import util; print util.version().split("+")[0]'` | ||
Augie Fackler
|
r16744 | $ echo 'testedwith = """'"$hgver"'"""' >> throw.py | ||
$ rm -f throw.pyc throw.pyo | ||||
$ hg --config extensions.throw=throw.py throw 2>&1 | egrep '^\*\*' | ||||
** unknown exception encountered, please report by visiting | ||||
** http://mercurial.selenic.com/wiki/BugTracker | ||||
** Python * (glob) | ||||
** Mercurial Distributed SCM (*) (glob) | ||||
** Extensions loaded: throw | ||||
FUJIWARA Katsunori
|
r19777 | |||
Augie Fackler
|
r21849 | Test version number support in 'hg version': | ||
$ echo '__version__ = (1, 2, 3)' >> throw.py | ||||
$ rm -f throw.pyc throw.pyo | ||||
Matt Mackall
|
r21937 | $ hg version -v | ||
Mercurial Distributed SCM (version *) (glob) | ||||
(see http://mercurial.selenic.com for more information) | ||||
Copyright (C) 2005-* Matt Mackall and others (glob) | ||||
This is free software; see the source for copying conditions. There is NO | ||||
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | ||||
Enabled extensions: | ||||
Augie Fackler
|
r21849 | $ hg version -v --config extensions.throw=throw.py | ||
Mercurial Distributed SCM (version *) (glob) | ||||
(see http://mercurial.selenic.com for more information) | ||||
Copyright (C) 2005-* Matt Mackall and others (glob) | ||||
This is free software; see the source for copying conditions. There is NO | ||||
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | ||||
Enabled extensions: | ||||
throw 1.2.3 | ||||
$ echo 'getversion = lambda: "1.twentythree"' >> throw.py | ||||
$ rm -f throw.pyc throw.pyo | ||||
$ hg version -v --config extensions.throw=throw.py | ||||
Mercurial Distributed SCM (version *) (glob) | ||||
(see http://mercurial.selenic.com for more information) | ||||
Copyright (C) 2005-* Matt Mackall and others (glob) | ||||
This is free software; see the source for copying conditions. There is NO | ||||
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | ||||
Enabled extensions: | ||||
throw 1.twentythree | ||||
FUJIWARA Katsunori
|
r19777 | Restore HGRCPATH | ||
$ HGRCPATH=$ORGHGRCPATH | ||||
$ export HGRCPATH | ||||
Commands handling multiple repositories at a time should invoke only | ||||
"reposetup()" of extensions enabling in the target repository. | ||||
$ mkdir reposetup-test | ||||
$ cd reposetup-test | ||||
$ cat > $TESTTMP/reposetuptest.py <<EOF | ||||
> from mercurial import extensions | ||||
> def reposetup(ui, repo): | ||||
> ui.write('reposetup() for %s\n' % (repo.root)) | ||||
> EOF | ||||
$ hg init src | ||||
$ echo a > src/a | ||||
$ hg -R src commit -Am '#0 at src/a' | ||||
adding a | ||||
$ echo '[extensions]' >> src/.hg/hgrc | ||||
$ echo '# enable extension locally' >> src/.hg/hgrc | ||||
$ echo "reposetuptest = $TESTTMP/reposetuptest.py" >> src/.hg/hgrc | ||||
$ hg -R src status | ||||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/src (glob) | ||
FUJIWARA Katsunori
|
r19777 | |||
$ hg clone -U src clone-dst1 | ||||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/src (glob) | ||
FUJIWARA Katsunori
|
r19777 | $ hg init push-dst1 | ||
$ hg -q -R src push push-dst1 | ||||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/src (glob) | ||
FUJIWARA Katsunori
|
r19777 | $ hg init pull-src1 | ||
$ hg -q -R pull-src1 pull src | ||||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/src (glob) | ||
FUJIWARA Katsunori
|
r19777 | |||
Yuya Nishihara
|
r23172 | $ cat <<EOF >> $HGRCPATH | ||
> [extensions] | ||||
> # disable extension globally and explicitly | ||||
> reposetuptest = ! | ||||
> EOF | ||||
FUJIWARA Katsunori
|
r19777 | $ hg clone -U src clone-dst2 | ||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/src (glob) | ||
FUJIWARA Katsunori
|
r19777 | $ hg init push-dst2 | ||
$ hg -q -R src push push-dst2 | ||||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/src (glob) | ||
FUJIWARA Katsunori
|
r19777 | $ hg init pull-src2 | ||
$ hg -q -R pull-src2 pull src | ||||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/src (glob) | ||
FUJIWARA Katsunori
|
r19777 | |||
Yuya Nishihara
|
r23172 | $ cat <<EOF >> $HGRCPATH | ||
> [extensions] | ||||
> # enable extension globally | ||||
> reposetuptest = $TESTTMP/reposetuptest.py | ||||
> EOF | ||||
FUJIWARA Katsunori
|
r19777 | $ hg clone -U src clone-dst3 | ||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/src (glob) | ||
reposetup() for $TESTTMP/reposetup-test/clone-dst3 (glob) | ||||
FUJIWARA Katsunori
|
r19777 | $ hg init push-dst3 | ||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/push-dst3 (glob) | ||
FUJIWARA Katsunori
|
r19777 | $ hg -q -R src push push-dst3 | ||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/src (glob) | ||
reposetup() for $TESTTMP/reposetup-test/push-dst3 (glob) | ||||
FUJIWARA Katsunori
|
r19777 | $ hg init pull-src3 | ||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/pull-src3 (glob) | ||
FUJIWARA Katsunori
|
r19777 | $ hg -q -R pull-src3 pull src | ||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/pull-src3 (glob) | ||
reposetup() for $TESTTMP/reposetup-test/src (glob) | ||||
FUJIWARA Katsunori
|
r19777 | |||
$ echo '[extensions]' >> src/.hg/hgrc | ||||
$ echo '# disable extension locally' >> src/.hg/hgrc | ||||
$ echo 'reposetuptest = !' >> src/.hg/hgrc | ||||
$ hg clone -U src clone-dst4 | ||||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/clone-dst4 (glob) | ||
FUJIWARA Katsunori
|
r19777 | $ hg init push-dst4 | ||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/push-dst4 (glob) | ||
FUJIWARA Katsunori
|
r19777 | $ hg -q -R src push push-dst4 | ||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/push-dst4 (glob) | ||
FUJIWARA Katsunori
|
r19777 | $ hg init pull-src4 | ||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/pull-src4 (glob) | ||
FUJIWARA Katsunori
|
r19777 | $ hg -q -R pull-src4 pull src | ||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/pull-src4 (glob) | ||
FUJIWARA Katsunori
|
r19777 | |||
disabling in command line overlays with all configuration | ||||
$ hg --config extensions.reposetuptest=! clone -U src clone-dst5 | ||||
$ hg --config extensions.reposetuptest=! init push-dst5 | ||||
$ hg --config extensions.reposetuptest=! -q -R src push push-dst5 | ||||
$ hg --config extensions.reposetuptest=! init pull-src5 | ||||
$ hg --config extensions.reposetuptest=! -q -R pull-src5 pull src | ||||
Yuya Nishihara
|
r23172 | $ cat <<EOF >> $HGRCPATH | ||
> [extensions] | ||||
> # disable extension globally and explicitly | ||||
> reposetuptest = ! | ||||
> EOF | ||||
FUJIWARA Katsunori
|
r19777 | $ hg init parent | ||
$ hg init parent/sub1 | ||||
$ echo 1 > parent/sub1/1 | ||||
$ hg -R parent/sub1 commit -Am '#0 at parent/sub1' | ||||
adding 1 | ||||
$ hg init parent/sub2 | ||||
$ hg init parent/sub2/sub21 | ||||
$ echo 21 > parent/sub2/sub21/21 | ||||
$ hg -R parent/sub2/sub21 commit -Am '#0 at parent/sub2/sub21' | ||||
adding 21 | ||||
$ cat > parent/sub2/.hgsub <<EOF | ||||
> sub21 = sub21 | ||||
> EOF | ||||
$ hg -R parent/sub2 commit -Am '#0 at parent/sub2' | ||||
adding .hgsub | ||||
$ hg init parent/sub3 | ||||
$ echo 3 > parent/sub3/3 | ||||
$ hg -R parent/sub3 commit -Am '#0 at parent/sub3' | ||||
adding 3 | ||||
$ cat > parent/.hgsub <<EOF | ||||
> sub1 = sub1 | ||||
> sub2 = sub2 | ||||
> sub3 = sub3 | ||||
> EOF | ||||
$ hg -R parent commit -Am '#0 at parent' | ||||
adding .hgsub | ||||
$ echo '[extensions]' >> parent/.hg/hgrc | ||||
$ echo '# enable extension locally' >> parent/.hg/hgrc | ||||
$ echo "reposetuptest = $TESTTMP/reposetuptest.py" >> parent/.hg/hgrc | ||||
$ cp parent/.hg/hgrc parent/sub2/.hg/hgrc | ||||
$ hg -R parent status -S -A | ||||
FUJIWARA Katsunori
|
r20003 | reposetup() for $TESTTMP/reposetup-test/parent (glob) | ||
reposetup() for $TESTTMP/reposetup-test/parent/sub2 (glob) | ||||
FUJIWARA Katsunori
|
r19777 | C .hgsub | ||
C .hgsubstate | ||||
C sub1/1 | ||||
C sub2/.hgsub | ||||
C sub2/.hgsubstate | ||||
C sub2/sub21/21 | ||||
C sub3/3 | ||||
$ cd .. | ||||