Eric Newberry | c22afde | 2018-06-19 01:28:31 -0700 | [diff] [blame^] | 1 | #!/bin/bash |
| 2 | source ../multi-host.conf |
| 3 | |
| 4 | clean_up() { |
| 5 | r=$(sudo killall ndn-traffic-server 2>&1) |
| 6 | r=$(sudo killall ndn-traffic 2>&1) |
| 7 | r=$(sudo killall nfd 2>&1) |
| 8 | } |
| 9 | |
| 10 | # A: Start NFD |
| 11 | workdir=$(pwd) |
| 12 | echo "Starting nfd on A..." |
| 13 | mkdir -p $workdir/logs; sudo nfd &> $workdir/logs/nfd.log & |
| 14 | sleep 1 |
| 15 | |
| 16 | # A: Start instances of ndn-traffic-server |
| 17 | echo "Starting Traffic Server 1 (Prefix=/, FreshnessPeriod=10ms, Data=Z)..." |
| 18 | ndn-traffic-server $workdir/test-traffic-server-1.conf &> $workdir/logs/server-1.log & |
| 19 | sleep 0.1 |
| 20 | echo "Starting Traffic Server 2 (Prefix=/A, FreshnessPeriod=10ms, Data=A)..." |
| 21 | ndn-traffic-server $workdir/test-traffic-server-2.conf &> $workdir/logs/server-2.log & |
| 22 | sleep 0.1 |
| 23 | echo "Starting Traffic Server 3 (Prefix=/A/B/C, FreshnessPeriod=10ms, Data=C)..." |
| 24 | ndn-traffic-server $workdir/test-traffic-server-3.conf &> $workdir/logs/server-3.log & |
| 25 | sleep 0.1 |
| 26 | echo "Starting Traffic Server 4 (Prefix=/D/E, FreshnessPeriod=10ms, Data=E)..." |
| 27 | ndn-traffic-server $workdir/test-traffic-server-4.conf &> $workdir/logs/server-4.log & |
| 28 | sleep 0.1 |
| 29 | |
| 30 | # A: Request / with MustBeFresh=true. Fail if unanswered or if received content is not "Z". |
| 31 | echo "Starting Traffic Client 1 (Prefix=/, MustBeFresh=true, ExpectedContent=Z, MaxSuffixComponents=2)..." |
| 32 | ndn-traffic -c 1 $workdir/test-traffic-client-1.conf &> $workdir/logs/client-1.log |
| 33 | outcode=$? |
| 34 | if [[ $outcode -ne 0 ]]; then |
| 35 | echo "Received non-zero exit code from Traffic Client 1. Actual: $outcode" |
| 36 | clean_up |
| 37 | exit 1 |
| 38 | fi |
| 39 | echo "Traffic Client 1 received Data with Content=Z" |
| 40 | |
| 41 | # Sleep for 100ms |
| 42 | sleep 0.1 |
| 43 | |
| 44 | # A: Request /F with MustBeFresh=true. Fail if unanswered or if received content is not "Z". |
| 45 | echo "Starting Traffic Client 2 (Prefix=/F, MustBeFresh=true, ExpectedContent=Z)..." |
| 46 | ndn-traffic -c 1 $workdir/test-traffic-client-2.conf &> $workdir/logs/client-2.log |
| 47 | outcode=$? |
| 48 | if [[ $outcode -ne 0 ]]; then |
| 49 | echo "Received non-zero exit code from Traffic Client 2. Actual: $outcode" |
| 50 | clean_up |
| 51 | exit 1 |
| 52 | fi |
| 53 | echo "Traffic Client 2 received Data with Content=Z" |
| 54 | |
| 55 | # Sleep for 100ms |
| 56 | sleep 0.1 |
| 57 | |
| 58 | # A: Request /A with MustBeFresh=true. Fail if unanswered or if received content is not "A" |
| 59 | echo "Starting Traffic Client 3 (Prefix=/A, MustBeFresh=true, ExpectedContent=A)..." |
| 60 | ndn-traffic -c 1 $workdir/test-traffic-client-3.conf &> $workdir/logs/client-3.log |
| 61 | outcode=$? |
| 62 | if [[ $outcode -ne 0 ]]; then |
| 63 | echo "Received non-zero exit code from Traffic Client 3. Actual: $outcode" |
| 64 | clean_up |
| 65 | exit 1 |
| 66 | fi |
| 67 | echo "Traffic Client 3 received Data with Content=A" |
| 68 | |
| 69 | # Sleep for 100ms |
| 70 | sleep 0.1 |
| 71 | |
| 72 | # A: Request /a with MustBeFresh=true. Fail if unanswered or if received content is not "Z". |
| 73 | echo "Starting Traffic Client 4 (Prefix=/a, MustBeFresh=true, ExpectedContent=Z)..." |
| 74 | ndn-traffic -c 1 $workdir/test-traffic-client-4.conf &> $workdir/logs/client-4.log |
| 75 | outcode=$? |
| 76 | if [[ $outcode -ne 0 ]]; then |
| 77 | echo "Received non-zero exit code from Traffic Client 4. Actual: $outcode" |
| 78 | clean_up |
| 79 | exit 1 |
| 80 | fi |
| 81 | echo "Traffic Client 4 received Data with Content=Z" |
| 82 | |
| 83 | # Sleep for 100ms |
| 84 | sleep 0.1 |
| 85 | |
| 86 | # A: Request /A/B with MustBeFresh=true. Fail if unanswered or if received content is not "A". |
| 87 | echo "Starting Traffic Client 5 (Prefix=/A/B, MustBeFresh=true, ExpectedContent=A)..." |
| 88 | ndn-traffic -c 1 $workdir/test-traffic-client-5.conf &> $workdir/logs/client-5.log |
| 89 | outcode=$? |
| 90 | if [[ $outcode -ne 0 ]]; then |
| 91 | echo "Received non-zero exit code from Traffic Client 5. Actual: $outcode" |
| 92 | clean_up |
| 93 | exit 1 |
| 94 | fi |
| 95 | echo "Traffic Client 5 received Data with Content=A" |
| 96 | |
| 97 | # Sleep for 100ms |
| 98 | sleep 0.1 |
| 99 | |
| 100 | # A: Request /A/B/G with MustBeFresh=true. Fail if unanswered or if received content is not "A". |
| 101 | echo "Starting Traffic Client 6 (Prefix=/A/B/G, MustBeFresh=true, ExpectedContent=A)..." |
| 102 | ndn-traffic -c 1 $workdir/test-traffic-client-6.conf &> $workdir/logs/client-6.log |
| 103 | outcode=$? |
| 104 | if [[ $outcode -ne 0 ]]; then |
| 105 | echo "Received non-zero exit code from Traffic Client 6. Actual: $outcode" |
| 106 | clean_up |
| 107 | exit 1 |
| 108 | fi |
| 109 | echo "Traffic Client 6 received Data with Content=A" |
| 110 | |
| 111 | # Sleep for 100ms |
| 112 | sleep 0.1 |
| 113 | |
| 114 | # A: Request /A/B/C with MustBeFresh=true. Fail if unanswered or if received content is not "C". |
| 115 | echo "Starting Traffic Client 7 (Prefix=/A/B/C, MustBeFresh=true, ExpectedContent=C)..." |
| 116 | ndn-traffic -c 1 $workdir/test-traffic-client-7.conf &> $workdir/logs/client-7.log |
| 117 | outcode=$? |
| 118 | if [[ $outcode -ne 0 ]]; then |
| 119 | echo "Received non-zero exit code from Traffic Client 7. Actual: $outcode" |
| 120 | clean_up |
| 121 | exit 1 |
| 122 | fi |
| 123 | echo "Traffic Client 7 received Data with Content=C" |
| 124 | |
| 125 | # Sleep for 100ms |
| 126 | sleep 0.1 |
| 127 | |
| 128 | # A: Request /A/B/C/P/Q/R/S/T/U/V/W/X/Y/Z with MustBeFresh=true. Fail if unanswered or if received |
| 129 | # content is not "C". |
| 130 | echo "Starting Traffic Client 8 (Prefix=/A/B/C/P/Q/R/S/T/U/V/W/X/Y/Z, MustBeFresh=true, ExpectedContent=C)..." |
| 131 | ndn-traffic -c 1 $workdir/test-traffic-client-8.conf &> $workdir/logs/client-8.log |
| 132 | outcode=$? |
| 133 | if [[ $outcode -ne 0 ]]; then |
| 134 | echo "Received non-zero exit code from Traffic Client 8. Actual: $outcode" |
| 135 | clean_up |
| 136 | exit 1 |
| 137 | fi |
| 138 | echo "Traffic Client 8 received Data with Content=C" |
| 139 | |
| 140 | # Sleep for 100ms |
| 141 | sleep 0.1 |
| 142 | |
| 143 | # A: Request /D with MustBeFresh=true and Exclude=[...,D]. Fail if unanswered or if received content |
| 144 | # is not "Z". |
| 145 | echo "Starting Traffic Client 9 (Prefix=/D, MustBeFresh=true, ExcludeRange=...,D, ExpectedContent=Z)..." |
| 146 | ndn-traffic -c 1 $workdir/test-traffic-client-9.conf &> $workdir/logs/client-9.log |
| 147 | outcode=$? |
| 148 | if [[ $outcode -ne 0 ]]; then |
| 149 | echo "Received non-zero exit code from Traffic Client 9. Actual: $outcode" |
| 150 | clean_up |
| 151 | exit 1 |
| 152 | fi |
| 153 | echo "Traffic Client 9 received Data with Content=Z" |
| 154 | |
| 155 | # Sleep for 100ms |
| 156 | sleep 0.1 |
| 157 | |
| 158 | # A: Request /D with MustBeFresh=true and Exclude=[...,E]. Fail if unanswered or if received content |
| 159 | # is not "Z". |
| 160 | echo "Starting Traffic Client 10 (Prefix=/D MustBeFresh=true, ExcludeRange=...,E, ExpectedContent=Z)..." |
| 161 | outcode=$? |
| 162 | if [[ $outcode -ne 0 ]]; then |
| 163 | echo "Received non-zero exit code from Traffic Client 10. Actual: $outcode" |
| 164 | clean_up |
| 165 | exit 1 |
| 166 | fi |
| 167 | echo "Traffic Client 10 received Data with Content=Z" |
| 168 | |
| 169 | clean_up |