##// END OF EJS Templates
tests: fix test-sparse-revlog...
tests: fix test-sparse-revlog This one is not covered by the CIbecause I requires an expensive artifact to be cached. So it goes out of think on regular basis (we should fix that…) The test ouput was affected by e706bb41fdb3 as we filtering now happens sooner, removing for the output.

File last commit:

r49530:e845537f merge default
r50521:da636e7a default
Show More
test-dirstate-race.t
250 lines | 6.5 KiB | text/troff | Tads3Lexer
/ tests / test-dirstate-race.t
Simon Sapin
dirstate: Remove the flat Rust DirstateMap implementation...
r48882 #testcases dirstate-v1 dirstate-v2
Simon Sapin
dirstate-tree: Add a dirstate-v1-tree variant of some tests...
r47900
Simon Sapin
dirstate-v2: Add a variant of some tests, that uses the new format...
r48056 #if dirstate-v2
dirstate-v2: add an option to prevent unintentional slow dirstate-v2...
r49049 $ cat >> $HGRCPATH << EOF
> [format]
dirstate-v2: rename the configuration to enable the format...
r49523 > use-dirstate-v2=1
dirstate-v2: add an option to prevent unintentional slow dirstate-v2...
r49049 > [storage]
> dirstate-v2.slow-path=allow
> EOF
Simon Sapin
dirstate-v2: Add a variant of some tests, that uses the new format...
r48056 #endif
Siddharth Agarwal
status: don't crash if a lookup file disappears...
r32651 $ hg init repo
$ cd repo
Adrian Buehlmann
combine tests
r12279 $ echo a > a
$ hg add a
$ hg commit -m test
Do we ever miss a sub-second change?:
$ for i in 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20; do
dirstate: clarify a `hg update` invocation in a test...
r49196 > hg update -qC 0
Adrian Buehlmann
combine tests
r12279 > echo b > a
> hg st
> done
M a
M a
M a
M a
M a
M a
M a
M a
M a
M a
M a
M a
M a
M a
M a
M a
M a
M a
M a
M a
Siddharth Agarwal
status: don't crash if a lookup file disappears...
r32651 $ echo test > b
$ mkdir dir1
$ echo test > dir1/c
$ echo test > d
$ echo test > e
#if execbit
A directory will typically have the execute bit -- make sure it doesn't get
confused with a file with the exec bit set
$ chmod +x e
#endif
$ hg add b dir1 d e
Matt Harbison
tests: remove (glob) annotations that were only for '\' matches...
r35394 adding dir1/c
Siddharth Agarwal
status: don't crash if a lookup file disappears...
r32651 $ hg commit -m test2
$ cat >> $TESTTMP/dirstaterace.py << EOF
> from mercurial import (
> context,
> extensions,
> )
Matt Harbison
extensions: deprecate extsetup without a `ui` argument (API)...
r41098 > def extsetup(ui):
Siddharth Agarwal
status: don't crash if a lookup file disappears...
r32651 > extensions.wrapfunction(context.workingctx, '_checklookup', overridechecklookup)
status: use filesystem time boundary to invalidate racy mtime...
r49213 > def overridechecklookup(orig, self, *args, **kwargs):
Siddharth Agarwal
status: don't crash if a lookup file disappears...
r32651 > # make an update that changes the dirstate from underneath
Mark Thomas
py3: fix test-dirstate-race.t...
r40332 > self._repo.ui.system(br"sh '$TESTTMP/dirstaterace.sh'",
FUJIWARA Katsunori
tests: factor external procedures out for portability...
r32751 > cwd=self._repo.root)
status: use filesystem time boundary to invalidate racy mtime...
r49213 > return orig(self, *args, **kwargs)
Siddharth Agarwal
status: don't crash if a lookup file disappears...
r32651 > EOF
$ hg debugrebuilddirstate
$ hg debugdirstate
n 0 -1 unset a
n 0 -1 unset b
n 0 -1 unset d
n 0 -1 unset dir1/c
n 0 -1 unset e
XXX Note that this returns M for files that got replaced by directories. This is
definitely a bug, but the fix for that is hard and the next status run is fine
anyway.
FUJIWARA Katsunori
tests: factor external procedures out for portability...
r32751 $ cat > $TESTTMP/dirstaterace.sh <<EOF
> rm b && rm -r dir1 && rm d && mkdir d && rm e && mkdir e
> EOF
tests: ensure a status will have non ambiguous mtime in some race test...
r49198 $ sleep 1 # ensure non-ambiguous mtime
FUJIWARA Katsunori
tests: factor external procedures out for portability...
r32751 $ hg status --config extensions.dirstaterace=$TESTTMP/dirstaterace.py
Siddharth Agarwal
status: don't crash if a lookup file disappears...
r32651 M d
M e
! b
! dir1/c
$ hg debugdirstate
n 644 2 * a (glob)
n 0 -1 unset b
n 0 -1 unset d
n 0 -1 unset dir1/c
n 0 -1 unset e
$ hg status
! b
! d
! dir1/c
! e
FUJIWARA Katsunori
context: avoid writing outdated dirstate out (issue5584)...
r32752
$ rmdir d e
$ hg update -C -q .
Test that dirstate changes aren't written out at the end of "hg
status", if .hg/dirstate is already changed simultaneously before
Siddharth Agarwal
workingctx: factor out post-status dirstate fixup...
r32812 acquisition of wlock in workingctx._poststatusfixup().
FUJIWARA Katsunori
context: avoid writing outdated dirstate out (issue5584)...
r32752
This avoidance is important to keep consistency of dirstate in race
condition (see issue5584 for detail).
$ hg parents -q
1:* (glob)
$ hg debugrebuilddirstate
$ hg debugdirstate
n 0 -1 unset a
n 0 -1 unset b
n 0 -1 unset d
n 0 -1 unset dir1/c
n 0 -1 unset e
$ cat > $TESTTMP/dirstaterace.sh <<EOF
> # This script assumes timetable of typical issue5584 case below:
> #
> # 1. "hg status" loads .hg/dirstate
> # 2. "hg status" confirms clean-ness of FILE
> # 3. "hg update -C 0" updates the working directory simultaneously
> # (FILE is removed, and FILE is dropped from .hg/dirstate)
> # 4. "hg status" acquires wlock
> # (.hg/dirstate is re-loaded = no FILE entry in dirstate)
> # 5. "hg status" marks FILE in dirstate as clean
> # (FILE entry is added to in-memory dirstate)
> # 6. "hg status" writes dirstate changes into .hg/dirstate
> # (FILE entry is written into .hg/dirstate)
> #
> # To reproduce similar situation easily and certainly, #2 and #3
> # are swapped. "hg cat" below ensures #2 on "hg status" side.
>
> hg update -q -C 0
> hg cat -r 1 b > b
test: use a different timestamp for the updated file...
r49212 > # make sure the timestamps is not ambiguous and a write will be issued
> touch -t 198606251012 b
FUJIWARA Katsunori
context: avoid writing outdated dirstate out (issue5584)...
r32752 > EOF
"hg status" below should excludes "e", of which exec flag is set, for
portability of test scenario, because unsure but missing "e" is
treated differently in _checklookup() according to runtime platform.
- "missing(!)" on POSIX, "pctx[f].cmp(self[f])" raises ENOENT
- "modified(M)" on Windows, "self.flags(f) != pctx.flags(f)" is True
$ hg status --config extensions.dirstaterace=$TESTTMP/dirstaterace.py --debug -X path:e
skip updating dirstate: identity mismatch
M a
! d
! dir1/c
$ hg parents -q
0:* (glob)
$ hg files
a
$ hg debugdirstate
Siddharth Agarwal
test-dirstate-race: back out changeset c82fa7efcbc8...
r32801 n * * * a (glob)
Siddharth Agarwal
fsmonitor: write state with wlock held and dirstate unchanged (issue5581)...
r32815
$ rm b
Siddharth Agarwal
fsmonitor: don't write out state if identity has changed (issue5581)...
r32816 #if fsmonitor
Create fsmonitor state.
$ hg status
$ f --type .hg/fsmonitor.state
.hg/fsmonitor.state: file
Test that invalidating fsmonitor state in the middle (which doesn't require the
wlock) causes the fsmonitor update to be skipped.
hg debugrebuilddirstate ensures that the dirstaterace hook will be called, but
it also invalidates the fsmonitor state. So back it up and restore it.
$ mv .hg/fsmonitor.state .hg/fsmonitor.state.tmp
$ hg debugrebuilddirstate
$ mv .hg/fsmonitor.state.tmp .hg/fsmonitor.state
$ cat > $TESTTMP/dirstaterace.sh <<EOF
> rm .hg/fsmonitor.state
> EOF
$ hg status --config extensions.dirstaterace=$TESTTMP/dirstaterace.py --debug
skip updating fsmonitor.state: identity mismatch
$ f .hg/fsmonitor.state
.hg/fsmonitor.state: file not found
#endif
Siddharth Agarwal
fsmonitor: write state with wlock held and dirstate unchanged (issue5581)...
r32815 Set up a rebase situation for issue5581.
$ echo c2 > a
$ echo c2 > b
$ hg add b
$ hg commit -m c2
created new head
$ echo c3 >> a
$ hg commit -m c3
$ hg update 2
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ echo c4 >> a
$ echo c4 >> b
$ hg commit -m c4
created new head
Siddharth Agarwal
test-dirstate-race: hide irrelevant hg status output...
r33578 Configure a merge tool that runs status in the middle of the rebase. The goal of
the status call is to trigger a potential bug if fsmonitor's state is written
even though the wlock is held by another process. The output of 'hg status' in
the merge tool goes to /dev/null because we're more interested in the results of
'hg status' run after the rebase.
Siddharth Agarwal
fsmonitor: write state with wlock held and dirstate unchanged (issue5581)...
r32815
$ cat >> $TESTTMP/mergetool-race.sh << EOF
> echo "custom merge tool"
> printf "c2\nc3\nc4\n" > \$1
Siddharth Agarwal
test-dirstate-race: hide irrelevant hg status output...
r33578 > hg --cwd "$TESTTMP/repo" status > /dev/null
Siddharth Agarwal
fsmonitor: write state with wlock held and dirstate unchanged (issue5581)...
r32815 > echo "custom merge tool end"
> EOF
$ cat >> $HGRCPATH << EOF
> [extensions]
> rebase =
> [merge-tools]
> test.executable=sh
> test.args=$TESTTMP/mergetool-race.sh \$output
> EOF
$ hg rebase -s . -d 3 --tool test
Martin von Zweigbergk
rebase: change and standarize template for rebase's one-line summary...
r46356 rebasing 4:b08445fd6b2a tip "c4"
Siddharth Agarwal
fsmonitor: write state with wlock held and dirstate unchanged (issue5581)...
r32815 merging a
custom merge tool
custom merge tool end
saved backup bundle to $TESTTMP/repo/.hg/strip-backup/* (glob)
This hg status should be empty, whether or not fsmonitor is enabled (issue5581).
$ hg status