notmuch/performance-test
David Bremner 327f30a8f3 perf-test: use nmbug tags in dump-restore tests
This makes the tag set a bit less trivial.

Note that if you use the small corpus, this is not so interesting (and
is also a bit noisy) since the messages will not be found. In the
future this could be checked for.

Conflicts:
	performance-test/01-dump-restore
2012-12-15 08:30:13 -04:00
..
download perf-test: bump corpus version to 0.3 2012-12-15 08:17:58 -04:00
.gitignore perf-test: add caching of xapian database 2012-12-15 08:17:58 -04:00
00-new perf-test: split basic into 00-new, 01-dump-restore, and 02-tag 2012-12-15 08:29:08 -04:00
01-dump-restore perf-test: use nmbug tags in dump-restore tests 2012-12-15 08:30:13 -04:00
02-tag perf-test: split basic into 00-new, 01-dump-restore, and 02-tag 2012-12-15 08:29:08 -04:00
Makefile test: initial performance testing infrastructure 2012-11-26 08:39:21 -04:00
Makefile.local perf-test: add caching of xapian database 2012-12-15 08:17:58 -04:00
notmuch-perf-test perf-test: split basic into 00-new, 01-dump-restore, and 02-tag 2012-12-15 08:29:08 -04:00
perf-test-lib.sh perf-test: unpack tags. 2012-12-15 08:17:58 -04:00
README perf-test: split basic into 00-new, 01-dump-restore, and 02-tag 2012-12-15 08:29:08 -04:00
version.sh perf-test: bump corpus version to 0.3 2012-12-15 08:17:58 -04:00

Pre-requisites
--------------

In addition to having notmuch, you need:

- gpg
- gnu tar
- gnu time
- xz. Some speedup can be gotten by installing "pixz", but this is
  probably only worthwhile if you are debugging the tests.

Getting set up to run tests:
----------------------------

First, you need to get the corpus.  If you don't already have the gpg
key for David Bremner, run

   % gpg --search 'david@tethera.net'

This should get you a key with fingerprint

    815B 6398 2A79 F8E7 C727  86C4 762B 57BB 7842 06AD

(the last 8 digits are printed as the "key id").

To fetch the actual corpus it should work to run

   % make download-corpus

In case that fails or is too slow, check

   http://notmuchmail.org/corpus

for a list of mirrors.

Running tests
-------------

The easiest way to run performance tests is to say "make perf-test", (or
simply run the notmuch-perf-test script). Either command will run all
available performance tests.

Alternately, you can run a specific subset of tests by simply invoking
one of the executable scripts in this directory, (such as ./basic).
Each test script supports the following arguments

--small / --medium / --large	Choose corpus size.
--debug				Enable debugging. In particular don't delete
				temporary directories.

Writing tests
-------------

Have a look at "01-dump-restore" for an example. Sourcing
"perf-test-lib.sh" is mandatory.  Utility functions include

- 'add_email_corpus' unpacks a set of messages and adds them to the database.
- 'cache_database': makes a snapshot of the current database
- 'uncache_database': forces the next 'add_email_corpus' to rebuild the
  database.
- 'time_start' unpacks the mail corpus and calls notmuch new if it
   cannot find a cache of the appropriate corpus.
- 'time_done' does the cleanup; comment it out or pass --debug to the
  script to leave the temporary files around.

Scripts are run in the order specified in notmuch-perf-test. In the
future this order might be chosen automatically so please follow the
convention of starting the name with two digits to specify the order.