paul@1185 | 1 | #!/bin/sh |
paul@1185 | 2 | |
paul@1185 | 3 | . "`dirname \"$0\"`/common.sh" |
paul@1185 | 4 | |
paul@1185 | 5 | USER1="mailto:resource-car-porsche911@example.com" |
paul@1185 | 6 | USER2="mailto:resource-car-fiat500@example.com" |
paul@1185 | 7 | SENDER1="mailto:paul.boddie@example.com" |
paul@1185 | 8 | SENDER2="mailto:vincent.vole@example.com" |
paul@1185 | 9 | USER1ADDRESS="resource-car-porsche911@example.com" |
paul@1185 | 10 | USER2ADDRESS="resource-car-fiat500@example.com" |
paul@1185 | 11 | SENDER1ADDRESS="paul.boddie@example.com" |
paul@1185 | 12 | SENDER2ADDRESS="vincent.vole@example.com" |
paul@1185 | 13 | QUOTA=cars |
paul@1185 | 14 | OTHER_QUOTA=rooms |
paul@1185 | 15 | |
paul@1188 | 16 | # Test delegation using the "most-available" policy and without using the |
paul@1188 | 17 | # explicit schedule_in_freebusy function since multiple concurrent reservations |
paul@1188 | 18 | # are to occur without any limits. |
paul@1188 | 19 | |
paul@1188 | 20 | # The result should be the reservation of USER1, then the reservation of both |
paul@1188 | 21 | # USER1 and USER2, followed by an attempt to reserve USER1 that results in the |
paul@1188 | 22 | # delegation to USER2 because USER2 is less committed (more available) during |
paul@1188 | 23 | # the period concerned. |
paul@1188 | 24 | |
paul@1185 | 25 | mkdir -p "$PREFS/$USER1" |
paul@1185 | 26 | echo 'Europe/Oslo' > "$PREFS/$USER1/TZID" |
paul@1185 | 27 | echo 'share' > "$PREFS/$USER1/freebusy_sharing" |
paul@1185 | 28 | cat > "$PREFS/$USER1/scheduling_function" <<EOF |
paul@1185 | 29 | schedule_for_delegate $QUOTA most-available |
paul@1185 | 30 | EOF |
paul@1185 | 31 | |
paul@1185 | 32 | mkdir -p "$PREFS/$USER2" |
paul@1185 | 33 | echo 'Europe/Oslo' > "$PREFS/$USER2/TZID" |
paul@1185 | 34 | echo 'share' > "$PREFS/$USER2/freebusy_sharing" |
paul@1185 | 35 | cat > "$PREFS/$USER2/scheduling_function" <<EOF |
paul@1185 | 36 | schedule_for_delegate $QUOTA most-available |
paul@1185 | 37 | EOF |
paul@1185 | 38 | |
paul@1185 | 39 | # Have a common group for all organisers when scheduling. |
paul@1185 | 40 | |
paul@1185 | 41 | cat <<EOF | "$SET_QUOTA_GROUPS" "$QUOTA" $SET_QUOTA_GROUPS_ARGS |
paul@1185 | 42 | * all |
paul@1185 | 43 | EOF |
paul@1185 | 44 | |
paul@1185 | 45 | # Set a common quota. |
paul@1185 | 46 | |
paul@1185 | 47 | cat <<EOF | "$SET_QUOTA_LIMITS" "$QUOTA" $SET_QUOTA_LIMITS_ARGS |
paul@1185 | 48 | all * |
paul@1185 | 49 | EOF |
paul@1185 | 50 | |
paul@1185 | 51 | # Allow cars to delegate to each other. |
paul@1185 | 52 | |
paul@1185 | 53 | cat <<EOF | "$SET_DELEGATES" "$QUOTA" $SET_DELEGATES_ARGS |
paul@1185 | 54 | mailto:resource-car-porsche911@example.com |
paul@1185 | 55 | mailto:resource-car-fiat500@example.com |
paul@1185 | 56 | EOF |
paul@1185 | 57 | |
paul@1185 | 58 | "$RESOURCE_SCRIPT" $ARGS < "$TEMPLATES/fb-request-car.txt" 2>> $ERROR \ |
paul@1185 | 59 | | "$SHOWMAIL" \ |
paul@1185 | 60 | > out0.tmp |
paul@1185 | 61 | |
paul@1185 | 62 | grep -q 'METHOD:REPLY' out0.tmp \ |
paul@1185 | 63 | && ! grep -q '^FREEBUSY' out0.tmp \ |
paul@1185 | 64 | && echo "Success" \ |
paul@1185 | 65 | || echo "Failed" |
paul@1185 | 66 | |
paul@1185 | 67 | # Attempt to schedule an event. |
paul@1185 | 68 | |
paul@1185 | 69 | "$OUTGOING_SCRIPT" $ARGS < "$TEMPLATES/event-request-car.txt" 2>> $ERROR |
paul@1185 | 70 | |
paul@1185 | 71 | "$LIST_SCRIPT" $LIST_ARGS "$SENDER1" "freebusy" \ |
paul@1185 | 72 | | tee out0s.tmp \ |
paul@1185 | 73 | | grep -q "^20141126T150000Z${TAB}20141126T160000Z" \ |
paul@1185 | 74 | && echo "Success" \ |
paul@1185 | 75 | || echo "Failed" |
paul@1185 | 76 | |
paul@1185 | 77 | # Present the request to the resource. |
paul@1185 | 78 | |
paul@1185 | 79 | "$RESOURCE_SCRIPT" $ARGS < "$TEMPLATES/event-request-car.txt" 2>> $ERROR \ |
paul@1185 | 80 | | tee out1r.tmp \ |
paul@1185 | 81 | | "$SHOWMAIL" \ |
paul@1185 | 82 | > out1.tmp |
paul@1185 | 83 | |
paul@1185 | 84 | grep -q 'METHOD:REPLY' out1.tmp \ |
paul@1185 | 85 | && grep -q 'ATTENDEE.*;PARTSTAT=ACCEPTED' out1.tmp \ |
paul@1185 | 86 | && echo "Success" \ |
paul@1185 | 87 | || echo "Failed" |
paul@1185 | 88 | |
paul@1185 | 89 | "$LIST_SCRIPT" $LIST_ARGS "$USER1" "freebusy" \ |
paul@1185 | 90 | | tee out1f.tmp \ |
paul@1185 | 91 | | grep -q "^20141126T150000Z${TAB}20141126T160000Z" \ |
paul@1185 | 92 | && echo "Success" \ |
paul@1185 | 93 | || echo "Failed" |
paul@1185 | 94 | |
paul@1185 | 95 | # Check the quota (event is confirmed). |
paul@1185 | 96 | |
paul@1185 | 97 | "$LIST_SCRIPT" $LIST_ARGS "$QUOTA" "entries" "all" \ |
paul@1185 | 98 | | tee out1e.tmp \ |
paul@1185 | 99 | | grep -q "event21@example.com" \ |
paul@1185 | 100 | && echo "Success" \ |
paul@1185 | 101 | || echo "Failed" |
paul@1185 | 102 | |
paul@1185 | 103 | # Attempt to schedule another event. |
paul@1185 | 104 | |
paul@1185 | 105 | sed 's/FREQ=DAILY/FREQ=DAILY;COUNT=5/;' "$TEMPLATES/event-request-cars-recurring.txt" \ |
paul@1185 | 106 | | "$OUTGOING_SCRIPT" $ARGS 2>> $ERROR |
paul@1185 | 107 | |
paul@1185 | 108 | "$LIST_SCRIPT" $LIST_ARGS "$SENDER1" "freebusy" \ |
paul@1185 | 109 | > out2s.tmp |
paul@1185 | 110 | |
paul@1185 | 111 | grep -q "^20141126T150000Z${TAB}20141126T160000Z" "out2s.tmp" \ |
paul@1185 | 112 | && grep -q "event21@example.com" "out2s.tmp" \ |
paul@1185 | 113 | && grep -q "event25@example.com" "out2s.tmp" \ |
paul@1185 | 114 | && echo "Success" \ |
paul@1185 | 115 | || echo "Failed" |
paul@1185 | 116 | |
paul@1185 | 117 | # Present the request to the recipients. |
paul@1185 | 118 | |
paul@1185 | 119 | sed 's/FREQ=DAILY/FREQ=DAILY;COUNT=5/;' "$TEMPLATES/event-request-cars-recurring.txt" \ |
paul@1185 | 120 | | "$RESOURCE_SCRIPT" $ARGS 2>> $ERROR \ |
paul@1185 | 121 | > out2r.tmp |
paul@1185 | 122 | |
paul@1185 | 123 | "$SHOWMAIL" < "out2r.tmp" \ |
paul@1185 | 124 | > out2p0.tmp |
paul@1185 | 125 | |
paul@1185 | 126 | "$SHOWMAIL" 1 < "out2r.tmp" \ |
paul@1185 | 127 | > out2p1.tmp |
paul@1185 | 128 | |
paul@1185 | 129 | grep -q 'METHOD:REPLY' out2p0.tmp \ |
paul@1185 | 130 | && grep -q 'ATTENDEE.*;PARTSTAT=ACCEPTED' out2p0.tmp \ |
paul@1185 | 131 | && echo "Success" \ |
paul@1185 | 132 | || echo "Failed" |
paul@1185 | 133 | |
paul@1185 | 134 | grep -q 'METHOD:REPLY' out2p1.tmp \ |
paul@1185 | 135 | && grep -q 'ATTENDEE.*;PARTSTAT=ACCEPTED' out2p1.tmp \ |
paul@1185 | 136 | && echo "Success" \ |
paul@1185 | 137 | || echo "Failed" |
paul@1185 | 138 | |
paul@1185 | 139 | "$LIST_SCRIPT" $LIST_ARGS "$USER1" "freebusy" \ |
paul@1185 | 140 | > out2f0.tmp |
paul@1185 | 141 | |
paul@1185 | 142 | grep -q "^20141126T150000Z${TAB}20141126T160000Z" "out2f0.tmp" \ |
paul@1185 | 143 | && grep -q "event21@example.com" "out2f0.tmp" \ |
paul@1185 | 144 | && grep -q "event25@example.com" "out2f0.tmp" \ |
paul@1185 | 145 | && echo "Success" \ |
paul@1185 | 146 | || echo "Failed" |
paul@1185 | 147 | |
paul@1185 | 148 | "$LIST_SCRIPT" $LIST_ARGS "$USER2" "freebusy" \ |
paul@1185 | 149 | > out2f1.tmp |
paul@1185 | 150 | |
paul@1185 | 151 | grep -q "^20141126T150000Z${TAB}20141126T160000Z" "out2f1.tmp" \ |
paul@1185 | 152 | && grep -q "event25@example.com" "out2f1.tmp" \ |
paul@1185 | 153 | && echo "Success" \ |
paul@1185 | 154 | || echo "Failed" |
paul@1185 | 155 | |
paul@1185 | 156 | # Check the quota (event is confirmed). |
paul@1185 | 157 | |
paul@1185 | 158 | "$LIST_SCRIPT" $LIST_ARGS "$QUOTA" "entries" "all" \ |
paul@1185 | 159 | | tee out2e.tmp \ |
paul@1185 | 160 | | grep -q "event25@example.com" \ |
paul@1185 | 161 | && echo "Success" \ |
paul@1185 | 162 | || echo "Failed" |
paul@1185 | 163 | |
paul@1185 | 164 | # Attempt to schedule another event. |
paul@1185 | 165 | |
paul@1185 | 166 | "$OUTGOING_SCRIPT" $ARGS < "$TEMPLATES/event-request-car-delegating.txt" 2>> $ERROR |
paul@1185 | 167 | |
paul@1185 | 168 | "$LIST_SCRIPT" $LIST_ARGS "$SENDER2" "freebusy" \ |
paul@1185 | 169 | | tee out3s.tmp \ |
paul@1185 | 170 | | grep -q "^20141126T153000Z${TAB}20141126T163000Z" \ |
paul@1185 | 171 | && echo "Success" \ |
paul@1185 | 172 | || echo "Failed" |
paul@1185 | 173 | |
paul@1185 | 174 | # Present the request to the resource. |
paul@1185 | 175 | |
paul@1185 | 176 | "$RESOURCE_SCRIPT" $ARGS < "$TEMPLATES/event-request-car-delegating.txt" 2>> $ERROR \ |
paul@1185 | 177 | > out3r.tmp |
paul@1185 | 178 | |
paul@1185 | 179 | "$SHOWMAIL" < out3r.tmp \ |
paul@1185 | 180 | > out3p0.tmp |
paul@1185 | 181 | |
paul@1185 | 182 | "$SHOWMAIL" 1 < out3r.tmp \ |
paul@1185 | 183 | > out3p1.tmp |
paul@1185 | 184 | |
paul@1185 | 185 | if grep -q "To: $SENDER2ADDRESS" out3p0.tmp ; then |
paul@1185 | 186 | ORGFN=out3p0.tmp ; DELFN=out3p1.tmp |
paul@1185 | 187 | else |
paul@1185 | 188 | ORGFN=out3p1.tmp ; DELFN=out3p0.tmp |
paul@1185 | 189 | fi |
paul@1185 | 190 | |
paul@1185 | 191 | # One of the responses will be a request sent to the delegate. |
paul@1185 | 192 | |
paul@1185 | 193 | grep -q "To: $USER2ADDRESS" "$DELFN" \ |
paul@1185 | 194 | && grep -q 'METHOD:REQUEST' "$DELFN" \ |
paul@1185 | 195 | && grep -q 'ATTENDEE.*;PARTSTAT=DELEGATED.*:'"$USER1" "$DELFN" \ |
paul@1185 | 196 | && grep -q 'ATTENDEE.*:'"$USER2" "$DELFN" \ |
paul@1185 | 197 | && echo "Success" \ |
paul@1185 | 198 | || echo "Failed" |
paul@1185 | 199 | |
paul@1185 | 200 | # The other will be a reply to the organiser. |
paul@1185 | 201 | |
paul@1185 | 202 | grep -q "To: $SENDER2ADDRESS" "$ORGFN" \ |
paul@1185 | 203 | && grep -q 'METHOD:REPLY' "$ORGFN" \ |
paul@1185 | 204 | && grep -q 'ATTENDEE.*;PARTSTAT=DELEGATED.*:'"$USER1" "$ORGFN" \ |
paul@1185 | 205 | && grep -q 'ATTENDEE.*:'"$USER2" "$ORGFN" \ |
paul@1185 | 206 | && echo "Success" \ |
paul@1185 | 207 | || echo "Failed" |
paul@1185 | 208 | |
paul@1185 | 209 | # Neither the delegator or the delegate will have changed their schedules. |
paul@1185 | 210 | |
paul@1185 | 211 | "$LIST_SCRIPT" $LIST_ARGS "$USER1" "freebusy" \ |
paul@1185 | 212 | > out4f1.tmp |
paul@1185 | 213 | |
paul@1185 | 214 | ! grep -q "^20141126T153000Z${TAB}20141126T163000Z" "out4f1.tmp" \ |
paul@1185 | 215 | && echo "Success" \ |
paul@1185 | 216 | || echo "Failed" |
paul@1185 | 217 | |
paul@1185 | 218 | "$LIST_SCRIPT" $LIST_ARGS "$USER2" "freebusy" \ |
paul@1185 | 219 | > out4f2.tmp |
paul@1185 | 220 | |
paul@1185 | 221 | ! grep -q "^20141126T153000Z${TAB}20141126T163000Z" "out4f2.tmp" \ |
paul@1185 | 222 | && echo "Success" \ |
paul@1185 | 223 | || echo "Failed" |
paul@1185 | 224 | |
paul@1185 | 225 | # Check the quota (event is not confirmed). |
paul@1185 | 226 | |
paul@1185 | 227 | "$LIST_SCRIPT" $LIST_ARGS "$QUOTA" "entries" "all" \ |
paul@1185 | 228 | > out4e.tmp |
paul@1185 | 229 | |
paul@1185 | 230 | grep -q "event21@example.com" "out4e.tmp" \ |
paul@1185 | 231 | && grep -q "event25@example.com" "out4e.tmp" \ |
paul@1185 | 232 | && ! grep -q "event27@example.com" "out4e.tmp" \ |
paul@1185 | 233 | && echo "Success" \ |
paul@1185 | 234 | || echo "Failed" |
paul@1185 | 235 | |
paul@1185 | 236 | # Present the reply to the organiser. |
paul@1185 | 237 | |
paul@1185 | 238 | "$PERSON_SCRIPT" $ARGS < "$ORGFN" 2>> "$ERROR" \ |
paul@1185 | 239 | | tee out5r.tmp \ |
paul@1185 | 240 | | "$SHOWMAIL" \ |
paul@1185 | 241 | > out5.tmp |
paul@1185 | 242 | |
paul@1185 | 243 | # Check the free/busy status of the attendees at the organiser. |
paul@1185 | 244 | # Currently, neither are attending. |
paul@1185 | 245 | |
paul@1185 | 246 | "$LIST_SCRIPT" $LIST_ARGS "$SENDER2" "freebusy_other" "$USER1" \ |
paul@1185 | 247 | > out5s0.tmp \ |
paul@1185 | 248 | |
paul@1185 | 249 | ! grep -q "^20141126T153000Z${TAB}20141126T163000Z" out5s0.tmp \ |
paul@1185 | 250 | && echo "Success" \ |
paul@1185 | 251 | || echo "Failed" |
paul@1185 | 252 | |
paul@1185 | 253 | "$LIST_SCRIPT" $LIST_ARGS "$SENDER2" "freebusy_other" "$USER2" \ |
paul@1185 | 254 | > out5s1.tmp \ |
paul@1185 | 255 | |
paul@1185 | 256 | ! grep -q "^20141126T153000Z${TAB}20141126T163000Z" out5s1.tmp \ |
paul@1185 | 257 | && echo "Success" \ |
paul@1185 | 258 | || echo "Failed" |
paul@1185 | 259 | |
paul@1185 | 260 | # Present the request to the delegate. |
paul@1185 | 261 | |
paul@1185 | 262 | "$RESOURCE_SCRIPT" $ARGS < "$DELFN" 2>> "$ERROR" \ |
paul@1185 | 263 | > out6r.tmp |
paul@1185 | 264 | |
paul@1185 | 265 | "$SHOWMAIL" < out6r.tmp \ |
paul@1185 | 266 | > out6p0.tmp |
paul@1185 | 267 | |
paul@1185 | 268 | "$SHOWMAIL" 1 < out6r.tmp \ |
paul@1185 | 269 | > out6p1.tmp |
paul@1185 | 270 | |
paul@1185 | 271 | if grep -q "To: $SENDER2ADDRESS" out6p0.tmp ; then |
paul@1185 | 272 | ORGFN=out6p0.tmp ; DELFN=out6p1.tmp |
paul@1185 | 273 | else |
paul@1185 | 274 | ORGFN=out6p1.tmp ; DELFN=out6p0.tmp |
paul@1185 | 275 | fi |
paul@1185 | 276 | |
paul@1185 | 277 | # One of the responses will be a reply sent to the organiser. |
paul@1185 | 278 | |
paul@1185 | 279 | grep -q "To: $SENDER2ADDRESS" "$ORGFN" \ |
paul@1185 | 280 | && grep -q 'METHOD:REPLY' "$ORGFN" \ |
paul@1185 | 281 | && grep -q 'ATTENDEE.*;PARTSTAT=DELEGATED.*:'"$USER1" "$ORGFN" \ |
paul@1185 | 282 | && grep -q 'ATTENDEE.*;PARTSTAT=ACCEPTED.*:'"$USER2" "$ORGFN" \ |
paul@1185 | 283 | && echo "Success" \ |
paul@1185 | 284 | || echo "Failed" |
paul@1185 | 285 | |
paul@1185 | 286 | # The other will be a reply to the delegator. |
paul@1185 | 287 | |
paul@1185 | 288 | grep -q "To: $USER1ADDRESS" "$DELFN" \ |
paul@1185 | 289 | && grep -q 'METHOD:REPLY' "$DELFN" \ |
paul@1185 | 290 | && grep -q 'ATTENDEE.*;PARTSTAT=DELEGATED.*:'"$USER1" "$DELFN" \ |
paul@1185 | 291 | && grep -q 'ATTENDEE.*;PARTSTAT=ACCEPTED.*:'"$USER2" "$DELFN" \ |
paul@1185 | 292 | && echo "Success" \ |
paul@1185 | 293 | || echo "Failed" |
paul@1185 | 294 | |
paul@1185 | 295 | # The delegate should now have a changed schedule. |
paul@1185 | 296 | |
paul@1185 | 297 | "$LIST_SCRIPT" $LIST_ARGS "$USER1" "freebusy" \ |
paul@1185 | 298 | > out7f0.tmp |
paul@1185 | 299 | |
paul@1185 | 300 | ! grep -q "^20141126T153000Z${TAB}20141126T163000Z" "out7f0.tmp" \ |
paul@1185 | 301 | && echo "Success" \ |
paul@1185 | 302 | || echo "Failed" |
paul@1185 | 303 | |
paul@1185 | 304 | "$LIST_SCRIPT" $LIST_ARGS "$USER2" "freebusy" \ |
paul@1185 | 305 | > out7f1.tmp |
paul@1185 | 306 | |
paul@1185 | 307 | grep -q "^20141126T153000Z${TAB}20141126T163000Z" "out7f1.tmp" \ |
paul@1185 | 308 | && grep -q "event27@example.com" "out7f1.tmp" \ |
paul@1185 | 309 | && echo "Success" \ |
paul@1185 | 310 | || echo "Failed" |
paul@1185 | 311 | |
paul@1185 | 312 | # Present the reply to the organiser. |
paul@1185 | 313 | |
paul@1185 | 314 | "$PERSON_SCRIPT" $ARGS < "$ORGFN" 2>> "$ERROR" \ |
paul@1185 | 315 | | tee out8r.tmp \ |
paul@1185 | 316 | | "$SHOWMAIL" \ |
paul@1185 | 317 | > out8.tmp |
paul@1185 | 318 | |
paul@1185 | 319 | # Check the free/busy status of the attendees at the organiser. |
paul@1185 | 320 | # Now, the delegate is attending. |
paul@1185 | 321 | |
paul@1185 | 322 | "$LIST_SCRIPT" $LIST_ARGS "$SENDER2" "freebusy_other" "$USER1" \ |
paul@1185 | 323 | > out8s0.tmp \ |
paul@1185 | 324 | |
paul@1185 | 325 | ! grep -q "^20141126T153000Z${TAB}20141126T163000Z" out8s0.tmp \ |
paul@1185 | 326 | && ! grep -q "event27@example.com" out8s0.tmp \ |
paul@1185 | 327 | && echo "Success" \ |
paul@1185 | 328 | || echo "Failed" |
paul@1185 | 329 | |
paul@1185 | 330 | "$LIST_SCRIPT" $LIST_ARGS "$SENDER2" "freebusy_other" "$USER2" \ |
paul@1185 | 331 | > out8s1.tmp \ |
paul@1185 | 332 | |
paul@1185 | 333 | grep -q "^20141126T153000Z${TAB}20141126T163000Z" out8s1.tmp \ |
paul@1185 | 334 | && grep -q "event27@example.com" out8s1.tmp \ |
paul@1185 | 335 | && echo "Success" \ |
paul@1185 | 336 | || echo "Failed" |
paul@1185 | 337 | |
paul@1185 | 338 | # Present the reply to the delegator. |
paul@1185 | 339 | |
paul@1185 | 340 | "$RESOURCE_SCRIPT" $ARGS < "$DELFN" 2>> "$ERROR" \ |
paul@1185 | 341 | > out9r.tmp |