1 #!/bin/sh 2 3 THIS_DIR=`dirname $0` 4 5 TEMPLATES="$THIS_DIR/templates" 6 PERSON_SCRIPT="$THIS_DIR/../imip_person.py" 7 RESOURCE_SCRIPT="$THIS_DIR/../imip_resource.py" 8 SHOWMAIL="$THIS_DIR/../tools/showmail.py" 9 STORE=/tmp/store 10 STATIC=/tmp/static 11 PREFS=/tmp/prefs 12 ARGS="-S $STORE -P $STATIC -p $PREFS -d" 13 USER="mailto:resource-room-sauna@example.com" 14 SENDER="mailto:paul.boddie@example.com" 15 RIVALSENDER="mailto:vincent.vole@example.com" 16 FBFILE="$STORE/$USER/freebusy" 17 FBOFFERFILE="$STORE/$USER/freebusy-offers" 18 FBSENDERFILE="$STORE/$SENDER/freebusy" 19 FBSENDEROTHERFILE="$STORE/$SENDER/freebusy-other/$USER" 20 FBSENDERREQUESTS="$STORE/$SENDER/requests" 21 FBRIVALSENDERFILE="$STORE/$RIVALSENDER/freebusy" 22 TAB=`printf '\t'` 23 24 OUTGOING_SCRIPT="$THIS_DIR/../imip_person_outgoing.py" 25 26 ERROR=err.tmp 27 28 rm -r $STORE 29 rm -r $STATIC 30 rm -r $PREFS 31 rm $ERROR 32 rm out*.tmp 33 34 mkdir -p "$PREFS/$USER" 35 echo 'Europe/Oslo' > "$PREFS/$USER/TZID" 36 echo 'share' > "$PREFS/$USER/freebusy_sharing" 37 echo '10,12,14,16,18:0,15,30,45' > "$PREFS/$USER/permitted_times" 38 echo 'PT60S' > "$PREFS/$USER/freebusy_offers" 39 40 "$RESOURCE_SCRIPT" $ARGS < "$TEMPLATES/fb-request-sauna-all.txt" 2>> $ERROR \ 41 | "$SHOWMAIL" \ 42 > out0.tmp 43 44 grep -q 'METHOD:REPLY' out0.tmp \ 45 && ! grep -q '^FREEBUSY' out0.tmp \ 46 && echo "Success" \ 47 || echo "Failed" 48 49 # Attempt to schedule an event. 50 51 "$OUTGOING_SCRIPT" $ARGS < "$TEMPLATES/event-request-sauna-bad.txt" 2>> $ERROR 52 53 grep -q "^20141126T151000Z${TAB}20141126T154500Z" "$FBSENDERFILE" \ 54 && echo "Success" \ 55 || echo "Failed" 56 57 # Present the request to the resource. 58 59 "$RESOURCE_SCRIPT" $ARGS < "$TEMPLATES/event-request-sauna-bad.txt" 2>> $ERROR \ 60 | tee out1r.tmp \ 61 | "$SHOWMAIL" \ 62 > out1.tmp 63 64 grep -q 'METHOD:COUNTER' out1.tmp \ 65 && grep -q 'DTSTART;TZID=Europe/Oslo.*:20141126T161500' out1.tmp \ 66 && echo "Success" \ 67 || echo "Failed" 68 69 ! [ -e "$FBFILE" ] \ 70 || ! grep -q "^20141126T151500Z${TAB}20141126T154500Z" "$FBFILE" \ 71 && echo "Success" \ 72 || echo "Failed" 73 74 grep -q "^20141126T151500Z${TAB}20141126T154500Z" "$FBOFFERFILE" \ 75 && echo "Success" \ 76 || echo "Failed" 77 78 # Present the response to the organiser. 79 80 "$PERSON_SCRIPT" $ARGS < out1r.tmp 2>> $ERROR \ 81 | tee out2r.tmp \ 82 | "$SHOWMAIL" \ 83 > out2.tmp 84 85 ! grep -q "^20141126T151000Z${TAB}20141126T154500Z" "$FBSENDEROTHERFILE" \ 86 && echo "Success" \ 87 || echo "Failed" 88 89 grep -q 'ATTENDEE.*;PARTSTAT=DECLINED' "$STORE/$SENDER/objects/event13@example.com" \ 90 && grep -q 'DTSTART;TZID=Europe/Oslo.*:20141126T161000' "$STORE/$SENDER/objects/event13@example.com" \ 91 && echo "Success" \ 92 || echo "Failed" 93 94 grep -q 'DTSTART;TZID=Europe/Oslo.*:20141126T161500' "$STORE/$SENDER/counters/objects/event13@example.com/$USER" \ 95 && echo "Success" \ 96 || echo "Failed" 97 98 grep -q 'event13@example.com' "$FBSENDERREQUESTS" \ 99 && echo "Success" \ 100 || echo "Failed" 101 102 # Attempt to schedule an event in the proposed period. 103 104 "$OUTGOING_SCRIPT" $ARGS < "$TEMPLATES/event-request-sauna-rival.txt" 2>> $ERROR 105 106 ! grep -q "^20141126T151000Z${TAB}20141126T154500Z" "$FBRIVALSENDERFILE" \ 107 && grep -q "^20141126T153000Z${TAB}20141126T154500Z" "$FBRIVALSENDERFILE" \ 108 && echo "Success" \ 109 || echo "Failed" 110 111 # Present the request to the resource. 112 113 "$RESOURCE_SCRIPT" $ARGS < "$TEMPLATES/event-request-sauna-rival.txt" 2>> $ERROR \ 114 | "$SHOWMAIL" \ 115 > out3.tmp 116 117 grep -q 'METHOD:REPLY' out3.tmp \ 118 && grep -q 'ATTENDEE.*;PARTSTAT=DECLINED' out3.tmp \ 119 && echo "Success" \ 120 || echo "Failed" 121 122 # Present the response to the organiser. 123 124 "$PERSON_SCRIPT" $ARGS < out3.tmp 2>> $ERROR \ 125 | tee out4r.tmp \ 126 | "$SHOWMAIL" \ 127 > out4.tmp 128 129 ! grep -q "^20141126T151000Z${TAB}20141126T154500Z" "$FBRIVALSENDERFILE" \ 130 && grep -q "^20141126T153000Z${TAB}20141126T154500Z" "$FBRIVALSENDERFILE" \ 131 && echo "Success" \ 132 || echo "Failed" 133 134 grep -q 'ATTENDEE.*;PARTSTAT=DECLINED' "$STORE/$RIVALSENDER/objects/event18@example.com" \ 135 && echo "Success" \ 136 || echo "Failed" 137 138 # Check the free/busy state of the resource so far. 139 140 "$RESOURCE_SCRIPT" $ARGS < "$TEMPLATES/fb-request-sauna-all.txt" 2>> $ERROR \ 141 | "$SHOWMAIL" \ 142 > out5.tmp 143 144 grep -q 'METHOD:REPLY' out5.tmp \ 145 && ! grep -q 'FREEBUSY;FBTYPE=BUSY:20141126T151000Z/20141126T154500Z' out5.tmp \ 146 && ! grep -q 'FREEBUSY;FBTYPE=BUSY:20141126T151500Z/20141126T154500Z' out5.tmp \ 147 && ! grep -q 'FREEBUSY;FBTYPE=BUSY:20141126T153000Z/20141126T154500Z' out5.tmp \ 148 && echo "Success" \ 149 || echo "Failed" 150 151 # Attempt to schedule again in response to the counter-proposal. 152 153 "$OUTGOING_SCRIPT" $ARGS < "$TEMPLATES/event-request-sauna-good.txt" 2>> $ERROR 154 155 ! grep -q "^20141126T151000Z${TAB}20141126T154500Z" "$FBSENDERFILE" \ 156 && ! grep -q "^20141126T151500Z${TAB}20141126T154500Z" "$FBSENDERFILE" \ 157 && ! grep -q "^20141126T153000Z${TAB}20141126T154500Z" "$FBSENDERFILE" \ 158 && echo "Success" \ 159 || echo "Failed" 160 161 [ ! -e "$STORE/$SENDER/counters/objects/event13@example.com/$USER" ] \ 162 && echo "Success" \ 163 || echo "Failed" 164 165 ! grep -q 'event13@example.com' "$FBSENDERREQUESTS" \ 166 && echo "Success" \ 167 || echo "Failed" 168 169 # Present the request to the resource. 170 171 "$RESOURCE_SCRIPT" $ARGS < "$TEMPLATES/event-request-sauna-good.txt" 2>> $ERROR \ 172 | "$SHOWMAIL" \ 173 > out6.tmp 174 175 grep -q 'METHOD:REPLY' out6.tmp \ 176 && grep -q 'ATTENDEE.*;PARTSTAT=ACCEPTED' out6.tmp \ 177 && echo "Success" \ 178 || echo "Failed" 179 180 grep -q "^20141126T150000Z${TAB}20141126T154500Z" "$FBFILE" \ 181 && echo "Success" \ 182 || echo "Failed" 183 184 ! grep -q "^20141126T150000Z${TAB}20141126T154500Z" "$FBOFFERFILE" \ 185 && ! grep -q "^20141126T151500Z${TAB}20141126T154500Z" "$FBOFFERFILE" \ 186 && ! grep -q "^20141126T153000Z${TAB}20141126T154500Z" "$FBOFFERFILE" \ 187 && echo "Success" \ 188 || echo "Failed" 189 190 # Present the response to the organiser. 191 192 "$PERSON_SCRIPT" $ARGS < out6.tmp 2>> $ERROR \ 193 | tee out7r.tmp \ 194 | "$SHOWMAIL" \ 195 > out7.tmp 196 197 grep -q "^20141126T150000Z${TAB}20141126T154500Z" "$FBSENDERFILE" \ 198 && ! grep -q "^20141126T151000Z${TAB}20141126T154500Z" "$FBSENDERFILE" \ 199 && ! grep -q "^20141126T151500Z${TAB}20141126T154500Z" "$FBSENDERFILE" \ 200 && ! grep -q "^20141126T153000Z${TAB}20141126T154500Z" "$FBSENDERFILE" \ 201 && echo "Success" \ 202 || echo "Failed" 203 204 [ ! -e "$STORE/$SENDER/counters/objects/event13@example.com/$USER" ] \ 205 && echo "Success" \ 206 || echo "Failed" 207 208 ! grep -q 'event13@example.com' "$FBSENDERREQUESTS" \ 209 && echo "Success" \ 210 || echo "Failed" 211 212 # Check the free/busy state of the resource again. 213 214 "$RESOURCE_SCRIPT" $ARGS < "$TEMPLATES/fb-request-sauna-all.txt" 2>> $ERROR \ 215 | "$SHOWMAIL" \ 216 > out6.tmp 217 218 grep -q 'METHOD:REPLY' out6.tmp \ 219 && grep -q 'FREEBUSY;FBTYPE=BUSY:20141126T150000Z/20141126T154500Z' out6.tmp \ 220 && ! grep -q 'FREEBUSY;FBTYPE=BUSY:20141126T151000Z/20141126T154500Z' out6.tmp \ 221 && ! grep -q 'FREEBUSY;FBTYPE=BUSY:20141126T151500Z/20141126T154500Z' out6.tmp \ 222 && ! grep -q 'FREEBUSY;FBTYPE=BUSY:20141126T153000Z/20141126T154500Z' out6.tmp \ 223 && echo "Success" \ 224 || echo "Failed"