mirror of
https://github.com/facebook/sapling.git
synced 2024-10-10 08:47:12 +03:00
fa1c4e5ebe
Many tests didn't change back from subdirectories at the end of the tests ... and they don't have to. The missing 'cd ..' could always be added when another test case is added to the test file. This change do that tests (99.5%) consistently end up in $TESTDIR where they started, thus making it simpler to extend them or move them around.
55 lines
1.2 KiB
Perl
55 lines
1.2 KiB
Perl
$ "$TESTDIR/hghave" system-sh || exit 80
|
|
|
|
Corrupt an hg repo with a pull started during an aborted commit
|
|
Create two repos, so that one of them can pull from the other one.
|
|
|
|
$ hg init source
|
|
$ cd source
|
|
$ touch foo
|
|
$ hg add foo
|
|
$ hg ci -m 'add foo'
|
|
$ hg clone . ../corrupted
|
|
updating to branch default
|
|
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
|
$ echo >> foo
|
|
$ hg ci -m 'change foo'
|
|
|
|
Add a hook to wait 5 seconds and then abort the commit
|
|
|
|
$ cd ../corrupted
|
|
$ echo '[hooks]' >> .hg/hgrc
|
|
$ echo 'pretxncommit = sleep 5; exit 1' >> .hg/hgrc
|
|
|
|
start a commit...
|
|
|
|
$ touch bar
|
|
$ hg add bar
|
|
$ hg ci -m 'add bar' &
|
|
|
|
... and start a pull while the commit is still running
|
|
|
|
$ sleep 1
|
|
$ hg pull ../source 2>/dev/null
|
|
pulling from ../source
|
|
transaction abort!
|
|
rollback completed
|
|
abort: pretxncommit hook exited with status 1
|
|
searching for changes
|
|
adding changesets
|
|
adding manifests
|
|
adding file changes
|
|
added 1 changesets with 1 changes to 1 files
|
|
(run 'hg update' to get a working copy)
|
|
|
|
see what happened
|
|
|
|
$ wait
|
|
$ hg verify
|
|
checking changesets
|
|
checking manifests
|
|
crosschecking files in changesets and manifests
|
|
checking files
|
|
1 files, 2 changesets, 2 total revisions
|
|
|
|
$ cd ..
|