Skip to content

Commit

Permalink
update
Browse files Browse the repository at this point in the history
  • Loading branch information
junkmd committed May 29, 2024
1 parent 4eee732 commit 4a2f5a7
Showing 1 changed file with 71 additions and 4 deletions.
75 changes: 71 additions & 4 deletions comtypes/test/test_dispifc_records.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@


@unittest.skipIf(IMPORT_FAILED, "This depends on the out of process COM-server.")
class Test(unittest.TestCase):
class Test_Disp(unittest.TestCase):
"""Test dispmethods with record and record pointer parameters."""

EXPECTED_INITED_QUESTIONS = "The meaning of life, the universe and everything?"
Expand All @@ -31,7 +31,7 @@ def _create_dispifc(self) -> "ComtypesCppTestSrvLib.IDispRecordParamTest":
interface=ComtypesCppTestSrvLib.IDispRecordParamTest,
)

def test_byref(self):
def test_inout_byref(self):
dispifc = self._create_dispifc()
# Passing a record by reference to a method that has declared the parameter
# as [in, out] we expect modifications of the record on the server side to
Expand All @@ -45,7 +45,7 @@ def test_byref(self):
self.assertEqual(test_record.answer, 42)
self.assertEqual(test_record.needs_clarification, True)

def test_pointer(self):
def test_inout_pointer(self):
dispifc = self._create_dispifc()
# Passing a record pointer to a method that has declared the parameter
# as [in, out] we expect modifications of the record on the server side to
Expand All @@ -59,7 +59,18 @@ def test_pointer(self):
self.assertEqual(test_record.answer, 42)
self.assertEqual(test_record.needs_clarification, True)

def test_record(self):
def test_inout_record(self):
dispifc = self._create_dispifc()
test_record = ComtypesCppTestSrvLib.StructRecordParamTest()
self.assertEqual(test_record.question, None)
self.assertEqual(test_record.answer, 0)
self.assertEqual(test_record.needs_clarification, False)
dispifc.InitRecord(test_record)
self.assertEqual(test_record.question, None)
self.assertEqual(test_record.answer, 0)
self.assertEqual(test_record.needs_clarification, False)

def test_in_record(self):
# Passing a record to a method that has declared the parameter just as [in]
# we expect modifications of the record on the server side NOT to change
# the record on the client side.
Expand All @@ -86,5 +97,61 @@ def test_record(self):
self.assertEqual(rec.needs_clarification, nc)


@unittest.skipIf(IMPORT_FAILED, "This depends on the out of process COM-server.")
class Test_Dual(unittest.TestCase):
EXPECTED_INITED_QUESTIONS = "The meaning of life, the universe and everything?"

def _create_dualifc(self) -> "ComtypesCppTestSrvLib.IDualRecordParamTest":
# Explicitely ask for the dispinterface of the component.
return CreateObject(
"Comtypes.DispIfcParamTests",
clsctx=CLSCTX_LOCAL_SERVER,
interface=ComtypesCppTestSrvLib.IDualRecordParamTest,
)

def test_inout_pointer(self):
dualifc = self._create_dualifc()
test_record = ComtypesCppTestSrvLib.StructRecordParamTest()
self.assertEqual(test_record.question, None)
self.assertEqual(test_record.answer, 0)
self.assertEqual(test_record.needs_clarification, False)
dualifc.InitRecord(pointer(test_record))
self.assertEqual(test_record.question, self.EXPECTED_INITED_QUESTIONS)
self.assertEqual(test_record.answer, 42)
self.assertEqual(test_record.needs_clarification, True)

def test_inout_record(self):
dualifc = self._create_dualifc()
test_record = ComtypesCppTestSrvLib.StructRecordParamTest()
self.assertEqual(test_record.question, None)
self.assertEqual(test_record.answer, 0)
self.assertEqual(test_record.needs_clarification, False)
# Passing a record by reference to a method, such as
# `dualifc.InitRecord(byref(test_record))`, clashes Python.
dualifc.InitRecord(test_record)
self.assertEqual(test_record.question, self.EXPECTED_INITED_QUESTIONS)
self.assertEqual(test_record.answer, 42)
self.assertEqual(test_record.needs_clarification, True)

def test_in_record(self):
inited_record = ComtypesCppTestSrvLib.StructRecordParamTest()
inited_record.question = self.EXPECTED_INITED_QUESTIONS
inited_record.answer = 42
inited_record.needs_clarification = True
for rec, expected, (q, a, nc) in [
(inited_record, True, (self.EXPECTED_INITED_QUESTIONS, 42, True)),
# Also perform the inverted test. For this, create a blank record.
(ComtypesCppTestSrvLib.StructRecordParamTest(), False, (None, 0, False)),
]:
with self.subTest(expected=expected, q=q, a=a, nc=nc):
# Perform the check on initialization values.
self.assertEqual(self._create_dualifc().VerifyRecord(rec), expected)
self.assertEqual(rec.question, q)
# Check if the 'answer' field is unchanged although the method
# modifies this field on the server side.
self.assertEqual(rec.answer, a)
self.assertEqual(rec.needs_clarification, nc)


if __name__ == "__main__":
unittest.main()

0 comments on commit 4a2f5a7

Please sign in to comment.