mirror of
https://github.com/samba-team/samba.git
synced 2024-12-23 17:34:34 +03:00
py:dcerpc/raw_testcase: add start_with_alter to do_generic_bind()
This will allow do_generic_bind() to be used to test security context multiplexing. Check with git show -w BUG: https://bugzilla.samba.org/show_bug.cgi?id=7113 BUG: https://bugzilla.samba.org/show_bug.cgi?id=11892 Signed-off-by: Stefan Metzmacher <metze@samba.org> Reviewed-by: Jeremy Allison <jra@samba.org>
This commit is contained in:
parent
6574d2daef
commit
7a83cb02a1
@ -156,7 +156,8 @@ class RawDCERPCTest(TestCase):
|
||||
pfc_flags=samba.dcerpc.dcerpc.DCERPC_PFC_FLAG_FIRST |
|
||||
samba.dcerpc.dcerpc.DCERPC_PFC_FLAG_LAST,
|
||||
assoc_group_id=0, call_id=0,
|
||||
nak_reason=None, alter_fault=None):
|
||||
nak_reason=None, alter_fault=None,
|
||||
start_with_alter=False):
|
||||
ctx_list = [ctx]
|
||||
|
||||
if auth_context is not None:
|
||||
@ -176,6 +177,36 @@ class RawDCERPCTest(TestCase):
|
||||
else:
|
||||
auth_info = b""
|
||||
|
||||
if start_with_alter:
|
||||
req = self.generate_alter(call_id=call_id,
|
||||
pfc_flags=pfc_flags,
|
||||
ctx_list=ctx_list,
|
||||
assoc_group_id=0xffffffff - assoc_group_id,
|
||||
auth_info=auth_info)
|
||||
self.send_pdu(req)
|
||||
rep = self.recv_pdu()
|
||||
if alter_fault is not None:
|
||||
self.verify_pdu(rep, samba.dcerpc.dcerpc.DCERPC_PKT_FAULT, req.call_id,
|
||||
pfc_flags=req.pfc_flags |
|
||||
samba.dcerpc.dcerpc.DCERPC_PFC_FLAG_DID_NOT_EXECUTE,
|
||||
auth_length=0)
|
||||
self.assertNotEquals(rep.u.alloc_hint, 0)
|
||||
self.assertEquals(rep.u.context_id, 0)
|
||||
self.assertEquals(rep.u.cancel_count, 0)
|
||||
self.assertEquals(rep.u.flags, 0)
|
||||
self.assertEquals(rep.u.status, alter_fault)
|
||||
self.assertEquals(rep.u.reserved, 0)
|
||||
self.assertEquals(len(rep.u.error_and_verifier), 0)
|
||||
return None
|
||||
self.verify_pdu(rep, samba.dcerpc.dcerpc.DCERPC_PKT_ALTER_RESP, req.call_id,
|
||||
pfc_flags=req.pfc_flags)
|
||||
self.assertEquals(rep.u.max_xmit_frag, req.u.max_xmit_frag)
|
||||
self.assertEquals(rep.u.max_recv_frag, req.u.max_recv_frag)
|
||||
self.assertEquals(rep.u.assoc_group_id, assoc_group_id)
|
||||
self.assertEquals(rep.u.secondary_address_size, 0)
|
||||
self.assertEquals(rep.u.secondary_address, '')
|
||||
self.assertPadding(rep.u._pad1, 2)
|
||||
else:
|
||||
req = self.generate_bind(call_id=call_id,
|
||||
pfc_flags=pfc_flags,
|
||||
ctx_list=ctx_list,
|
||||
|
Loading…
Reference in New Issue
Block a user