Commit 18024c4f authored by Mark Florisson's avatar Mark Florisson

cy exec test + correct building of locals dict in Cython frames for non-wide...

cy exec test + correct building of locals dict in Cython frames for non-wide python 3 unicode builds
parent 74af34d9
...@@ -12,6 +12,8 @@ import trace ...@@ -12,6 +12,8 @@ import trace
import inspect import inspect
import warnings import warnings
import unittest import unittest
import textwrap
import tempfile
import traceback import traceback
from test import test_support from test import test_support
...@@ -292,6 +294,51 @@ class TestUpDown(DebugTestCase): ...@@ -292,6 +294,51 @@ class TestUpDown(DebugTestCase):
assert 'os.path.join("foo", "bar")' in result assert 'os.path.join("foo", "bar")' in result
class TestExec(DebugTestCase):
def setUp(self):
super(TestExec, self).setUp()
self.fd, self.tmpfilename = tempfile.mkstemp()
self.tmpfile = os.fdopen(self.fd, 'r+')
def tearDown(self):
super(TestExec, self).tearDown()
try:
self.tmpfile.close()
finally:
os.remove(self.tmpfilename)
def eval_command(self, command):
gdb.execute('cy exec open(%r, "w").write(str(%s))' %
(self.tmpfilename, command))
return self.tmpfile.read().strip()
def test_cython_exec(self):
self.break_and_run('os.path.join("foo", "bar")')
# test normal behaviour
self.assertEqual("[0]", self.eval_command('[a]'))
# test multiline code
result = gdb.execute(textwrap.dedent('''\
cy exec
pass
"nothing"
end
'''))
result = self.tmpfile.read().rstrip()
self.assertEqual('', result)
def test_python_exec(self):
self.break_and_run('os.path.join("foo", "bar")')
gdb.execute('cy step')
gdb.execute('cy exec some_random_var = 14')
self.assertEqual('14', self.eval_command('some_random_var'))
def _main(): def _main():
try: try:
gdb.lookup_type('PyModuleObject') gdb.lookup_type('PyModuleObject')
......
...@@ -2185,11 +2185,21 @@ class PythonCodeExecutor(object): ...@@ -2185,11 +2185,21 @@ class PythonCodeExecutor(object):
def alloc_pystring(self, string): def alloc_pystring(self, string):
stringp = self.alloc_string(string) stringp = self.alloc_string(string)
PyString_FromStringAndSize = 'PyString_FromStringAndSize'
try:
gdb.parse_and_eval(PyString_FromStringAndSize)
except RuntimeError:
try:
gdb.parse_and_eval('PyUnicode_FromStringAndSize')
except RuntimeError:
PyString_FromStringAndSize = 'PyUnicodeUCS2_FromStringAndSize'
else:
PyString_FromStringAndSize = 'PyUnicode_FromStringAndSize'
try: try:
result = gdb.parse_and_eval( result = gdb.parse_and_eval(
'(PyObject *) PyString_FromStringAndSize(' '(PyObject *) %s((char *) %d, (size_t) %d)' % (
'(char *) %d,' PyString_FromStringAndSize, stringp, len(string)))
'(size_t) %d)' % (stringp, len(string)))
finally: finally:
self.free(stringp) self.free(stringp)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment