|
@@ -2,7 +2,7 @@
|
2
|
2
|
#
|
3
|
3
|
# CBL : Curl Benchmark on Lodel
|
4
|
4
|
#
|
5
|
|
-# Usage : $0 [HOSTNAME] [INSTANCE_LIST_FILE]
|
|
5
|
+# Usage : $0 [HOSTNAME] [INSTANCE_LIST_FILE] [N_CREATE] [N_EDIT] [N_DELETE]
|
6
|
6
|
#
|
7
|
7
|
# Instance_list_file is expected to be a file containing instances name (1 per
|
8
|
8
|
# line). Uses by default /tmp/lodel2_instance_list.txt
|
|
@@ -81,20 +81,11 @@ n_delete=${n_delete:=10}
|
81
|
81
|
|
82
|
82
|
for i in $(seq $#)
|
83
|
83
|
do
|
84
|
|
- echo $1 |grep -E "^-?-h" &>/dev/null && usage
|
|
84
|
+ echo $1 |grep -E "^-?-h" &>/dev/null
|
85
|
85
|
shift
|
86
|
86
|
done
|
87
|
87
|
|
88
|
88
|
|
89
|
|
-logdir="/tmp/lodel2_cbl_logs"
|
90
|
|
-if [ -d "$logdir" ]
|
91
|
|
-then
|
92
|
|
- echo "WARNING : $logdir allready exists. It's a better idea to delete it before running this script again"
|
93
|
|
- echo "waiting 3s"
|
94
|
|
- sleep 3
|
95
|
|
-fi
|
96
|
|
-mkdir -p $logdir
|
97
|
|
-
|
98
|
89
|
#curl_options='--silent -o /dev/null -s -w %{http_code}:%{time_connect}:%{time_starttransfer}:%{time_total}\n'
|
99
|
90
|
curl_options='--silent -o /dev/null -s -w %{url_effective};%{http_code};%{time_connect};%{time_starttransfer};%{time_total}\n'
|
100
|
91
|
curl_debug_opt='-v -w %{url_effective};%{http_code};%{time_connect};%{time_starttransfer};%{time_total}\n'
|
|
@@ -128,9 +119,14 @@ mass_creation() {
|
128
|
119
|
instance_name=$1
|
129
|
120
|
iteration_count=$2
|
130
|
121
|
base_uri=$(_base_uri $1)
|
131
|
|
- logfile="$logdir/mass_creation_${instance_name}.log"
|
132
|
122
|
cls_list_file=$(fetch_all_classes $1)
|
133
|
123
|
|
|
124
|
+ if [ -z "$(cat $cls_list_file)" ]
|
|
125
|
+ then
|
|
126
|
+ echo "Failed to fetch class list for instance $1. Abording..." >&2
|
|
127
|
+ exit
|
|
128
|
+ fi
|
|
129
|
+
|
134
|
130
|
if [ "$iteration_count" -le "0" ]
|
135
|
131
|
then
|
136
|
132
|
return
|
|
@@ -139,10 +135,9 @@ mass_creation() {
|
139
|
135
|
for i in $(seq $iteration_count)
|
140
|
136
|
do
|
141
|
137
|
cls=$(shuf -n1 $cls_list_file)
|
142
|
|
- $curcurl -d "$(curl_opt_create_$cls)" "${base_uri}$(uri_create $cls)" | tee -a $logfile
|
|
138
|
+ echo "${base_uri}$(uri_create $cls) POST $(curl_opt_create_$cls)"
|
143
|
139
|
done
|
144
|
|
-
|
145
|
|
- rm -v $cls_list_file
|
|
140
|
+ rm -v $cls_list_file >&2
|
146
|
141
|
}
|
147
|
142
|
|
148
|
143
|
mass_link_edit() {
|
|
@@ -152,7 +147,6 @@ mass_link_edit() {
|
152
|
147
|
instance_name=$1
|
153
|
148
|
iteration_count=$2
|
154
|
149
|
base_uri=$(_base_uri $1)
|
155
|
|
- logfile="$logdir/mass_link_edit_${instance_name}.log"
|
156
|
150
|
cls_list_file=$(fetch_all_classes $1)
|
157
|
151
|
|
158
|
152
|
for cls in $(cat $cls_list_file)
|
|
@@ -171,17 +165,79 @@ mass_link_edit() {
|
171
|
165
|
ltext_count=$(shuf -i1-5 -n1)
|
172
|
166
|
alias_param=$(head -n $(expr $alias_count \* $i) $person_ids| tail -n$alias_count|tr -s "\n" "," | sed 's/,$//')
|
173
|
167
|
txt_param=$(head -n $(expr $ltext_count \* $i) $text_ids | tail -n$ltext_count|tr -s "\n" "," | sed 's/,$//')
|
174
|
|
- $curcurl -d "$(curl_opt_create_$cls $alias_param $txt_param)&uid=$cur_id" "$base_uri/admin/update?classname=$cls&lodel_id=$cur_id" | tee -a $logfile
|
|
168
|
+ echo "$base_uri/admin/update?classname=$cls&lodel_id=$cur_id POST $(curl_opt_create_$cls $alias_param $txt_param)&uid=$cur_id"
|
175
|
169
|
done
|
176
|
170
|
rm -v $text_ids $person_ids $section_ids $subsection_ids
|
177
|
171
|
;;
|
178
|
|
-
|
|
172
|
+
|
|
173
|
+ Collection)
|
|
174
|
+ collections_ids=$(fetch_all_ids $1 Collection)
|
|
175
|
+ publication_ids=$(fetch_all_ids $1 Publication)
|
|
176
|
+ for i in $(seq $iteration_count)
|
|
177
|
+ do
|
|
178
|
+ cur_id=$(shuf -n1 $collections_ids)
|
|
179
|
+ publications_count=$(shuf -i1-5 -n1)
|
|
180
|
+ publication_param=$(head -n $(expr $publications_count \* $i) $publication_ids| tail -n$publications_count|tr -s "\n" ",")
|
|
181
|
+ echo "$base_uri/admin/update?classname=$cls&lodel_id=$cur_id POST $(curl_opt_create_$cls $publication_param)&uid=$cur_id"
|
|
182
|
+ done
|
|
183
|
+ rm -v $collections_ids $publication_ids
|
|
184
|
+ ;;
|
|
185
|
+
|
|
186
|
+ Publication)
|
|
187
|
+ publication_ids=$(fetch_all_ids $1 Publication)
|
|
188
|
+ collection_ids=$(fetch_all_ids $1 Collection)
|
|
189
|
+ for i in $(seq $iteration_count)
|
|
190
|
+ do
|
|
191
|
+ cur_id=$(shuf -n1 $publication_ids)
|
|
192
|
+ collections_count=$(shuf -i1-5 -n1)
|
|
193
|
+ collection_param=$(head -n $(expr $collections_count \* $i) $collection_ids| tail -n$collections_count|tr -s "\n" ",")
|
|
194
|
+ echo "$base_uri/admin.update?classname=$cls&lodel_id=$cur_id POST $(curl_opt_create_$cls $collection_param)&uid=$cur_id"
|
|
195
|
+ done
|
|
196
|
+ rm -v $publication_ids $collection_ids >&2
|
|
197
|
+ ;;
|
|
198
|
+
|
|
199
|
+ Section)
|
|
200
|
+ section_ids=$(fetch_all_ids $1 Section)
|
|
201
|
+ child_ids=$(fetch_all_ids $1 Subsection)
|
|
202
|
+ person_ids=$(fetch_all_ids $1 Person)
|
|
203
|
+ for i in $(seq $iteration_count)
|
|
204
|
+ do
|
|
205
|
+ cur_id=$(shuf -n1 $section_ids)
|
|
206
|
+ child_count=$(shuf -i1-5 -n1)
|
|
207
|
+ person_count=$(shuf -i1-5 -n1)
|
|
208
|
+ child_param=$(head -n $(expr $child_count \* $i) $child_ids| tail -n$child_count|tr -s "\n" ",")
|
|
209
|
+ person_param=$(head -n $(expr $person_count \* $i) $person_ids| tail -n$person_count|tr -s "\n" ",")
|
|
210
|
+ echo "$base_uri/admin/update?classname=$cls&lodel_id=$cur_id POST $(curl_opt_create_$cls $child_param $person_param)&uid=$cur_id"
|
|
211
|
+ done
|
|
212
|
+ rm -v $section_ids $child_ids $person_ids >&2
|
|
213
|
+ ;;
|
|
214
|
+
|
|
215
|
+ Subsection)
|
|
216
|
+ subsection_ids=$(fetch_all_ids $1 Subsection)
|
|
217
|
+ section_ids=$(fetch_all_ids $1 Section)
|
|
218
|
+ persons_ids=$(fetch_all_ids $1 Person)
|
|
219
|
+ parent_ids=$($cmktemp)
|
|
220
|
+ cat $section_ids $subsection_ids | shuf > $parent_ids
|
|
221
|
+ child_ids=$subsection_ids
|
|
222
|
+ for i in $(seq $iteration_count)
|
|
223
|
+ do
|
|
224
|
+ cur_id=$(shuf -n1 $subsection_ids)
|
|
225
|
+ child_count=$(shuf -i1-5 -n1)
|
|
226
|
+ parent_count=$(shuf -i1-5 -n1)
|
|
227
|
+ person_count=$(shuf -i1-5 -n1)
|
|
228
|
+ child_param=$(head -n $(expr $child_count \* $i) $child_ids| tail -n$child_count|tr -s "\n" ",")
|
|
229
|
+ parent_param=$(head -n $(expr $parent_count \* $i) $parent_ids| tail -n$parent_count|tr -s "\n" ",")
|
|
230
|
+ person_param=$(head -n $(expr $person_count \* $i) $persons_ids| tail -n$person_count|tr -s "\n" ",")
|
|
231
|
+ echo "$base_uri/admin/update?classname=$cls&lodel_id=$cur_id POST $(curl_opt_create_$cls $child_param $person_param $parent_param)&uid=$cur_id"
|
|
232
|
+ done
|
|
233
|
+ rm -v $subsection_ids $parent_ids $section_ids $persons_ids >&2
|
|
234
|
+ ;;
|
179
|
235
|
*)
|
180
|
236
|
;;
|
181
|
237
|
|
182
|
238
|
esac
|
183
|
239
|
done
|
184
|
|
- rm -v $cls_list_file
|
|
240
|
+ rm -v $cls_list_file >&2
|
185
|
241
|
}
|
186
|
242
|
|
187
|
243
|
mass_deletion() {
|
|
@@ -191,7 +247,6 @@ mass_deletion() {
|
191
|
247
|
instance_name=$1
|
192
|
248
|
iteration_count=$2
|
193
|
249
|
base_uri=$(_base_uri $1)
|
194
|
|
- logfile="$logdir/mass_deletion_${instance_name}.log"
|
195
|
250
|
cls_list_file=$(fetch_all_classes $1)
|
196
|
251
|
|
197
|
252
|
for cls in $(cat $cls_list_file)
|
|
@@ -207,7 +262,7 @@ mass_deletion() {
|
207
|
262
|
for i in $(seq $max_iter)
|
208
|
263
|
do
|
209
|
264
|
id=$(tail -n $i $id_list_file | head -n1)
|
210
|
|
- $curcurl "${base_uri}/admin/delete?classname=$cls&lodel_id=$id" | tee -a $logfile
|
|
265
|
+ echo "${base_uri}/admin/delete?classname=$cls&lodel_id=$id"
|
211
|
266
|
done
|
212
|
267
|
rm -v $id_list_file
|
213
|
268
|
done
|
|
@@ -219,6 +274,13 @@ fetch_all_classes() {
|
219
|
274
|
#$1 is intance name
|
220
|
275
|
cls_list_file=$($cmktemp)
|
221
|
276
|
$curl_raw "$(_base_uri $1)/list_classes" | grep -v Abstract |sed -nE 's/^ *<li> +<a href="show_class([^"]+)".*$/\1/p'|cut -d"=" -f2 > $cls_list_file
|
|
277
|
+ if [ -z "$(cat $cls_list_file)" ]
|
|
278
|
+ then
|
|
279
|
+ echo "Unable to fetch class list for $1" >&2
|
|
280
|
+ echo "Request was : $curl_raw '$(_base_uri $1)/list_classes'" >&2
|
|
281
|
+ rm $cls_list_file
|
|
282
|
+ exit 1
|
|
283
|
+ fi
|
222
|
284
|
echo $cls_list_file
|
223
|
285
|
}
|
224
|
286
|
|
|
@@ -291,10 +353,30 @@ run_bg_with_param() {
|
291
|
353
|
rm -v $pidlist
|
292
|
354
|
}
|
293
|
355
|
|
294
|
|
-run_bg_with_param "mass_creation" $instance_list $n_create
|
295
|
|
-run_bg_with_param "mass_link_edit" $instance_list $n_edit
|
296
|
|
-run_bg_with_param "mass_deletion" $instance_list $n_delete
|
|
356
|
+get_queries_with_params() {
|
|
357
|
+ #$1 is the function name to run
|
|
358
|
+ #$2 is the instance_list filename
|
|
359
|
+ #other parameters are given to the function
|
|
360
|
+ fun=$1
|
|
361
|
+ instance_list=$2
|
|
362
|
+ shift;shift
|
|
363
|
+ counter=0
|
|
364
|
+ for iname in $(cat $instance_list| sort)
|
|
365
|
+ do
|
|
366
|
+ echo "Running $fun $iname $@" >&2
|
|
367
|
+ beg=$(date "+%s")
|
|
368
|
+ $fun $iname $@
|
|
369
|
+ tsecs=$(expr $(date "+%s") - $beg)
|
|
370
|
+ left=$(expr $(cat $instance_list |wc -l) - $counter)
|
|
371
|
+ counter=$(expr $counter + 1)
|
|
372
|
+ tleft=$(expr $left \* $tsecs)
|
|
373
|
+ percent_done=$(echo "2k ${counter}.0 100.0 * $(cat $instance_list |wc -l).0 2k/ f" | dc)
|
|
374
|
+ echo -e "Done in ${tsecs}s\t$fun ${percent_done}% done ~$tleft secs" >&2
|
|
375
|
+
|
|
376
|
+ done | shuf
|
|
377
|
+}
|
297
|
378
|
|
298
|
|
-echo ""
|
299
|
|
-echo "Logs can be found in $logdir"
|
|
379
|
+get_queries_with_params "mass_creation" $instance_list $n_create
|
|
380
|
+get_queries_with_params "mass_link_edit" $instance_list $n_edit
|
|
381
|
+get_queries_with_params "mass_deletion" $instance_list $n_delete
|
300
|
382
|
|