##// END OF EJS Templates
lfs: allow non-lfs exchanges when the extension is only enabled on one side...
lfs: allow non-lfs exchanges when the extension is only enabled on one side Once the 'lfs' requirement is added, the extension must be loaded on both sides, and changegroup3 used. But there's no reason that I can see for bailing with cryptic errors if lfs is not required, but randomly enabled somewhere.

File last commit:

r34867:1644623a default
r35521:2526579a default
Show More
test-cache-abuse.t
97 lines | 2.4 KiB | text/troff | Tads3Lexer
/ tests / test-cache-abuse.t
Matt Mackall
tests: test a variety of cache invariants...
r29041 Enable obsolete markers
$ cat >> $HGRCPATH << EOF
> [experimental]
Boris Feld
config: use 'experimental.evolution.create-markers'...
r34867 > evolution.createmarkers=True
Matt Mackall
tests: test a variety of cache invariants...
r29041 > [phases]
> publish=False
> EOF
Build a repo with some cacheable bits:
$ hg init a
$ cd a
$ echo a > a
$ hg ci -qAm0
$ hg tag t1
$ hg book -i bk1
$ hg branch -q b2
$ hg ci -Am1
$ hg tag t2
$ echo dumb > dumb
$ hg ci -qAmdumb
$ hg debugobsolete b1174d11b69e63cb0c5726621a43c859f0858d7f
Boris Feld
debugobsolete: also report the number of obsoleted changesets...
r33542 obsoleted 1 changesets
Matt Mackall
tests: test a variety of cache invariants...
r29041
$ hg phase -pr t1
$ hg phase -fsr t2
Make a helper function to check cache damage invariants:
- command output shouldn't change
- cache should be present after first use
- corruption/repair should be silent (no exceptions or warnings)
- cache should survive deletion, overwrite, and append
- unreadable / unwriteable caches should be ignored
- cache should be rebuilt after corruption
$ damage() {
> CMD=$1
> CACHE=.hg/cache/$2
> CLEAN=$3
> hg $CMD > before
> test -f $CACHE || echo "not present"
> echo bad > $CACHE
> test -z "$CLEAN" || $CLEAN
> hg $CMD > after
FUJIWARA Katsunori
tests: use pdiff instead of diff for portability...
r33614 > "$RUNTESTDIR/pdiff" before after || echo "*** overwrite corruption"
Matt Mackall
tests: test a variety of cache invariants...
r29041 > echo corruption >> $CACHE
> test -z "$CLEAN" || $CLEAN
> hg $CMD > after
FUJIWARA Katsunori
tests: use pdiff instead of diff for portability...
r33614 > "$RUNTESTDIR/pdiff" before after || echo "*** append corruption"
Matt Mackall
tests: test a variety of cache invariants...
r29041 > rm $CACHE
> mkdir $CACHE
> test -z "$CLEAN" || $CLEAN
> hg $CMD > after
FUJIWARA Katsunori
tests: use pdiff instead of diff for portability...
r33614 > "$RUNTESTDIR/pdiff" before after || echo "*** read-only corruption"
Matt Mackall
tests: test a variety of cache invariants...
r29041 > test -d $CACHE || echo "*** directory clobbered"
> rmdir $CACHE
> test -z "$CLEAN" || $CLEAN
> hg $CMD > after
FUJIWARA Katsunori
tests: use pdiff instead of diff for portability...
r33614 > "$RUNTESTDIR/pdiff" before after || echo "*** missing corruption"
Matt Mackall
tests: test a variety of cache invariants...
r29041 > test -f $CACHE || echo "not rebuilt"
> }
Beat up tags caches:
$ damage "tags --hidden" tags2
$ damage tags tags2-visible
$ damage "tag -f t3" hgtagsfnodes1
Beat up branch caches:
$ damage branches branch2-base "rm .hg/cache/branch2-[vs]*"
$ damage branches branch2-served "rm .hg/cache/branch2-[bv]*"
$ damage branches branch2-visible
$ damage "log -r branch(.)" rbc-names-v1
$ damage "log -r branch(default)" rbc-names-v1
$ damage "log -r branch(b2)" rbc-revs-v1
We currently can't detect an rbc cache with unknown names:
$ damage "log -qr branch(b2)" rbc-names-v1
--- before * (glob)
+++ after * (glob)
Danek Duvall
test-cache-abuse: correct for different hunk headers between Solaris and GNU...
r29255 @@ -1,8 +?,0 @@ (glob)
Matt Mackall
tests: test a variety of cache invariants...
r29041 -2:5fb7d38b9dc4
-3:60b597ffdafa
-4:b1174d11b69e
-5:6354685872c0
-6:5ebc725f1bef
-7:7b76eec2f273
-8:ef3428d9d644
-9:ba7a936bc03c
*** append corruption