diff options
author | Victor Stinner <vstinner@python.org> | 2020-04-29 15:11:48 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-04-29 15:11:48 (GMT) |
commit | ec9bea4a3766bd815148a27f61eb24e7dd459ac7 (patch) | |
tree | 808f462e186e6c7ff286186bac813af8488325c7 | |
parent | 9a8c1315c3041fdb85d091bb8dc92f0d9dcb1529 (diff) | |
download | cpython-ec9bea4a3766bd815148a27f61eb24e7dd459ac7.zip cpython-ec9bea4a3766bd815148a27f61eb24e7dd459ac7.tar.gz cpython-ec9bea4a3766bd815148a27f61eb24e7dd459ac7.tar.bz2 |
bpo-40436: Fix code parsing gdb version (GH-19792)
test_gdb and test.pythoninfo now check gdb command exit code.
-rw-r--r-- | Lib/test/pythoninfo.py | 3 | ||||
-rw-r--r-- | Lib/test/test_gdb.py | 10 | ||||
-rw-r--r-- | Misc/NEWS.d/next/Tests/2020-04-29-16-08-24.bpo-40436.gDMnYl.rst | 1 |
3 files changed, 12 insertions, 2 deletions
diff --git a/Lib/test/pythoninfo.py b/Lib/test/pythoninfo.py index cc230dd..cc0bbc5 100644 --- a/Lib/test/pythoninfo.py +++ b/Lib/test/pythoninfo.py @@ -376,6 +376,9 @@ def collect_gdb(info_add): stderr=subprocess.PIPE, universal_newlines=True) version = proc.communicate()[0] + if proc.returncode: + # ignore gdb failure: test_gdb will log the error + return except OSError: return diff --git a/Lib/test/test_gdb.py b/Lib/test/test_gdb.py index fb14801..210cd0d 100644 --- a/Lib/test/test_gdb.py +++ b/Lib/test/test_gdb.py @@ -17,12 +17,18 @@ from test.support import findfile, python_is_optimized def get_gdb_version(): try: - proc = subprocess.Popen(["gdb", "-nx", "--version"], + cmd = ["gdb", "-nx", "--version"] + proc = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, universal_newlines=True) with proc: - version = proc.communicate()[0] + version, stderr = proc.communicate() + + if proc.returncode: + raise Exception(f"Command {' '.join(cmd)!r} failed " + f"with exit code {proc.returncode}: " + f"stdout={version!r} stderr={stderr!r}") except OSError: # This is what "no gdb" looks like. There may, however, be other # errors that manifest this way too. diff --git a/Misc/NEWS.d/next/Tests/2020-04-29-16-08-24.bpo-40436.gDMnYl.rst b/Misc/NEWS.d/next/Tests/2020-04-29-16-08-24.bpo-40436.gDMnYl.rst new file mode 100644 index 0000000..0aee2c3 --- /dev/null +++ b/Misc/NEWS.d/next/Tests/2020-04-29-16-08-24.bpo-40436.gDMnYl.rst @@ -0,0 +1 @@ +test_gdb and test.pythoninfo now check gdb command exit code. |