mirror of
https://github.com/python/cpython.git
synced 2024-11-29 21:05:33 +08:00
88fc6646d1
* Fix some docstrings and one Print -> print. * Fix test_{class,code,descrtut,dis,extcall,parser,popen,pkg,subprocess,syntax,traceback}. These were the ones that generated code with a print statement. In most remaining failing tests there's an issue with the soft space.
48 lines
1.4 KiB
Python
48 lines
1.4 KiB
Python
#! /usr/bin/env python
|
|
"""Basic tests for os.popen()
|
|
|
|
Particularly useful for platforms that fake popen.
|
|
"""
|
|
|
|
import unittest
|
|
from test import test_support
|
|
import os, sys
|
|
|
|
# Test that command-lines get down as we expect.
|
|
# To do this we execute:
|
|
# python -c "import sys;print sys.argv" {rest_of_commandline}
|
|
# This results in Python being spawned and printing the sys.argv list.
|
|
# We can then eval() the result of this, and see what each argv was.
|
|
python = sys.executable
|
|
if ' ' in python:
|
|
python = '"' + python + '"' # quote embedded space for cmdline
|
|
|
|
class PopenTest(unittest.TestCase):
|
|
def _do_test_commandline(self, cmdline, expected):
|
|
cmd = '%s -c "import sys; print(sys.argv)" %s' % (python, cmdline)
|
|
data = os.popen(cmd).read()
|
|
got = eval(data)[1:] # strip off argv[0]
|
|
self.assertEqual(got, expected)
|
|
|
|
def test_popen(self):
|
|
self.assertRaises(TypeError, os.popen)
|
|
self._do_test_commandline(
|
|
"foo bar",
|
|
["foo", "bar"]
|
|
)
|
|
self._do_test_commandline(
|
|
'foo "spam and eggs" "silly walk"',
|
|
["foo", "spam and eggs", "silly walk"]
|
|
)
|
|
self._do_test_commandline(
|
|
'foo "a \\"quoted\\" arg" bar',
|
|
["foo", 'a "quoted" arg', "bar"]
|
|
)
|
|
test_support.reap_children()
|
|
|
|
def test_main():
|
|
test_support.run_unittest(PopenTest)
|
|
|
|
if __name__ == "__main__":
|
|
test_main()
|