Fix: rcuja merge fixes
[userspace-rcu.git] / tests / runja.sh
CommitLineData
f619b0ff
MD
1#!/bin/sh
2
3# TODO: missing tests:
4# - send kill signals during tests to change the behavior between
5# add/remove/random
6# - validate that "nr_leaked" is always 0 in SUMMARY for all tests
7
8# 30 seconds per test
9TIME_UNITS=30
10
11TESTPROG=./test_urcu_ja
12
13#thread multiplier
14THREAD_MUL=1
15
16EXTRA_PARAMS=-v
17
18# ** test update coherency with single-value table
19
86b95d66 20# sanity test
04c48ddf 21${TESTPROG} 0 $((4*${THREAD_MUL})) ${TIME_UNITS} -t ${EXTRA_PARAMS} || exit 1
86b95d66 22
f619b0ff
MD
23# rw test, single key, add and del randomly, 4 threads
24# key range: init, lookup, and update: 0 to 0
25${TESTPROG} 0 $((4*${THREAD_MUL})) ${TIME_UNITS} -M 1 -N 1 -O 1 ${EXTRA_PARAMS} || exit 1
26
27# rw test, single key, add and del randomly, 2 lookup threads, 2 update threads
28# key range: init, lookup, and update: 0 to 0
29${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -M 1 -N 1 -O 1 ${EXTRA_PARAMS} || exit 1
f9965cd7
MD
30
31# add with duplicates
32
33${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -B 8 -M 10 -N 10 -O 10 ${EXTRA_PARAMS} || exit 1
34
35${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -B 8 -M 100 -N 100 -O 100 ${EXTRA_PARAMS} || exit 1
36
37${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -B 8 -M 255 -N 255 -O 255 ${EXTRA_PARAMS} || exit 1
38
39#expected fail (TODO)
40#${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -B 8 -M 256 -N 256 -O 256 ${EXTRA_PARAMS} || exit 1
41
42${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -B 16 -M 10 -N 10 -O 10 ${EXTRA_PARAMS} || exit 1
43
44${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -B 16 -M 1000 -N 1000 -O 1000 ${EXTRA_PARAMS} || exit 1
45
46${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -B 16 -M 65535 -N 65535 -O 65535 ${EXTRA_PARAMS} || exit 1
47
48
49${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -B 24 -M 10 -N 10 -O 10 ${EXTRA_PARAMS} || exit 1
50
51${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -B 24 -M 65535 -N 65535 -O 65535 ${EXTRA_PARAMS} || exit 1
52
53${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -B 24 -M 16777215 -N 16777215 -O 16777215 ${EXTRA_PARAMS} || exit 1
54
55
56${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -B 32 -M 10 -N 10 -O 10 ${EXTRA_PARAMS} || exit 1
57
58${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -B 32 -M 1000 -N 1000 -O 1000 ${EXTRA_PARAMS} || exit 1
59
60${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -B 32 -M 1000000 -N 1000000 -O 1000000 ${EXTRA_PARAMS} || exit 1
61
62${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -B 32 ${EXTRA_PARAMS} || exit 1
63
64${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -B 64 ${EXTRA_PARAMS} || exit 1
65
93d1e063
MD
66# with node leak detection
67${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -l -B 32 ${EXTRA_PARAMS} || exit 1
68
69
f9965cd7
MD
70# add unique
71
72${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -B 8 -M 10 -N 10 -O 10 ${EXTRA_PARAMS} || exit 1
73
74${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -B 8 -M 100 -N 100 -O 100 ${EXTRA_PARAMS} || exit 1
75
76${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -B 8 -M 255 -N 255 -O 255 ${EXTRA_PARAMS} || exit 1
77
78#expected fail (TODO)
79#${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -B 8 -M 256 -N 256 -O 256 ${EXTRA_PARAMS} || exit 1
80
81${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -B 16 -M 10 -N 10 -O 10 ${EXTRA_PARAMS} || exit 1
82
83${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -B 16 -M 1000 -N 1000 -O 1000 ${EXTRA_PARAMS} || exit 1
84
85${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -B 16 -M 65535 -N 65535 -O 65535 ${EXTRA_PARAMS} || exit 1
86
87
88${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -B 24 -M 10 -N 10 -O 10 ${EXTRA_PARAMS} || exit 1
89
90${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -B 24 -M 65535 -N 65535 -O 65535 ${EXTRA_PARAMS} || exit 1
91
92${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -B 24 -M 16777215 -N 16777215 -O 16777215 ${EXTRA_PARAMS} || exit 1
93
94${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -B 32 -M 10 -N 10 -O 10 ${EXTRA_PARAMS} || exit 1
95
96${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -B 32 -M 1000 -N 1000 -O 1000 ${EXTRA_PARAMS} || exit 1
97
98${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -B 32 -M 1000000 -N 1000000 -O 1000000 ${EXTRA_PARAMS} || exit 1
99
100${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -B 32 ${EXTRA_PARAMS} || exit 1
101
102${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -B 64 ${EXTRA_PARAMS} || exit 1
103
93d1e063
MD
104# with node leak detection
105${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -l -B 32 ${EXTRA_PARAMS} || exit 1
f9965cd7 106
93d1e063 107# removal (0% add), leak detection
f9965cd7 108
93d1e063 109${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -l -B 32 -k 10000 -M 10000 -N 10000 -O 10000 -r 0 ${EXTRA_PARAMS} || exit 1
f9965cd7 110
93d1e063 111# vary add ratio, leak detection
f9965cd7 112
93d1e063 113${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -l -B 32 -k 10000 -M 10000 -N 10000 -O 10000 -r 5 ${EXTRA_PARAMS} || exit 1
f9965cd7 114
93d1e063 115${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -u -l -B 32 -k 10000 -M 10000 -N 10000 -O 10000 -r 95 ${EXTRA_PARAMS} || exit 1
f9965cd7
MD
116
117
118# validate lookup of init values
119
120${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -V -u -B 32 -k 100 -S 100 -M 100 -N 100 -O 100 ${EXTRA_PARAMS} || exit 1
121
122${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -V -u -B 32 -k 10000 -S 10000 -M 10000 -N 10000 -O 10000 ${EXTRA_PARAMS} || exit 1
123
124# vary key multiplication factor
125
126${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -V -u -B 32 -m 17 -k 100 -S 100 -M 100 -N 100 -O 100 ${EXTRA_PARAMS} || exit 1
127
128${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -V -u -B 32 -m 17 -k 10000 -S 10000 -M 10000 -N 10000 -O 10000 ${EXTRA_PARAMS} || exit 1
129
130
131${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -V -u -B 64 -m 1717 -k 100 -S 100 -M 100 -N 100 -O 100 ${EXTRA_PARAMS} || exit 1
132
133${TESTPROG} $((2*${THREAD_MUL})) $((2*${THREAD_MUL})) ${TIME_UNITS} -V -u -B 64 -m 1717 -k 10000 -S 10000 -M 10000 -N 10000 -O 10000 ${EXTRA_PARAMS} || exit 1
This page took 0.028843 seconds and 4 git commands to generate.