summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorBerker Peksag <berker.peksag@gmail.com>2017-01-02 03:59:12 (GMT)
committerBerker Peksag <berker.peksag@gmail.com>2017-01-02 03:59:12 (GMT)
commit01debaccdd1042ecff474637bd8905d6ec3efd60 (patch)
tree34b44a52f9f0c8c913435fa351fd99b2a173300e /Lib
parent5430293fdf286b33f2370d15705ee4339c81e82c (diff)
parentff0e3b7a54673791bb724be9679c85a4feb7468c (diff)
downloadcpython-01debaccdd1042ecff474637bd8905d6ec3efd60.zip
cpython-01debaccdd1042ecff474637bd8905d6ec3efd60.tar.gz
cpython-01debaccdd1042ecff474637bd8905d6ec3efd60.tar.bz2
Issue #15812: Merge from 3.5
Diffstat (limited to 'Lib')
-rw-r--r--Lib/inspect.py2
-rw-r--r--Lib/test/test_inspect.py5
2 files changed, 6 insertions, 1 deletions
diff --git a/Lib/inspect.py b/Lib/inspect.py
index e08e9f5..ba7a913 100644
--- a/Lib/inspect.py
+++ b/Lib/inspect.py
@@ -1416,7 +1416,7 @@ def getframeinfo(frame, context=1):
except OSError:
lines = index = None
else:
- start = max(start, 1)
+ start = max(start, 0)
start = max(0, min(start, len(lines) - context))
lines = lines[start:start+context]
index = lineno - 1 - start
diff --git a/Lib/test/test_inspect.py b/Lib/test/test_inspect.py
index 97634e5..88eaabe 100644
--- a/Lib/test/test_inspect.py
+++ b/Lib/test/test_inspect.py
@@ -402,6 +402,11 @@ class TestRetrievingSourceCode(GetSourceBase):
# Check filename override
self.assertEqual(inspect.getmodule(None, modfile), mod)
+ def test_getframeinfo_get_first_line(self):
+ frame_info = inspect.getframeinfo(self.fodderModule.fr, 50)
+ self.assertEqual(frame_info.code_context[0], "# line 1\n")
+ self.assertEqual(frame_info.code_context[1], "'A module docstring.'\n")
+
def test_getsource(self):
self.assertSourceEqual(git.abuse, 29, 39)
self.assertSourceEqual(mod.StupidGit, 21, 51)