Whamcloud - gitweb
f36b0fe7b1965cdc824f1270b742dd8b523b0bfd
[fs/lustre-release.git] / lustre / tests / mdsrate-create-large.sh
1 #!/bin/bash
2 #
3 # This test was used in a set of CMD3 tests (cmd3-4 test).
4
5 LUSTRE=${LUSTRE:-`dirname $0`/..}
6 . $LUSTRE/tests/test-framework.sh
7 init_test_env $@
8 . ${CONFIG:=$LUSTRE/tests/cfg/$NAME.sh}
9
10 assert_env CLIENTS MDSRATE SINGLECLIENT MPIRUN
11
12 MACHINEFILE=${MACHINEFILE:-$TMP/$(basename $0 .sh).machines}
13 TESTDIR=$MOUNT
14
15 # Requirements
16 TIME_PERIOD=${TIME_PERIOD:-600}                        # seconds
17 SINGLE_TARGET_RATE=$((1300 / OSTCOUNT))     # ops/sec
18 AGGREGATE_TARGET_RATE=$((7000 / OSTCOUNT))  # ops/sec
19
20 # Local test variables
21 TESTDIR_SINGLE="${TESTDIR}/single"
22 TESTDIR_MULTI="${TESTDIR}/multi"
23
24 LOG=${TESTSUITELOG:-$TMP/$(basename $0 .sh).log}
25 CLIENT=$SINGLECLIENT
26 NODES_TO_USE=${NODES_TO_USE:-$CLIENTS}
27 NUM_CLIENTS=$(get_node_count ${NODES_TO_USE//,/ })
28
29 [ ! -x ${MDSRATE} ] && error "${MDSRATE} not built."
30
31 log "===== $0 ====== " 
32
33 check_and_setup_lustre
34
35 generate_machine_file $NODES_TO_USE $MACHINEFILE || error "can not generate machinefile"
36
37 $LFS setstripe $TESTDIR -c -1
38 get_stripe $TESTDIR
39
40 # Make sure we start with a clean slate
41 rm -f ${LOG} PI*
42
43 if [ -n "$NOSINGLE" ]; then
44     echo "NO Test for creates for a single client."
45 else
46     log "===== $0 ### 1 NODE CREATE ###"
47     echo "Running creates on 1 node(s)."
48
49     COMMAND="${MDSRATE} ${MDSRATE_DEBUG} --create --time ${TIME_PERIOD}
50                         --dir ${TESTDIR_SINGLE} --filefmt 'f%%d'"
51     echo "+ ${COMMAND}"
52     $MPIRUN -np 1 -machinefile ${MACHINEFILE} \
53         ${MPIRUN_OPTIONS} ${COMMAND} | tee ${LOG}
54
55     if [ ${PIPESTATUS[0]} != 0 ]; then
56         [ -f $LOG ] && cat $LOG
57         error "mpirun ... mdsrate ... failed, aborting"
58     fi
59     
60     check_rate create ${SINGLE_TARGET_RATE} 1 ${LOG} || true
61
62     log "===== $0 ### 1 NODE UNLINK ###"
63     echo "Running unlinks on 1 node(s)."
64
65     let NUM_FILES=${SINGLE_TARGET_RATE}\*${TIME_PERIOD}
66     COMMAND="${MDSRATE} ${MDSRATE_DEBUG} --unlink --time ${TIME_PERIOD}
67                  --nfiles ${NUM_FILES} --dir ${TESTDIR_SINGLE} --filefmt 'f%%d'"
68     echo "+ ${COMMAND}"
69     $MPIRUN -np 1 -machinefile ${MACHINEFILE} \
70         ${MPIRUN_OPTIONS} ${COMMAND} | tee ${LOG}
71  
72     if [ ${PIPESTATUS[0]} != 0 ]; then
73         [ -f $LOG ] && cat $LOG
74         error "mpirun ... mdsrate ... failed, aborting"
75     fi
76
77     check_rate unlink ${SINGLE_TARGET_RATE} 1 ${LOG} || true
78 fi
79
80 if [ -n "$NOMULTI" ]; then
81     echo "NO test for create on multiple nodes."
82 else
83
84     log "===== $0 ### $NUM_CLIENTS NODES CREATE ###"
85     echo "Running creates on ${NUM_CLIENTS} node(s)."
86
87     COMMAND="${MDSRATE} ${MDSRATE_DEBUG} --create --time ${TIME_PERIOD}
88                         --dir ${TESTDIR_MULTI} --filefmt 'f%%d'"
89     echo "+ ${COMMAND}"
90    $MPIRUN -np ${NUM_CLIENTS} -machinefile ${MACHINEFILE} \
91         ${MPIRUN_OPTIONS} ${COMMAND} | tee ${LOG}
92
93     if [ ${PIPESTATUS[0]} != 0 ]; then
94         [ -f $LOG ] && cat $LOG
95         error "mpirun ... mdsrate ... failed, aborting"
96     fi
97
98     check_rate create ${AGGREGATE_TARGET_RATE} ${NUM_CLIENTS} ${LOG} || true
99
100     echo "Running unlinks on ${NUM_CLIENTS} node(s)."
101
102     let NUM_FILES=${AGGREGATE_TARGET_RATE}\*${TIME_PERIOD}
103     COMMAND="${MDSRATE} ${MDSRATE_DEBUG} --unlink --time ${TIME_PERIOD}
104                   --nfiles ${NUM_FILES} --dir ${TESTDIR_MULTI} --filefmt 'f%%d'"
105     echo "+ ${COMMAND}"
106     $MPIRUN -np ${NUM_CLIENTS} -machinefile ${MACHINEFILE} \
107         ${MPIRUN_OPTIONS} ${COMMAND} | tee ${LOG}
108
109     if [ ${PIPESTATUS[0]} != 0 ]; then
110         [ -f $LOG ] && cat $LOG
111         error "mpirun ... mdsrate ... failed, aborting"
112     fi
113
114     check_rate unlink ${AGGREGATE_TARGET_RATE} ${NUM_CLIENTS} ${LOG} || true
115 fi
116
117 equals_msg `basename $0`: test complete, cleaning up
118 rm -f $MACHINEFILE
119 zconf_umount_clients $NODES_TO_USE $MOUNT
120 check_and_cleanup_lustre
121 #rm -f $LOG
122
123 exit 0