Mercurial > hg
view tests/test-dirstate-version-fallback.t @ 52194:16b300e30139 stable
tests: bump the wait timeouts in test-racy-mutations.t
This was done to try to figure out why there's output differences in the
previous two commits- low timeouts have been a cause of a lot of problems on
Windows. That doesn't seem to be the case here, but I'm leaving it in anyway
to avoid sporadic failures.
author | Matt Harbison <matt_harbison@yahoo.com> |
---|---|
date | Tue, 05 Nov 2024 12:02:38 -0500 |
parents | 7e5be4a7cda7 |
children |
line wrap: on
line source
$ cat >> $HGRCPATH << EOF > [storage] > dirstate-v2.slow-path=allow > [format] > use-dirstate-v2=no > EOF Set up a v1 repo $ hg init repo $ cd repo $ echo a > a $ touch file-with-somewhat-long-name-to-make-dirstate-v1-bigger-than-v2 $ hg commit -Aqm a $ hg debugrequires | grep dirstate [1] $ ls -1 .hg/dirstate* .hg/dirstate Copy v1 dirstate $ cp .hg/dirstate $TESTTMP/dirstate-v1-backup Upgrade it to v2 $ hg debugupgraderepo -q --config format.use-dirstate-v2=1 --run | grep -E 'added:|removed:' added: dirstate-v2 $ hg debugrequires | grep dirstate dirstate-v2 $ ls -1 .hg/dirstate* .hg/dirstate .hg/dirstate.* (glob) Manually reset to dirstate v1 to simulate an incomplete dirstate-v2 upgrade $ rm .hg/dirstate* $ cp $TESTTMP/dirstate-v1-backup .hg/dirstate There should be no errors, but a v2 dirstate should be written back to disk $ hg st $ ls -1 .hg/dirstate* .hg/dirstate .hg/dirstate.* (glob) Corrupt the dirstate to see how the errors show up to the user $ echo "I ate your data" > .hg/dirstate $ hg st abort: working directory state appears damaged! (no-rhg !) (falling back to dirstate-v1 from v2 also failed) (no-rhg !) abort: Too little data for dirstate: 16 bytes. (rhg !) [255]