diff options
| author | Gregory P. Smith <greg@krypto.org> | 2020-12-24 20:57:21 -0800 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-12-24 20:57:21 -0800 | 
| commit | 64abf373444944a240274a9b6d66d1cb01ecfcdd (patch) | |
| tree | 7cc3f785fec2389d6dd9b7bd05860e45ee3f459c /Lib/subprocess.py | |
| parent | 8badadec53cbf9dc049c5b54198c5689481e3f3f (diff) | |
| download | cpython-git-64abf373444944a240274a9b6d66d1cb01ecfcdd.tar.gz | |
bpo-42388: Fix subprocess.check_output input=None when text=True (GH-23467)
When the modern text= spelling of the universal_newlines= parameter was added
for Python 3.7, check_output's special case around input=None was overlooked.
So it behaved differently with universal_newlines=True vs text=True.  This
reconciles the behavior to be consistent and adds a test to guarantee it.
Also clarifies the existing check_output documentation.
Co-authored-by: Alexey Izbyshev <izbyshev@ispras.ru>
Diffstat (limited to 'Lib/subprocess.py')
| -rw-r--r-- | Lib/subprocess.py | 6 | 
1 files changed, 5 insertions, 1 deletions
| diff --git a/Lib/subprocess.py b/Lib/subprocess.py index e259dc3a8e..aa107cb60e 100644 --- a/Lib/subprocess.py +++ b/Lib/subprocess.py @@ -420,7 +420,11 @@ def check_output(*popenargs, timeout=None, **kwargs):      if 'input' in kwargs and kwargs['input'] is None:          # Explicitly passing input=None was previously equivalent to passing an          # empty string. That is maintained here for backwards compatibility. -        kwargs['input'] = '' if kwargs.get('universal_newlines', False) else b'' +        if kwargs.get('universal_newlines') or kwargs.get('text'): +            empty = '' +        else: +            empty = b'' +        kwargs['input'] = empty      return run(*popenargs, stdout=PIPE, timeout=timeout, check=True,                 **kwargs).stdout | 
