Add infrastructure for doing an UPDATE as part of an UPSERT. Still no actual
[sqlite.git] / tool / speed-check.sh
blobfc05ac98eff7b3ae813b7025e69b1a442c44378a
1 #!/bin/bash
3 # This is a template for a script used for day-to-day size and
4 # performance monitoring of SQLite. Typical usage:
6 # sh run-speed-test.sh trunk # Baseline measurement of trunk
7 # sh run-speed-test.sh x1 # Measure some experimental change
8 # fossil test-diff --tk cout-trunk.txt cout-x1.txt # View chanages
10 # There are multiple output files, all with a base name given by
11 # the first argument:
13 # summary-$BASE.txt # Copy of standard output
14 # cout-$BASE.txt # cachegrind output
15 # explain-$BASE.txt # EXPLAIN listings (only with --explain)
17 if test "$1" = ""
18 then
19 echo "Usage: $0 OUTPUTFILE [OPTIONS]"
20 exit
22 NAME=$1
23 shift
24 #CC_OPTS="-DSQLITE_ENABLE_RTREE -DSQLITE_ENABLE_MEMSYS5"
25 CC_OPTS="-DSQLITE_ENABLE_MEMSYS5"
26 CC=gcc
27 SPEEDTEST_OPTS="--shrink-memory --reprepare --stats --heap 10000000 64"
28 SIZE=5
29 LEAN_OPTS="-DSQLITE_THREADSAFE=0"
30 LEAN_OPTS="$LEAN_OPTS -DSQLITE_DEFAULT_MEMSTATUS=0"
31 LEAN_OPTS="$LEAN_OPTS -DSQLITE_DEFAULT_WAL_SYNCHRONOUS=1"
32 LEAN_OPTS="$LEAN_OPTS -DSQLITE_LIKE_DOESNT_MATCH_BLOBS"
33 LEAN_OPTS="$LEAN_OPTS -DSQLITE_MAX_EXPR_DEPTH=0"
34 LEAN_OPTS="$LEAN_OPTS -DSQLITE_OMIT_DECLTYPE"
35 LEAN_OPTS="$LEAN_OPTS -DSQLITE_OMIT_DEPRECATED"
36 LEAN_OPTS="$LEAN_OPTS -DSQLITE_OMIT_PROGRESS_CALLBACK"
37 LEAN_OPTS="$LEAN_OPTS -DSQLITE_OMIT_SHARED_CACHE"
38 LEAN_OPTS="$LEAN_OPTS -DSQLITE_USE_ALLOCA"
39 BASELINE="trunk"
40 doExplain=0
41 doCachegrind=1
42 doVdbeProfile=0
43 doWal=1
44 while test "$1" != ""; do
45 case $1 in
46 --reprepare)
47 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
49 --autovacuum)
50 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
52 --utf16be)
53 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
55 --stats)
56 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
58 --without-rowid)
59 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
61 --nomemstat)
62 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
64 --temp)
65 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --temp 6"
67 --legacy)
68 doWal=0
70 --wal)
71 doWal=1
73 --size)
74 shift; SIZE=$1
76 --cachesize)
77 shift; SPEEDTEST_OPTS="$SPEEDTEST_OPTS --cachesize $1"
79 --explain)
80 doExplain=1
82 --vdbeprofile)
83 rm -f vdbe_profile.out
84 CC_OPTS="$CC_OPTS -DVDBE_PROFILE"
85 doCachegrind=0
86 doVdbeProfile=1
88 --lean)
89 CC_OPTS="$CC_OPTS $LEAN_OPTS"
91 --clang)
92 CC=clang
94 --icc)
95 CC=/home/drh/intel/bin/icc
97 --gcc7)
98 CC=gcc-7
100 --heap)
101 CC_OPTS="$CC_OPTS -DSQLITE_ENABLE_MEMSYS5"
102 shift;
103 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --heap $1 64"
105 --lookaside)
106 shift;
107 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --lookaside $1 $2"
108 shift;
110 --repeat)
111 CC_OPTS="$CC_OPTS -DSQLITE_ENABLE_RCACHE"
112 shift;
113 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --repeat $1"
115 --mmap)
116 shift;
117 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --mmap $1"
119 --rtree)
120 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --testset rtree"
121 CC_OPTS="$CC_OPTS -DSQLITE_ENABLE_RTREE"
123 --orm)
124 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --testset orm"
126 --cte)
127 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --testset cte"
129 --fp)
130 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --testset fp"
133 CC_OPTS="$CC_OPTS $1"
136 BASELINE=$1
138 esac
139 shift
140 done
141 if test $doWal -eq 1; then
142 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --journal wal"
144 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --size $SIZE"
145 echo "NAME = $NAME" | tee summary-$NAME.txt
146 echo "SPEEDTEST_OPTS = $SPEEDTEST_OPTS" | tee -a summary-$NAME.txt
147 echo "CC_OPTS = $CC_OPTS" | tee -a summary-$NAME.txt
148 rm -f cachegrind.out.* speedtest1 speedtest1.db sqlite3.o
149 if test $doVdbeProfile -eq 1; then
150 rm -f vdbe_profile.out
152 $CC -g -Os -Wall -I. $CC_OPTS -c sqlite3.c
153 size sqlite3.o | tee -a summary-$NAME.txt
154 if test $doExplain -eq 1; then
155 $CC -g -Os -Wall -I. $CC_OPTS \
156 -DSQLITE_ENABLE_EXPLAIN_COMMENTS \
157 ./shell.c ./sqlite3.c -o sqlite3 -ldl -lpthread
159 SRC=./speedtest1.c
160 $CC -g -Os -Wall -I. $CC_OPTS $SRC ./sqlite3.o -o speedtest1 -ldl -lpthread
161 ls -l speedtest1 | tee -a summary-$NAME.txt
162 if test $doCachegrind -eq 1; then
163 valgrind --tool=cachegrind ./speedtest1 speedtest1.db \
164 $SPEEDTEST_OPTS 2>&1 | tee -a summary-$NAME.txt
165 else
166 ./speedtest1 speedtest1.db $SPEEDTEST_OPTS 2>&1 | tee -a summary-$NAME.txt
168 size sqlite3.o | tee -a summary-$NAME.txt
169 wc sqlite3.c
170 if test $doCachegrind -eq 1; then
171 cg_anno.tcl cachegrind.out.* >cout-$NAME.txt
172 echo '*****************************************************' >>cout-$NAME.txt
173 sed 's/^[0-9=-]\{9\}/==00000==/' summary-$NAME.txt >>cout-$NAME.txt
175 if test $doExplain -eq 1; then
176 ./speedtest1 --explain $SPEEDTEST_OPTS | ./sqlite3 >explain-$NAME.txt
178 if test $doVdbeProfile -eq 1; then
179 tclsh ../sqlite/tool/vdbe_profile.tcl >vdbeprofile-$NAME.txt
180 open vdbeprofile-$NAME.txt
182 if test "$NAME" != "$BASELINE" -a $doVdbeProfile -ne 1; then
183 fossil test-diff --tk -c 20 cout-$BASELINE.txt cout-$NAME.txt