Nanang Izzuddin | f810f95 | 2008-06-18 21:04:14 +0000 | [diff] [blame] | 1 | # $Id$ |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 2 | import time |
| 3 | import imp |
| 4 | import sys |
| 5 | import inc_const as const |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 6 | from inc_cfg import * |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 7 | |
| 8 | # Load configuration |
Nanang Izzuddin | a680bd6 | 2008-06-27 21:12:12 +0000 | [diff] [blame] | 9 | cfg_file = imp.load_source("cfg_file", ARGS[1]) |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 10 | |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 11 | # Check media flow between ua1 and ua2 |
| 12 | def check_media(ua1, ua2): |
| 13 | ua1.send("#") |
Benny Prijono | e4ddeec | 2008-06-27 08:51:55 +0000 | [diff] [blame] | 14 | ua1.expect("#") |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 15 | ua1.send("1122") |
| 16 | ua2.expect(const.RX_DTMF + "1") |
| 17 | ua2.expect(const.RX_DTMF + "1") |
| 18 | ua2.expect(const.RX_DTMF + "2") |
| 19 | ua2.expect(const.RX_DTMF + "2") |
| 20 | |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 21 | |
| 22 | # Test body function |
Nanang Izzuddin | a680bd6 | 2008-06-27 21:12:12 +0000 | [diff] [blame] | 23 | def test_func(t): |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 24 | callee = t.process[0] |
| 25 | caller = t.process[1] |
| 26 | |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 27 | # if have_reg then wait for couple of seconds for PUBLISH |
| 28 | # to complete (just in case pUBLISH is used) |
| 29 | if callee.inst_param.have_reg: |
| 30 | time.sleep(1) |
| 31 | if caller.inst_param.have_reg: |
| 32 | time.sleep(1) |
| 33 | |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 34 | # Caller making call |
| 35 | caller.send("m") |
| 36 | caller.send(t.inst_params[0].uri) |
| 37 | caller.expect(const.STATE_CALLING) |
| 38 | |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 39 | # Callee waits for call and answers with 180/Ringing |
Benny Prijono | 4d0da3a | 2008-06-26 20:23:47 +0000 | [diff] [blame] | 40 | time.sleep(0.2) |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 41 | callee.expect(const.EVENT_INCOMING_CALL) |
| 42 | callee.send("a") |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 43 | callee.send("180") |
| 44 | callee.expect("SIP/2.0 180") |
| 45 | caller.expect("SIP/2.0 180") |
| 46 | |
| 47 | # Synchronize stdout |
| 48 | caller.sync_stdout() |
| 49 | callee.sync_stdout() |
| 50 | |
| 51 | # Callee answers with 200/OK |
| 52 | callee.send("a") |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 53 | callee.send("200") |
| 54 | |
| 55 | # Wait until call is connected in both endpoints |
Benny Prijono | 4d0da3a | 2008-06-26 20:23:47 +0000 | [diff] [blame] | 56 | time.sleep(0.2) |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 57 | caller.expect(const.STATE_CONFIRMED) |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 58 | callee.expect(const.STATE_CONFIRMED) |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 59 | |
| 60 | # Synchronize stdout |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 61 | caller.sync_stdout() |
| 62 | callee.sync_stdout() |
Benny Prijono | 4d0da3a | 2008-06-26 20:23:47 +0000 | [diff] [blame] | 63 | time.sleep(0.1) |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 64 | caller.sync_stdout() |
| 65 | callee.sync_stdout() |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 66 | |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 67 | # Test that media is okay |
Benny Prijono | 4d0da3a | 2008-06-26 20:23:47 +0000 | [diff] [blame] | 68 | time.sleep(0.3) |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 69 | check_media(caller, callee) |
| 70 | check_media(callee, caller) |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 71 | |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 72 | # Hold call by caller |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 73 | caller.send("H") |
Benny Prijono | e4ddeec | 2008-06-27 08:51:55 +0000 | [diff] [blame] | 74 | caller.expect("INVITE sip:") |
| 75 | callee.expect("INVITE sip:") |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 76 | caller.expect(const.MEDIA_HOLD) |
| 77 | callee.expect(const.MEDIA_HOLD) |
| 78 | |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 79 | # Synchronize stdout |
| 80 | caller.sync_stdout() |
| 81 | callee.sync_stdout() |
| 82 | |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 83 | # Release hold |
Benny Prijono | 4d0da3a | 2008-06-26 20:23:47 +0000 | [diff] [blame] | 84 | time.sleep(0.5) |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 85 | caller.send("v") |
Benny Prijono | e4ddeec | 2008-06-27 08:51:55 +0000 | [diff] [blame] | 86 | caller.expect("INVITE sip:") |
| 87 | callee.expect("INVITE sip:") |
Benny Prijono | 5242a42 | 2008-06-26 16:27:17 +0000 | [diff] [blame] | 88 | caller.expect(const.MEDIA_ACTIVE, title="waiting for media active after call hold") |
Benny Prijono | e4ddeec | 2008-06-27 08:51:55 +0000 | [diff] [blame] | 89 | callee.expect(const.MEDIA_ACTIVE, title="waiting for media active after call hold") |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 90 | |
| 91 | # Synchronize stdout |
| 92 | caller.sync_stdout() |
| 93 | callee.sync_stdout() |
| 94 | |
| 95 | # Test that media is okay |
| 96 | check_media(caller, callee) |
| 97 | check_media(callee, caller) |
| 98 | |
| 99 | # Synchronize stdout |
| 100 | caller.sync_stdout() |
| 101 | callee.sync_stdout() |
| 102 | |
| 103 | # Hold call by callee |
| 104 | callee.send("H") |
Benny Prijono | e4ddeec | 2008-06-27 08:51:55 +0000 | [diff] [blame] | 105 | callee.expect("INVITE sip:") |
| 106 | caller.expect("INVITE sip:") |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 107 | caller.expect(const.MEDIA_HOLD) |
| 108 | callee.expect(const.MEDIA_HOLD) |
| 109 | |
| 110 | # Synchronize stdout |
| 111 | caller.sync_stdout() |
| 112 | callee.sync_stdout() |
| 113 | |
| 114 | # Release hold |
Benny Prijono | e4ddeec | 2008-06-27 08:51:55 +0000 | [diff] [blame] | 115 | time.sleep(0.1) |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 116 | callee.send("v") |
Benny Prijono | e4ddeec | 2008-06-27 08:51:55 +0000 | [diff] [blame] | 117 | callee.expect("INVITE sip:") |
| 118 | caller.expect("INVITE sip:") |
Benny Prijono | 5242a42 | 2008-06-26 16:27:17 +0000 | [diff] [blame] | 119 | callee.expect(const.MEDIA_ACTIVE, title="waiting for media active after call hold") |
Benny Prijono | e4ddeec | 2008-06-27 08:51:55 +0000 | [diff] [blame] | 120 | caller.expect(const.MEDIA_ACTIVE, title="waiting for media active after call hold") |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 121 | |
| 122 | # Synchronize stdout |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 123 | caller.sync_stdout() |
| 124 | callee.sync_stdout() |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 125 | |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 126 | # Test that media is okay |
Benny Prijono | e4ddeec | 2008-06-27 08:51:55 +0000 | [diff] [blame] | 127 | # Wait for some time for ICE negotiation |
| 128 | time.sleep(0.6) |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 129 | check_media(caller, callee) |
| 130 | check_media(callee, caller) |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 131 | |
| 132 | # Synchronize stdout |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 133 | caller.sync_stdout() |
| 134 | callee.sync_stdout() |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 135 | |
| 136 | # UPDATE (by caller) |
| 137 | caller.send("U") |
Benny Prijono | 5242a42 | 2008-06-26 16:27:17 +0000 | [diff] [blame] | 138 | #caller.sync_stdout() |
| 139 | callee.expect(const.MEDIA_ACTIVE, title="waiting for media active with UPDATE") |
| 140 | caller.expect(const.MEDIA_ACTIVE, title="waiting for media active with UPDATE") |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 141 | |
| 142 | # Synchronize stdout |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 143 | caller.sync_stdout() |
| 144 | callee.sync_stdout() |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 145 | |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 146 | # Test that media is okay |
Benny Prijono | 4d0da3a | 2008-06-26 20:23:47 +0000 | [diff] [blame] | 147 | time.sleep(0.1) |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 148 | check_media(caller, callee) |
| 149 | check_media(callee, caller) |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 150 | |
| 151 | # UPDATE (by callee) |
| 152 | callee.send("U") |
Benny Prijono | e4ddeec | 2008-06-27 08:51:55 +0000 | [diff] [blame] | 153 | callee.expect("UPDATE sip:") |
| 154 | caller.expect("UPDATE sip:") |
Benny Prijono | 5242a42 | 2008-06-26 16:27:17 +0000 | [diff] [blame] | 155 | caller.expect(const.MEDIA_ACTIVE, title="waiting for media active with UPDATE") |
| 156 | callee.expect(const.MEDIA_ACTIVE, title="waiting for media active with UPDATE") |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 157 | |
| 158 | # Synchronize stdout |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 159 | caller.sync_stdout() |
| 160 | callee.sync_stdout() |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 161 | |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 162 | # Test that media is okay |
Benny Prijono | 4d0da3a | 2008-06-26 20:23:47 +0000 | [diff] [blame] | 163 | time.sleep(0.1) |
Benny Prijono | 62a969c | 2008-06-26 13:29:29 +0000 | [diff] [blame] | 164 | check_media(caller, callee) |
| 165 | check_media(callee, caller) |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 166 | |
Benny Prijono | 5242a42 | 2008-06-26 16:27:17 +0000 | [diff] [blame] | 167 | # Synchronize stdout |
| 168 | caller.sync_stdout() |
| 169 | callee.sync_stdout() |
| 170 | |
| 171 | # Set codecs in both caller and callee so that there is |
| 172 | # no common codec between them. |
| 173 | # In caller we only enable PCMU, in callee we only enable PCMA |
| 174 | caller.send("Cp") |
Benny Prijono | e4ddeec | 2008-06-27 08:51:55 +0000 | [diff] [blame] | 175 | caller.expect("Enter codec") |
Benny Prijono | 5242a42 | 2008-06-26 16:27:17 +0000 | [diff] [blame] | 176 | caller.send("* 0") |
| 177 | caller.send("Cp") |
Benny Prijono | e4ddeec | 2008-06-27 08:51:55 +0000 | [diff] [blame] | 178 | caller.expect("Enter codec") |
Benny Prijono | 5242a42 | 2008-06-26 16:27:17 +0000 | [diff] [blame] | 179 | caller.send("pcmu 120") |
| 180 | |
| 181 | callee.send("Cp") |
Benny Prijono | e4ddeec | 2008-06-27 08:51:55 +0000 | [diff] [blame] | 182 | callee.expect("Enter codec") |
Benny Prijono | 5242a42 | 2008-06-26 16:27:17 +0000 | [diff] [blame] | 183 | callee.send("* 0") |
| 184 | callee.send("Cp") |
Benny Prijono | e4ddeec | 2008-06-27 08:51:55 +0000 | [diff] [blame] | 185 | callee.expect("Enter codec") |
Benny Prijono | 5242a42 | 2008-06-26 16:27:17 +0000 | [diff] [blame] | 186 | callee.send("pcma 120") |
| 187 | |
| 188 | # Test when UPDATE fails (by callee) |
| 189 | callee.send("U") |
| 190 | caller.expect("SIP/2.0 488") |
| 191 | callee.expect("SIP/2.0 488") |
| 192 | callee.sync_stdout() |
| 193 | caller.sync_stdout() |
| 194 | |
| 195 | # Test that media is still okay |
Benny Prijono | 4d0da3a | 2008-06-26 20:23:47 +0000 | [diff] [blame] | 196 | time.sleep(0.1) |
Benny Prijono | 5242a42 | 2008-06-26 16:27:17 +0000 | [diff] [blame] | 197 | check_media(caller, callee) |
| 198 | check_media(callee, caller) |
| 199 | |
| 200 | # Test when UPDATE fails (by caller) |
| 201 | caller.send("U") |
Benny Prijono | e4ddeec | 2008-06-27 08:51:55 +0000 | [diff] [blame] | 202 | caller.expect("UPDATE sip:") |
| 203 | callee.expect("UPDATE sip:") |
Benny Prijono | 5242a42 | 2008-06-26 16:27:17 +0000 | [diff] [blame] | 204 | callee.expect("SIP/2.0 488") |
| 205 | caller.expect("SIP/2.0 488") |
| 206 | caller.sync_stdout() |
| 207 | callee.sync_stdout() |
| 208 | |
| 209 | # Test that media is still okay |
Benny Prijono | 4d0da3a | 2008-06-26 20:23:47 +0000 | [diff] [blame] | 210 | time.sleep(0.1) |
Benny Prijono | 5242a42 | 2008-06-26 16:27:17 +0000 | [diff] [blame] | 211 | check_media(callee, caller) |
| 212 | check_media(caller, callee) |
| 213 | |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 214 | # Hangup call |
Benny Prijono | 4d0da3a | 2008-06-26 20:23:47 +0000 | [diff] [blame] | 215 | time.sleep(0.1) |
Benny Prijono | cc1ada5 | 2008-06-15 19:43:43 +0000 | [diff] [blame] | 216 | caller.send("h") |
| 217 | |
| 218 | # Wait until calls are cleared in both endpoints |
| 219 | caller.expect(const.STATE_DISCONNECTED) |
| 220 | callee.expect(const.STATE_DISCONNECTED) |
| 221 | |
| 222 | |
| 223 | # Here where it all comes together |
| 224 | test = cfg_file.test_param |
| 225 | test.test_func = test_func |
| 226 | |