1
# $Id: 230_reg_bad_fail_stale_true.py 2392 2008-12-22 18:54:58Z bennylp $
5
# In this test we simulate broken server, where it always sends
6
# stale=true with all 401 responses. We should expect pjsip to
7
# retry the authentication until PJSIP_MAX_STALE_COUNT is
8
# exceeded. When pjsip retries the authentication, it should
9
# use the new nonce from server
12
pjsua = "--null-audio --id=sip:CLIENT --registrar sip:127.0.0.1:$PORT " + \
13
"--realm=python --user=username --password=password"
15
req1 = sip.RecvfromTransaction("Initial request", 401,
16
include=["REGISTER sip"],
17
exclude=["Authorization"],
18
resp_hdr=["WWW-Authenticate: Digest realm=\"python\", nonce=\"1\""]
21
req2 = sip.RecvfromTransaction("First retry", 401,
22
include=["REGISTER sip", "Authorization", "nonce=\"1\""],
23
exclude=["Authorization:[\\s\\S]+Authorization:"],
24
resp_hdr=["WWW-Authenticate: Digest realm=\"python\", nonce=\"2\", stale=true"]
27
req3 = sip.RecvfromTransaction("Second retry retry", 401,
28
include=["REGISTER sip", "Authorization", "nonce=\"2\""],
29
exclude=["Authorization:[\\s\\S]+Authorization:"],
30
resp_hdr=["WWW-Authenticate: Digest realm=\"python\", nonce=\"3\", stale=true"]
33
req4 = sip.RecvfromTransaction("Third retry", 401,
34
include=["REGISTER sip", "Authorization", "nonce=\"3\""],
35
exclude=["Authorization:[\\s\\S]+Authorization:"],
36
resp_hdr=["WWW-Authenticate: Digest realm=\"python\", nonce=\"4\", stale=true"],
37
expect="PJSIP_EAUTHSTALECOUNT"
40
recvfrom_cfg = sip.RecvfromCfg("Failed registration retry (server rejects with stale=true) ",
41
pjsua, [req1, req2, req3, req4])