Hila Ben Abraham | 47583d1 | 2014-05-22 04:39:31 -0500 | [diff] [blame] | 1 | #!/usr/bin/env bash |
| 2 | source ../multi-host.conf |
| 3 | source include.sh |
| 4 | workdir=$(pwd) |
| 5 | mkdir -p $workdir/logs |
| 6 | testCase=$1 |
| 7 | testLog=$workdir/logs/nfdc_test_$testCase.log |
| 8 | |
| 9 | echo "TEST START" > $testLog |
| 10 | |
| 11 | start_nfd |
| 12 | |
| 13 | # run test case A: test nfdc create / add-nexthop / destroy test case |
| 14 | if [[ $testCase == 'A' ]]; then |
| 15 | |
| 16 | # Check for the existence of mcast address udp4://224.0.23.170 |
| 17 | udp4Mcast=$(nfd-status | grep udp4://224.0.23.170) |
| 18 | udp6Mcast=$(nfd-status | grep -iF udp6://[ff00) |
| 19 | ethv4=$(nfd-status | grep -iF ether://[01:00:5E:) |
| 20 | ethv6=$(nfd-status | grep -iF ether://[33:33:) |
| 21 | |
| 22 | if [[ -z "$udp4Mcast" ]] && [[ -z "$udp6Mcast" ]] && [[ -z "$ethv4" ]] && [[ -z "$ethv6" ]]; then |
| 23 | echo "nfd-status: Failed to find udp4/udp6/ether multicast faces" >> $testLog |
| 24 | echo "nfd-status is:" >> $testLog |
| 25 | nfd-status >> $testLog |
| 26 | clean_up |
| 27 | exit 2 |
| 28 | fi |
| 29 | |
| 30 | # Invoke nfdc create tcp://$IP4_B1. |
| 31 | faceIdTcp4=$(nfdc create tcp4://$IP4_B1 | grep -Po 'FaceId: .*?,' | sed 's/FaceId: //' | sed 's/,//') |
| 32 | sleep 2 |
| 33 | face=$(check_nfd_status_face_existence $faceIdTcp4 tcp4://$IP4_B1) |
| 34 | if [ "-1" = $face ]; then |
| 35 | clean_up |
| 36 | exit 2 |
| 37 | fi |
| 38 | |
| 39 | #compress IPv6 |
| 40 | IP6_B1=$(python -c "import sys; import socket; result = socket.getaddrinfo('$IP6_B1', None); family, socktype, proto, canonname,(address, port, flow_info, scope_id) = result[0]; print address") |
| 41 | |
| 42 | # Invoke nfdc create tcp://$IP6_B1. |
| 43 | faceIdTcp6=$(nfdc create tcp6://[$IP6_B1] | grep -Po 'FaceId: .*?,' | sed 's/FaceId: //' | sed 's/,//') |
| 44 | sleep 2 |
| 45 | face=$(check_nfd_status_face_existence $faceIdTcp6 tcp6://[$IP6_B1]) |
| 46 | if [ "-1" = $face ]; then |
| 47 | clean_up |
| 48 | exit 2 |
| 49 | fi |
| 50 | |
| 51 | # Invoke nfdc create udp://$IP4_B1. |
| 52 | faceIdUdp4=$(nfdc create udp4://$IP4_B1 | grep -Po 'FaceId: .*?,' | sed 's/FaceId: //' | sed 's/,//') |
| 53 | sleep 2 |
| 54 | |
| 55 | face=$(check_nfd_status_face_existence $faceIdUdp4 udp4://$IP4_B1) |
| 56 | if [ "-1" = $face ]; then |
| 57 | clean_up |
| 58 | exit 2 |
| 59 | fi |
| 60 | |
| 61 | |
| 62 | # Invoke nfdc create udp://$IP6_B1. |
| 63 | faceIdUdp6=$(nfdc create udp6://[$IP6_B1] | grep -Po 'FaceId: .*?,' | sed 's/FaceId: //' | sed 's/,//') |
| 64 | sleep 2 |
| 65 | face=$(check_nfd_status_face_existence $faceIdUdp6 udp6://[$IP6_B1]) |
| 66 | if [ "-1" = $face ]; then |
| 67 | clean_up |
| 68 | exit 2 |
| 69 | fi |
| 70 | |
| 71 | # Invoke nfdc to add next hops |
| 72 | nfdc add-nexthop -c 24 ndn:/test-nfdc $faceIdTcp4 |
| 73 | nfdc add-nexthop -c 26 ndn:/test-nfdc $faceIdTcp6 |
| 74 | nfdc add-nexthop -c 14 ndn:/test-nfdc $faceIdUdp4 |
| 75 | nfdc add-nexthop -c 16 ndn:/test-nfdc $faceIdUdp6 |
| 76 | |
| 77 | # check correctness of add-nexthop -c 24 ndn:/test-nfdc $faceIdTcp4 |
| 78 | check_nfd_status_correctness $faceIdTcp4 tcp4://$IP4_B1 /test-nfdc 24 |
| 79 | |
| 80 | # check correctness of add-nexthop -c 26 ndn:/test-nfdc $faceIdTcp6 |
| 81 | check_nfd_status_correctness $faceIdTcp6 tcp6://[$IP6_B1] /test-nfdc 26 |
| 82 | |
| 83 | # check correctness of add-nexthop -c 14 ndn:/test-nfdc $faceIdUdp4 |
| 84 | check_nfd_status_correctness $faceIdUdp4 udp4://$IP4_B1 /test-nfdc 14 |
| 85 | |
| 86 | # check correctness of add-nexthop -c 16 ndn:/test-nfdc $faceIdUdp6 |
| 87 | check_nfd_status_correctness $faceIdUdp6 udp6://[$IP6_B1] /test-nfdc 16 |
| 88 | |
| 89 | # Invoke nfdc to choose BroadcastStrategy for ndn:/ namespace. |
| 90 | nfdc set-strategy ndn:/ ndn:/localhost/nfd/strategy/broadcast |
| 91 | |
| 92 | ndnping ndn:/test-nfdc -c $NUM_OF_PINGS |
| 93 | |
| 94 | check_nfd_status_counters $faceIdTcp4 tcp4://$IP4_B1 out $NUM_OF_PINGS |
| 95 | check_nfd_status_counters $faceIdTcp6 tcp6://[$IP6_B1] out $NUM_OF_PINGS |
| 96 | check_nfd_status_counters $faceIdUdp4 udp4://$IP4_B1 out $NUM_OF_PINGS |
| 97 | check_nfd_status_counters $faceIdUdp6 udp6://[$IP6_B1] out $NUM_OF_PINGS |
| 98 | |
| 99 | ssh $CTRL_B "$workdir/test-B.sh $workdir" |
| 100 | if [[ $? -ne 0 ]]; then |
| 101 | echo "Failed to verify correctness on node B" >> $testLog |
| 102 | clean_up |
| 103 | exit 3 |
| 104 | fi |
| 105 | |
| 106 | nfdc destroy $faceIdTcp4 |
| 107 | echo "after nfdc destroy $faceIdTcp4" >> $testLog |
| 108 | face=$(check_nfd_status_face_existence $faceIdTcp4 tcp4://$IP4_B1) |
| 109 | if [ "-1" != $face ]; then |
| 110 | echo "face $faceIdTcp4 still exists after nfdc destory" >> $testLog |
| 111 | clean_up |
| 112 | exit 2 |
| 113 | fi |
| 114 | |
| 115 | nfdc destroy $faceIdTcp6 |
| 116 | echo "after nfdc destroy $faceIdTcp6" >> $testLog |
| 117 | face=$(check_nfd_status_face_existence $faceIdTcp6 tcp6://[$IP6_B1]) |
| 118 | if [ "-1" != $face ]; then |
| 119 | clean_up |
| 120 | exit 2 |
| 121 | fi |
| 122 | |
| 123 | clean_up |
| 124 | |
| 125 | # run test case B: nfdc add-nexthop / remove-nexthop test case |
| 126 | elif [[ $testCase == 'B' ]]; then |
| 127 | |
| 128 | # Invoke nfdc to add next hop |
| 129 | faceId=$(nfdc add-nexthop -c 44 ndn:/test-nfdc udp4://$IP4_B1 | grep -Po 'FaceId: .*?,' | sed 's/FaceId: //' | sed 's/,//') |
| 130 | if [[ "ERROR" == $faceId* ]] |
| 131 | then |
| 132 | echo "nfdc: Failed to add nexthop for $IP4_B1" >> $testLog |
| 133 | clean_up |
| 134 | exit 1 |
| 135 | fi |
| 136 | |
| 137 | check_nfd_status_correctness $faceId udp4://$IP4_B1 /test-nfdc 44 |
| 138 | |
| 139 | # invoke nfdc to remove the nexthop for created FaceId |
| 140 | removeNextHop=$(nfdc remove-nexthop ndn:/test-nfdc $faceId) |
| 141 | |
| 142 | # check the existence of ndn:/test-nfdc FIB entry |
| 143 | fibEntry=$(nfd-status | grep /test-nfdc) |
| 144 | if [ ! -z "$fibEntry" ]; then |
| 145 | echo "nfd-status: Failed to delete ndn:/test-nfdc FIB entry" >> $testLog |
| 146 | clean_up |
| 147 | exit 2 |
| 148 | fi |
| 149 | clean_up |
| 150 | |
| 151 | # run test case C: test nfdc register / unregister test case |
| 152 | elif [[ $testCase == 'C' ]]; then |
| 153 | |
| 154 | # run nrd |
| 155 | start_nrd |
| 156 | |
| 157 | # Invoke nfdc register a new prefix |
| 158 | faceId=$(nfdc register -c 55 ndn:/test-nfdc udp4://$IP4_B1 | grep -Po 'FaceId: .*?,' | sed 's/FaceId: //' | sed 's/,//') |
| 159 | if [[ "ERROR" == $faceId* ]]; then |
| 160 | echo "nfdc: Failed to register ndn:/test-nfdc for $IP4_B1" >> $testLog |
| 161 | clean_up |
| 162 | exit 1 |
| 163 | fi |
| 164 | check_nfd_status_correctness $faceId udp4://$IP4_B1 /test-nfdc 55 |
| 165 | |
| 166 | # Invoke nfdc to unregister the prefix |
| 167 | unregisterPrefix=$(nfdc unregister ndn:/test-nfdc $faceId) |
| 168 | |
| 169 | # check the existence of ndn:/test-nfdc FIB entry |
| 170 | fibEntry=$(nfd-status | grep /test-nfdc) |
| 171 | if [ ! -z "$fibEntry" ]; then |
| 172 | echo "nfd-status: Failed to unregister prefix" >> $testLog |
| 173 | clean_up |
| 174 | exit 2 |
| 175 | fi |
| 176 | clean_up |
| 177 | fi |
| 178 | |
| 179 | clean_up |
| 180 | exit 0 |
| 181 | |