From 2c5d206b33e4cdcafaaaf1eeaa189c10de332dc5 Mon Sep 17 00:00:00 2001 From: "Erlend E. Aasland" Date: Mon, 31 Jul 2023 13:50:03 +0200 Subject: gh-106368: Add test for Argument Clinic misbehaving custom converter_init() (#107496) --- Lib/test/test_clinic.py | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/Lib/test/test_clinic.py b/Lib/test/test_clinic.py index 3ce27d1..2f94f01 100644 --- a/Lib/test/test_clinic.py +++ b/Lib/test/test_clinic.py @@ -318,6 +318,26 @@ class ClinicWholeFileTest(_ParserBase): msg = "unknown destination command 'nosuchcommand'" self.assertIn(msg, out) + def test_no_access_to_members_in_converter_init(self): + out = self.expect_failure(""" + /*[python input] + class Custom_converter(CConverter): + converter = "some_c_function" + def converter_init(self): + self.function.noaccess + [python start generated code]*/ + /*[clinic input] + module test + test.fn + a: Custom + [clinic start generated code]*/ + """) + msg = ( + "Stepped on a land mine, trying to access attribute 'noaccess':\n" + "Don't access members of self.function inside converter_init!" + ) + self.assertIn(msg, out) + class ClinicGroupPermuterTest(TestCase): def _test(self, l, m, r, output): -- cgit v0.12