2009-10-07 15:45:17 +02:00
#!/bin/bash
# AD-Bench group add/remove benchmark
#
# Copyright (C) 2009 Kai Blin <kai@samba.org>
#
# This file is part of AD-Bench, an Active Directory benchmark tool
#
# AD-Bench is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# AD-Bench is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with AD-Bench. If not, see <http://www.gnu.org/licenses/>.
ITERATIONS = 100
source ` dirname $0 ` /utils.sh
PRINCIPAL = $( get_principal $1 )
PASSWORD = $( get_password $1 )
REALM = $( get_realm $1 )
NT_DOM = $( get_nt_dom $1 )
SERVER = $2
add_group ( ) {
GROUP = $1
2021-04-14 11:44:51 +02:00
${ NET } ads group add " ${ GROUP } " -k --configfile= $CONFIG_FILE -S ${ SERVER } > /dev/null
2009-10-07 15:45:17 +02:00
RET = $?
if [ $RET -ne 0 ] ; then
echo " ${ NET } ads group add returned error: $RET "
exit 1
fi
}
del_group ( ) {
GROUP = $1
2021-04-14 11:44:51 +02:00
${ NET } ads group delete " ${ GROUP } " -k --configfile= $CONFIG_FILE -S ${ SERVER } > /dev/null
2009-10-07 15:45:17 +02:00
RET = $?
if [ $RET -ne 0 ] ; then
echo " ${ NET } returned error: $RET "
exit 1
fi
}
enum_group ( ) {
2021-04-14 11:44:51 +02:00
${ NET } ads group -k --configfile= $CONFIG_FILE -S $SERVER > /dev/null
2009-10-07 15:45:17 +02:00
RET = $?
if [ $RET -ne 0 ] ; then
echo " ${ NET } returned error: $RET "
exit 1
fi
}
info_group ( ) {
GROUP = $1
2021-04-14 11:44:51 +02:00
${ NET } ads group info " ${ GROUP } " -k --configfile= $CONFIG_FILE -S ${ SERVER } > /dev/null
2009-10-07 15:45:17 +02:00
RET = $?
if [ $RET -ne 0 ] ; then
echo " ${ NET } returned error: $RET "
exit 1
fi
}
set_up ( ) {
set_krb_env
setup_kinit
call_kinit " ${ PRINCIPAL } " " ${ PASSWORD } "
write_configfile " ${ REALM } " " ${ NT_DOM } "
}
tear_down ( ) {
${ KDESTROY }
restore_krb_env
}
set_up
echo -e " \tGROUP $SERVER "
START_TIME = $( start_timer)
echo -en "\t"
for i in $( ${ SEQ } 1 $ITERATIONS ) ; do
GROUP = $( echo " ad_test_ $( pad_number $i 3) " )
add_group $GROUP
echo -n "."
done
echo "done"
enum_group
# Requires winbind, which requires root perms to start. Skip this for now
#echo -en "\t"
#for i in $( ${SEQ} 1 $ITERATIONS ); do
# GROUP=$( echo "ad_test_$(pad_number $i 3)" )
# info_group $GROUP
# echo -n "."
#done
#echo "done"
echo -en "\t"
for i in $( ${ SEQ } 1 $ITERATIONS ) ; do
GROUP = $( echo " ad_test_ $( pad_number $i 3) " )
del_group $GROUP
echo -n "."
done
echo "done"
STOP_TIME = $( stop_timer)
TOTAL_TIME = $( total_time $START_TIME $STOP_TIME )
echo -e " \t\ttotal time:\t\t ${ TOTAL_TIME } s "
LOGINS_PER_MINUTE = $( iterations_per_minute $START_TIME $STOP_TIME $ITERATIONS )
echo -e " \t\titerations/min:\t\t $LOGINS_PER_MINUTE "
tear_down