sapling/eden/scm/tests/test-hint.t
Zeyi (Rice) Fan 92f6f35e7a mark all tests requiring Python 2
Summary:
This diff marks **ALL** mercurial tests requiring Python 2 feature.

After you fixes some tests, simply remove the `py2` feature requirement and that tests will be continuously run after your diff is landed.

To bypass this feature requirement, run the tests command with `HGTEST_FORCE_PY2=1`. For example:

```
HGTEST_FORCE_PY2=1 buck test //eden/scm/tests:hg_run_tests
```

or

```
HGTEST_FORCE_PY2=1 python run-tests.py
```

----

Basically this diff are created with the following commands:

```
$ sed -i 's/import feature\(.*\)$/import feature\1\n\nfeature.require(["py2"])/' test-*-t.py
$ sed -i '1s/^/#require py2\n/' test-*.t
$ ls | grep -P "^test.*(?<\!-t)\.py$" > list && vim -p $(cat list)
# manually adding feature requires for these Python tests.
```

(Note: this ignores all push blocking failures!)

ignore-conflict-markers

Reviewed By: singhsrb

Differential Revision: D19655148

fbshipit-source-id: 985e3ccb4010cc559049f1d89f8909bc2d9b5e20
2020-01-30 18:49:21 -08:00

69 lines
1.7 KiB
Perl

#require py2
#chg-compatible
$ newext showhint << EOF
> from edenscm.mercurial import (
> cmdutil,
> hintutil,
> registrar,
> )
>
> cmdtable = {}
> command = registrar.command(cmdtable)
>
> hint = registrar.hint()
>
> @hint('next')
> def hintnext(a, b):
> return "use 'hg next' to go from %s to %s" % (a, b)
>
> @hint('export')
> def hintexport(a):
> return "use 'hg export %s' to show commit content" % (a,)
>
> @command('showhint', norepo=True)
> def showhint(*args):
> hintutil.trigger('export', 'P')
> hintutil.trigger('next', 'X', 'Y')
> hintutil.trigger('export', 'Q')
> EOF
$ hg showhint
hint[export]: use 'hg export P' to show commit content
hint[next]: use 'hg next' to go from X to Y
hint[hint-ack]: use 'hg hint --ack export next' to silence these hints
Test HGPLAIN=1 or HGPLAIN=hint silences all hints
$ HGPLAIN=1 hg showhint
$ HGPLAIN=hint hg showhint
Test silence configs
$ hg showhint --config hint.ack-export=True
hint[next]: use 'hg next' to go from X to Y
hint[hint-ack]: use 'hg hint --ack next' to silence these hints
$ hg showhint --config hint.ack=next
hint[export]: use 'hg export P' to show commit content
hint[hint-ack]: use 'hg hint --ack export' to silence these hints
$ hg showhint --config hint.ack=*
Test hint --ack command
$ HGRCPATH=$HGRCPATH:$HOME/.hgrc
$ hg hint --ack next hint-ack
hints about next, hint-ack are silenced
$ cat .hgrc
[hint]
ack = next hint-ack
$ hg showhint
hint[export]: use 'hg export P' to show commit content
$ hg hint --ack export -q
$ cat .hgrc
[hint]
ack = next hint-ack export
$ hg showhint