Hila Ben Abraham | a36f0d1 | 2016-02-08 18:03:47 -0600 | [diff] [blame] | 1 | #!/usr/bin/env bash |
| 2 | source ../multi-host.conf |
| 3 | workDir=$(pwd) |
| 4 | logDir=$workDir/logs |
| 5 | testLogA=$logDir/route-inheritanceA.log |
| 6 | testLogB=$logDir/route-inheritanceB.log |
| 7 | testLogC=$logDir/route-inheritanceC.log |
| 8 | testLogD=$logDir/route-inheritanceD.log |
| 9 | mkdir -p $workDir/logs |
| 10 | |
| 11 | echo "Starting nfd on host A" > $testLogA |
| 12 | # start nfd on localhost (A) |
| 13 | sudo nfd &> $logDir/nfdA.log & |
| 14 | |
| 15 | # start nfd on hostB |
| 16 | ssh $CTRL_B "mkdir -p $logDir ; sudo nfd &> $logDir/nfdB.log &\ |
| 17 | echo 'Starting nfd on host B' > $testLogB ; sleep 2" |
| 18 | |
| 19 | # start nfd on hostC |
| 20 | ssh $CTRL_C "mkdir -p $logDir ; sudo nfd &> $logDir/nfdC.log &\ |
| 21 | echo 'Starting nfd on host C' > $testLogC ; sleep 2" |
| 22 | |
| 23 | # start nfd on hostD |
| 24 | ssh $CTRL_D "mkdir -p $logDir ; sudo nfd &> $logDir/nfdD.log &\ |
| 25 | echo 'Starting nfd on host D' > $testLogD ; sleep 2" |
| 26 | |
| 27 | # set multicast strategy for root namespace on A |
Eric Newberry | 7745c1a | 2017-04-20 00:23:05 -0700 | [diff] [blame] | 28 | nfdc strategy set prefix / strategy /localhost/nfd/strategy/multicast |
Hila Ben Abraham | a36f0d1 | 2016-02-08 18:03:47 -0600 | [diff] [blame] | 29 | |
| 30 | # run traffic generator on B,C,D |
| 31 | ssh $CTRL_B "echo 'starting ndn-traffic-server on B' > $testLogB &\ |
| 32 | ndn-traffic-server $workDir/NDNTrafficServer.conf &> $logDir/serverB.log &" |
| 33 | ssh $CTRL_C "echo 'starting ndn-traffic-server on C' > $testLogC &\ |
| 34 | ndn-traffic-server $workDir/NDNTrafficServer.conf &> $logDir/serverC.log &" |
| 35 | ssh $CTRL_D "echo 'starting ndn-traffic-server on D' > $testLogD &\ |
| 36 | ndn-traffic-server $workDir/NDNTrafficServer.conf &> $logDir/serverD.log &" |
| 37 | |
Eric Newberry | 7745c1a | 2017-04-20 00:23:05 -0700 | [diff] [blame] | 38 | echo "setting up faces..." |
| 39 | |
| 40 | nfdc face create udp4://$IP4_B1:6363 >> $testLogA |
| 41 | nfdc face create udp4://$IP4_C1:6363 >> $testLogA |
| 42 | nfdc face create udp4://$IP4_D1:6363 >> $testLogA |
| 43 | |
Hila Ben Abraham | a36f0d1 | 2016-02-08 18:03:47 -0600 | [diff] [blame] | 44 | echo "setting up routes..." |
| 45 | |
| 46 | # on A, add ndn:/ , nexthop=hostB, CHILD_INHERIT=yes, CAPTURE=no |
Eric Newberry | 7745c1a | 2017-04-20 00:23:05 -0700 | [diff] [blame] | 47 | nfdc route add ndn:/ udp4://$IP4_B1:6363 >> $testLogA |
Hila Ben Abraham | a36f0d1 | 2016-02-08 18:03:47 -0600 | [diff] [blame] | 48 | |
| 49 | # on A, add ndn:/ , nexthop=hostC, CHILD_INHERIT=no, CAPTURE=no |
Eric Newberry | 7745c1a | 2017-04-20 00:23:05 -0700 | [diff] [blame] | 50 | nfdc route add ndn:/ udp4://$IP4_C1:6363 no-inherit >> $testLogA |
Hila Ben Abraham | a36f0d1 | 2016-02-08 18:03:47 -0600 | [diff] [blame] | 51 | |
| 52 | # on A, add ndn:/A , nexthop=hostB, CHILD_INHERIT=yes, CAPTURE=no |
Eric Newberry | 7745c1a | 2017-04-20 00:23:05 -0700 | [diff] [blame] | 53 | nfdc route add ndn:/A udp4://$IP4_B1:6363 >> $testLogA |
Hila Ben Abraham | a36f0d1 | 2016-02-08 18:03:47 -0600 | [diff] [blame] | 54 | |
| 55 | # on A, add ndn:/A/B/C , nexthop=hostD, CHILD_INHERIT=yes, CAPTURE=no |
Eric Newberry | 7745c1a | 2017-04-20 00:23:05 -0700 | [diff] [blame] | 56 | nfdc route add ndn:/A/B/C udp4://$IP4_D1:6363 >> $testLogA |
Hila Ben Abraham | a36f0d1 | 2016-02-08 18:03:47 -0600 | [diff] [blame] | 57 | |
| 58 | # on A, add ndn:/D , nexthop=hostC, CHILD_INHERIT=yes, CAPTURE=yes |
Eric Newberry | 7745c1a | 2017-04-20 00:23:05 -0700 | [diff] [blame] | 59 | nfdc route add ndn:/D udp4://$IP4_C1:6363 capture >> $testLogA |
Hila Ben Abraham | a36f0d1 | 2016-02-08 18:03:47 -0600 | [diff] [blame] | 60 | |
| 61 | # on A, add ndn:/D , nexthop=hostD, CHILD_INHERIT=yes, CAPTURE=no |
Eric Newberry | 7745c1a | 2017-04-20 00:23:05 -0700 | [diff] [blame] | 62 | nfdc route add ndn:/D udp4://$IP4_D1:6363 >> $testLogA |
Hila Ben Abraham | a36f0d1 | 2016-02-08 18:03:47 -0600 | [diff] [blame] | 63 | |
| 64 | sleep 2 |
| 65 | |
| 66 | |
| 67 | # run traffic generator clients on A |
| 68 | echo "running traffic generator client1..." |
| 69 | ndn-traffic -c 20 -i 200 $workDir/NDNTrafficClient1.conf > $logDir/client1.log 2>&1 |
| 70 | |
| 71 | echo "running traffic generator client2..." |
| 72 | ndn-traffic -c 20 -i 200 $workDir/NDNTrafficClient2.conf > $logDir/client2.log 2>&1 |
| 73 | |
| 74 | echo "running traffic generator client3..." |
| 75 | ndn-traffic -c 20 -i 200 $workDir/NDNTrafficClient3.conf > $logDir/client3.log 2>&1 |
| 76 | |
| 77 | echo "running traffic generator client4..." |
| 78 | ndn-traffic -c 20 -i 200 $workDir/NDNTrafficClient4.conf > $logDir/client4.log 2>&1 |
| 79 | |
| 80 | |
| 81 | # stop traffic generator server on B,C,D and kill local nfd |
| 82 | echo "killing ndn-traffic-server on B, C and D..." |
| 83 | ssh $CTRL_B "sudo killall ndn-traffic-server; sudo killall nfd >> $testLogB 2>&1" |
| 84 | ssh $CTRL_C "sudo killall ndn-traffic-server; sudo killall nfd >> $testLogC 2>&1" |
| 85 | ssh $CTRL_D "sudo killall ndn-traffic-server; sudo killall nfd >> $testLogD 2>&1" |
| 86 | sudo killall nfd 2>&1 |
| 87 | |
| 88 | sleep 2 |
| 89 | |
| 90 | # collect data from servers |
| 91 | scp $CTRL_B:$logDir/serverB.log $logDir/serverB.log |
| 92 | scp $CTRL_C:$logDir/serverC.log $logDir/serverC.log |
| 93 | scp $CTRL_D:$logDir/serverD.log $logDir/serverD.log |
| 94 | |
| 95 | #### verify server numbers of server B #### |
| 96 | echo "analyzing result of server B" |
| 97 | received=$(grep -A 1 "Name=ndn:/A/P," $logDir/serverB.log | grep "Total Interests Received" | |
| 98 | cut -d= -f2 | cut -d' ' -f2) |
| 99 | if [[ $received -lt 18 ]] |
| 100 | then |
| 101 | echo "FAIL: B received $received interests of ndn:/A/P out of the 20 sent by A. &\ |
| 102 | At least 18 were supposed to arrive at B due to CHILD_INHERIT flag of /A towards B." |
| 103 | exit 1 |
| 104 | fi |
| 105 | |
| 106 | received=$(grep -A 1 "Name=ndn:/A/B/C/Q," $logDir/serverB.log | grep "Total Interests Received" | |
| 107 | cut -d= -f2 | cut -d' ' -f2) |
| 108 | if [[ $received -lt 18 ]] |
| 109 | then |
| 110 | echo "FAIL: B received $received interests of ndn:/A/B/C/Q out of the 20 sent by A. &\ |
| 111 | At least 18 were supposed to arrive at B due to CHILD_INHERIT flag of /A towards B." |
| 112 | exit 1 |
| 113 | fi |
| 114 | |
| 115 | received=$(grep -A 1 "Name=ndn:/D/R," $logDir/serverB.log | grep "Total Interests Received" | |
| 116 | cut -d= -f2 | cut -d' ' -f2) |
| 117 | if [[ $received -ne 0 ]] |
| 118 | then |
| 119 | echo "FAIL: B received $received interests of ndn:/D/R out of 20 sent by A. &\ |
| 120 | There is no available route for ndn:/D/R at A towards B so 0 interests were supposed to arrive at B." |
| 121 | exit 1 |
| 122 | fi |
| 123 | |
| 124 | received=$(grep -A 1 "Name=ndn:/S," $logDir/serverB.log | grep "Total Interests Received" | |
| 125 | cut -d= -f2 | cut -d' ' -f2) |
| 126 | if [[ $received -lt 18 ]] |
| 127 | then |
| 128 | echo "FAIL: B received $received interests of ndn:/S out of the 20 sent by A. &\ |
| 129 | At least 18 were supposed to arrive at B due to CHILD_INHERIT flag of / towards B." |
| 130 | exit 1 |
| 131 | fi |
| 132 | |
| 133 | #### verify server numbers of server C #### |
| 134 | echo "analyzing result of server C" |
| 135 | received=$(grep -A 1 "Name=ndn:/A/P," $logDir/serverC.log | grep "Total Interests Received" | |
| 136 | cut -d= -f2 | cut -d' ' -f2) |
| 137 | if [[ $received -ne 0 ]] |
| 138 | then |
| 139 | echo "FAIL: C received $received interests of ndn:/A/P out of 20 sent by A. &\ |
| 140 | There is no available route for ndn:/A/P at A towards C so 0 interests were supposed to arrive at C." |
| 141 | exit 1 |
| 142 | fi |
| 143 | |
| 144 | received=$(grep -A 1 "Name=ndn:/A/B/C/Q," $logDir/serverC.log | grep "Total Interests Received" | |
| 145 | cut -d= -f2 | cut -d' ' -f2) |
| 146 | if [[ $received -ne 0 ]] |
| 147 | then |
| 148 | echo "FAIL: C received $received interests of ndn:/A/B/C/Q out of 20 sent by A. &\ |
| 149 | There is no available route for ndn:/A/B/C/Q at A towards C so 0 interests were supposed to arrive at C." |
| 150 | |
| 151 | exit 1 |
| 152 | fi |
| 153 | |
| 154 | received=$(grep -A 1 "Name=ndn:/D/R," $logDir/serverC.log | grep "Total Interests Received" | |
| 155 | cut -d= -f2 | cut -d' ' -f2) |
| 156 | if [[ $received -lt 18 ]] |
| 157 | then |
| 158 | echo "FAIL: C received $received interests of ndn:/D/R out of the 20 sent by A. &\ |
| 159 | At least 18 were supposed to arrive at C due to CHILD_INHERIT flag of /D towards C." |
| 160 | |
| 161 | exit 1 |
| 162 | fi |
| 163 | |
| 164 | received=$(grep -A 1 "Name=ndn:/S," $logDir/serverC.log | grep "Total Interests Received" | |
| 165 | cut -d= -f2 | cut -d' ' -f2) |
| 166 | if [[ $received -lt 18 ]] |
| 167 | then |
| 168 | echo "FAIL: C received $received interests of ndn:/S out of the 20 sent by A. &\ |
| 169 | Longest-prefix match of ndn:/S in A is ndn:/ and therefore at least 18 were supposed to arrive at C." |
| 170 | |
| 171 | exit 1 |
| 172 | fi |
| 173 | |
| 174 | #### verify server numbers of server D #### |
| 175 | echo "analyzing result of server D" |
| 176 | received=$(grep -A 1 "Name=ndn:/A/P," $logDir/serverD.log | grep "Total Interests Received" | |
| 177 | cut -d= -f2 | cut -d' ' -f2) |
| 178 | if [[ $received -ne 0 ]] |
| 179 | then |
| 180 | echo "FAIL: D received $received interests of ndn:/A/P out of 20 sent by A. &\ |
| 181 | There is no available route for ndn:/A/P at A towards D so 0 interests were supposed to arrive at D." |
| 182 | |
| 183 | exit 1 |
| 184 | fi |
| 185 | |
| 186 | received=$(grep -A 1 "Name=ndn:/A/B/C/Q," $logDir/serverD.log | grep "Total Interests Received" | |
| 187 | cut -d= -f2 | cut -d' ' -f2) |
| 188 | if [[ $received -lt 18 ]] |
| 189 | then |
| 190 | echo "FAIL: D received $received interests of ndn:/A/B/C/Q out of the 20 sent by A. &\ |
| 191 | At least 18 were supposed to arrive at D due to CHILD_INHERIT flag of /A/B/C towards D." |
| 192 | exit 1 |
| 193 | fi |
| 194 | |
| 195 | received=$(grep -A 1 "Name=ndn:/D/R," $logDir/serverD.log | grep "Total Interests Received" | |
| 196 | cut -d= -f2 | cut -d' ' -f2) |
| 197 | if [[ $received -lt 18 ]] |
| 198 | then |
| 199 | echo "FAIL: D received $received interests of ndn:/D/R out of the 20 sent by A. &\ |
| 200 | At least 18 were supposed to arrive at D due to CHILD_INHERIT flag of /D towards D." |
| 201 | exit 1 |
| 202 | fi |
| 203 | |
| 204 | received=$(grep -A 1 "Name=ndn:/S," $logDir/serverD.log | grep "Total Interests Received" | |
| 205 | cut -d= -f2 | cut -d' ' -f2) |
| 206 | if [[ $received -ne 0 ]] |
| 207 | then |
| 208 | echo "FAIL: D received $received interests of ndn:/S out of 20 sent by A. &\ |
| 209 | There is no available route for ndn:/S at A towards D so 0 interests were supposed to arrive at D." |
| 210 | exit 1 |
| 211 | fi |
| 212 | |
| 213 | echo "Test passed successfully" |
| 214 | exit 0 |