sapling/tests/test-perftweaks.t
Jun Wu 3d461ae600 check-ext: make checks stricter
Summary:
Enhance check-ext script to be more strict:

 - Only one foreign extension is allowed: `remotenames`
 - Require explicit path for in-repo extensions to avoid wrong extensions
   being tested

This would make the test more predicatable since system extensions
will be less likely to be imported. Explicit path is better than
setting `PYTHONPATH` since `hgext/name.py` could override
`hgext3rd/name.py` regardless of `PYTHONPATH`.

Test Plan: arc unit

Reviewers: phillco, durham, ikostia, #mercurial, stash

Reviewed By: stash

Subscribers: medson, mjpieters

Differential Revision: https://phabricator.intern.facebook.com/D5271430

Signature: t1:5271430:1497861776:7dd35ec7c522cd9b26aa0871cb4306b4f1b8993a
2017-06-19 08:02:38 -07:00

173 lines
4.6 KiB
Perl

$ cat >> $HGRCPATH << EOF
> [extensions]
> perftweaks=$TESTDIR/../hgext3rd/perftweaks.py
> EOF
Test disabling the tag cache
$ hg init tagcache
$ cd tagcache
$ cat >> .hg/hgrc <<EOF
> [extensions]
> blackbox=
> EOF
$ touch a && hg add -q a
$ hg commit -qm "Foo"
$ hg tag foo
$ rm -rf .hg/cache .hg/blackbox.log
$ hg tags
tip 1:2cc13e58bcd8
foo 0:be5a2292aa62
$ hg blackbox | grep tag
*> tags (glob)
*> writing * bytes to cache/hgtagsfnodes1 (glob)
*> writing .hg/cache/tags2-visible with 1 tags (glob)
*> tags exited 0 after * seconds (glob)
$ rm -rf .hg/cache .hg/blackbox.log
$ hg tags --config perftweaks.disabletags=True
tip 1:2cc13e58bcd8
$ hg blackbox | grep tag
*> tags (glob)
*> tags --config 'perftweaks.disabletags=True' exited 0 after * seconds (glob)
$ cd ..
#if osx
#else
Test disabling the case conflict check (only fails on case sensitive systems)
$ hg init casecheck
$ cd casecheck
$ cat >> .hg/hgrc <<EOF
> [perftweaks]
> disablecasecheck=True
> EOF
$ touch a
$ hg add a
$ hg commit -m a
$ touch A
$ hg add A
warning: possible case-folding collision for A
$ hg commit -m A
$ cd ..
#endif
Test disabling the branchcache
$ hg init branchcache
$ cd branchcache
$ cat >> .hg/hgrc <<EOF
> [extensions]
> blackbox=
> strip=
> EOF
$ echo a > a
$ hg commit -Aqm a
$ hg blackbox
*> commit -Aqm a (glob)
*> updated served branch cache in * seconds (glob)
*> wrote served branch cache with 1 labels and 1 nodes (glob)
*> commit -Aqm a exited 0 after * seconds (glob)
*> blackbox (glob)
$ hg strip -q -r . -k
$ rm .hg/blackbox.log
$ rm -rf .hg/cache
$ hg commit -Aqm a --config perftweaks.disablebranchcache=True
$ hg blackbox
*> commit -Aqm a (glob)
*> perftweaks updated served branch cache (glob)
*> wrote served branch cache with 1 labels and 1 nodes (glob)
*> commit -Aqm a --config 'perftweaks.disablebranchcache=True' exited 0 after * seconds (glob)
*> blackbox (glob)
$ cd ..
Test changing the delta heuristic
(this isn't a good test, but it executes the code path)
$ hg init preferdeltaserver
$ cd preferdeltaserver
$ touch a && hg commit -Aqm a
$ touch b && hg commit -Aqm b
$ cd ..
$ hg init preferdelta
$ cd preferdelta
$ cat >> .hg/hgrc <<EOF
> [perftweaks]
> preferdeltas=True
> EOF
$ hg pull ../preferdeltaserver
pulling from ../preferdeltaserver
requesting all changes
adding changesets
adding manifests
adding file changes
added 2 changesets with 2 changes to 2 files
(run 'hg update' to get a working copy)
Test file permissions
$ umask 002
$ cd ..
$ mkdir permcheck
$ chmod g+ws permcheck
$ cd permcheck
$ hg init repo
$ cd repo
$ touch a
$ hg commit -qAm a
$ ls -la .hg/cache/noderevs/
total * (glob)
drwxrw[sx]r-x.? [0-9]+ .* \. (re)
drwxrw[sx]r-x.? [0-9]+ .* \.\. (re)
-rw-rw-r--.? 1 .* branchheads-served (re)
Test logging the dirsize and sparse profiles
Set up the sampling extension and set a log file, then do a repo status.
We need to disable the SCM_SAMPLING_FILEPATH env var because arcanist may set it!
$ LOGDIR=`pwd`/logs
$ mkdir $LOGDIR
$ cat >> $HGRCPATH << EOF
> [sampling]
> key.dirstate_size=dirstate_size
> key.sparse_profiles=sparse_profiles
> filepath = $LOGDIR/samplingpath.txt
> [extensions]
> sampling=$TESTDIR/../hgext3rd/sampling.py
> EOF
$ PYTHONPATH=$TESTDIR/..:$PYTHONPATH
$ export PYTHONPATH
$ unset SCM_SAMPLING_FILEPATH
$ hg status
>>> import json
>>> with open("$LOGDIR/samplingpath.txt") as f:
... data = f.read()
>>> for record in data.strip("\0").split("\0"):
... parsedrecord = json.loads(record)
... print '{0}: {1}'.format(parsedrecord['category'],
... parsedrecord['data']['dirstate_size'])
dirstate_size: 1
$ cat >> $HGRCPATH << EOF
> [extensions]
> sparse=$TESTDIR/../hgext3rd/sparse.py
> EOF
$ cat >> profile_base << EOF
> [include]
> a
> EOF
$ cat >> profile_extended << EOF
> %include profile_base
> EOF
$ hg add profile_base profile_extended
$ hg ci -m 'adding sparse profiles'
$ hg sparse --enable-profile profile_extended
>>> import json
>>> with open("$LOGDIR/samplingpath.txt") as f:
... data = f.read()
>>> for record in data.strip("\0").split("\0"):
... parsedrecord = json.loads(record)
... if parsedrecord['category'] == 'sparse_profiles':
... print 'active_profiles:', parsedrecord['data']['active_profiles']
active_profiles:
active_profiles:
active_profiles: profile_base,profile_extended