mirror of
https://github.com/facebook/sapling.git
synced 2024-10-06 14:58:03 +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
73 lines
3.0 KiB
Raku
73 lines
3.0 KiB
Raku
#require py2
|
|
$ enable amend rebase remotenames
|
|
$ setconfig experimental.evolution=obsolete
|
|
$ setconfig experimental.narrow-heads=true
|
|
$ setconfig visibility.enabled=true
|
|
$ setconfig mutation.record=true mutation.enabled=true mutation.date="0 0"
|
|
|
|
$ newrepo
|
|
$ echo "base" > base
|
|
$ hg commit -Aqm base
|
|
$ echo 1 > file
|
|
$ hg commit -Aqm commit1
|
|
$ for i in 2 3 4 5
|
|
> do
|
|
> echo $i >> file
|
|
> hg amend -m "commit$i"
|
|
> done
|
|
$ hg debugmutation .
|
|
* 21c93100b04c543843a7dab4fa0d5bada061b7a0 amend by test at 1970-01-01T00:00:00 from:
|
|
672a4910c364d425231d2dd2fb0486f32a2d88f4 amend by test at 1970-01-01T00:00:00 from:
|
|
d3c8fd338cf40a496d981b2ada8df4108f575897 amend by test at 1970-01-01T00:00:00 from:
|
|
932f02c9fad3fa46e55b62560c88eb67528b02f0 amend by test at 1970-01-01T00:00:00 from:
|
|
e6c779c67aa947c951f334f4f312bd2b21d27e55
|
|
|
|
Loops are not normally possible, but they can sneak in through backfilling complex
|
|
obsmarker graphs. Create a fake one to check behaviour.
|
|
|
|
$ hg debugsh -c "with repo.lock(): m.mutation.recordentries(repo, [m.mutation.createsyntheticentry(repo, m.mutation.ORIGIN_OBSMARKER, [m.node.bin(\"e6c779c67aa947c951f334f4f312bd2b21d27e55\"), m.node.bin(\"672a4910c364d425231d2dd2fb0486f32a2d88f4\")], m.node.bin(\"932f02c9fad3fa46e55b62560c88eb67528b02f0\"), \"loop\")], skipexisting=False)"
|
|
$ tglogm --hidden
|
|
@ 5: 21c93100b04c 'commit5'
|
|
|
|
|
| x 4: 672a4910c364 'commit4' (Rewritten using amend into 21c93100b04c) (Rewritten using loop into 932f02c9fad3)
|
|
|/
|
|
| x 3: d3c8fd338cf4 'commit3' (Rewritten using amend into 672a4910c364)
|
|
|/
|
|
| x 2: 932f02c9fad3 'commit2' (Rewritten using amend into d3c8fd338cf4)
|
|
|/
|
|
| x 1: e6c779c67aa9 'commit1' (Rewritten using loop into 932f02c9fad3)
|
|
|/
|
|
o 0: d20a80d4def3 'base'
|
|
|
|
|
|
$ hg unhide e6c779c67aa9
|
|
|
|
Check the normal revsets.
|
|
$ hg log -r 'predecessors(21c93100b04c)' -T '{node} {desc}\n'
|
|
e6c779c67aa947c951f334f4f312bd2b21d27e55 commit1
|
|
932f02c9fad3fa46e55b62560c88eb67528b02f0 commit2
|
|
d3c8fd338cf40a496d981b2ada8df4108f575897 commit3
|
|
672a4910c364d425231d2dd2fb0486f32a2d88f4 commit4
|
|
21c93100b04c543843a7dab4fa0d5bada061b7a0 commit5
|
|
$ hg log -r 'successors(e6c779c67aa9)' -T '{node} {desc}\n'
|
|
e6c779c67aa947c951f334f4f312bd2b21d27e55 commit1
|
|
932f02c9fad3fa46e55b62560c88eb67528b02f0 commit2
|
|
d3c8fd338cf40a496d981b2ada8df4108f575897 commit3
|
|
672a4910c364d425231d2dd2fb0486f32a2d88f4 commit4
|
|
21c93100b04c543843a7dab4fa0d5bada061b7a0 commit5
|
|
|
|
If successorssets doesn't handle loops, this next command will hang as it
|
|
continuously cycles round the commit2 to commit4 loop.
|
|
|
|
$ tglogm
|
|
@ 5: 21c93100b04c 'commit5'
|
|
|
|
|
| x 1: e6c779c67aa9 'commit1' (Rewritten using rewrite into 21c93100b04c)
|
|
|/
|
|
o 0: d20a80d4def3 'base'
|
|
|
|
Similarly, check that predecessorsset is also safe.
|
|
|
|
$ hg debugsh -c "ui.write(str([m.node.hex(n) for n in m.mutation.predecessorsset(repo, m.node.bin(\"21c93100b04c543843a7dab4fa0d5bada061b7a0\"))]) + '\n')"
|
|
['e6c779c67aa947c951f334f4f312bd2b21d27e55']
|