X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=performance-test%2FT00-new.sh;h=53de1c2710aa7a59166f7fbabd9d9931f7131921;hb=b4a4ed0df9cd2150e75853f5491cfa02fe72caf1;hp=687501294e2ce0751311703b7d283fc37db0b2e0;hpb=fd36ae9f514520e85d9e43d4aa08263b3a5a8d3e;p=notmuch diff --git a/performance-test/T00-new.sh b/performance-test/T00-new.sh index 68750129..53de1c27 100755 --- a/performance-test/T00-new.sh +++ b/performance-test/T00-new.sh @@ -1,4 +1,4 @@ -#!/bin/bash +#!/usr/bin/env bash test_description='notmuch new' @@ -12,4 +12,32 @@ for i in $(seq 2 6); do time_run "notmuch new #$i" 'notmuch new' done +manifest=$(mktemp manifestXXXXXX) + +find mail -type f ! -path 'mail/.notmuch/*' | sed -n '1~4 p' > $manifest +# arithmetic context is to eat extra whitespace on e.g. some BSDs +count=$((`wc -l < $manifest`)) + +perl -nle 'rename $_, "$_.renamed"' $manifest + +time_run "new ($count mv)" 'notmuch new' + +perl -nle 'rename "$_.renamed", $_' $manifest + +time_run "new ($count mv back)" 'notmuch new' + +xargs tar cf backup.tar < $manifest + +perl -nle 'unlink $_; unlink $_.copy' $manifest + +time_run "new ($count rm)" 'notmuch new' + +tar xf backup.tar + +time_run "new ($count restore)" 'notmuch new' + +perl -nle 'link $_, "$_.copy"' $manifest + +time_run "new ($count cp)" 'notmuch new' + time_done