mirror of
https://github.com/facebook/sapling.git
synced 2024-10-11 09:17:30 +03:00
92f6f35e7a
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
86 lines
1.7 KiB
Perl
86 lines
1.7 KiB
Perl
#require py2
|
|
#chg-compatible
|
|
|
|
|
|
$ cat > writepatterns.py <<EOF
|
|
> import sys
|
|
>
|
|
> path = sys.argv[1]
|
|
> patterns = sys.argv[2:]
|
|
>
|
|
> fp = open(path, 'wb')
|
|
> for pattern in patterns:
|
|
> count = int(pattern[0:-1])
|
|
> char = (pattern[-1] + '\n').encode('utf-8')
|
|
> fp.write(char*count)
|
|
> fp.close()
|
|
> EOF
|
|
|
|
prepare repo
|
|
|
|
$ hg init a
|
|
$ cd a
|
|
|
|
These initial lines of Xs were not in the original file used to generate
|
|
the patch. So all the patch hunks need to be applied to a constant offset
|
|
within this file. If the offset isn't tracked then the hunks can be
|
|
applied to the wrong lines of this file.
|
|
|
|
$ $PYTHON ../writepatterns.py a 34X 10A 1B 10A 1C 10A 1B 10A 1D 10A 1B 10A 1E 10A 1B 10A
|
|
$ hg commit -Am adda
|
|
adding a
|
|
|
|
This is a cleaner patch generated via diff
|
|
In this case it reproduces the problem when
|
|
the output of hg export does not
|
|
import patch
|
|
|
|
$ hg import -v -m 'b' -d '2 0' - <<EOF
|
|
> --- a/a 2009-12-08 19:26:17.000000000 -0800
|
|
> +++ b/a 2009-12-08 19:26:17.000000000 -0800
|
|
> @@ -9,7 +9,7 @@
|
|
> A
|
|
> A
|
|
> B
|
|
> -A
|
|
> +a
|
|
> A
|
|
> A
|
|
> A
|
|
> @@ -53,7 +53,7 @@
|
|
> A
|
|
> A
|
|
> B
|
|
> -A
|
|
> +a
|
|
> A
|
|
> A
|
|
> A
|
|
> @@ -75,7 +75,7 @@
|
|
> A
|
|
> A
|
|
> B
|
|
> -A
|
|
> +a
|
|
> A
|
|
> A
|
|
> A
|
|
> EOF
|
|
applying patch from stdin
|
|
patching file a
|
|
Hunk #1 succeeded at 43 (offset 34 lines).
|
|
Hunk #2 succeeded at 87 (offset 34 lines).
|
|
Hunk #3 succeeded at 109 (offset 34 lines).
|
|
committing files:
|
|
a
|
|
committing manifest
|
|
committing changelog
|
|
created 189885cecb41
|
|
|
|
compare imported changes against reference file
|
|
|
|
$ $PYTHON ../writepatterns.py aref 34X 10A 1B 1a 9A 1C 10A 1B 10A 1D 10A 1B 1a 9A 1E 10A 1B 1a 9A
|
|
$ diff aref a
|
|
|
|
$ cd ..
|