File: test_popen.py

package info (click to toggle)
jython 2.5.1-2
  • links: PTS
  • area: main
  • in suites: squeeze
  • size: 41,624 kB
  • ctags: 101,579
  • sloc: python: 351,444; java: 204,338; xml: 1,316; sh: 330; ansic: 126; perl: 114; makefile: 94
file content (40 lines) | stat: -rw-r--r-- 1,427 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#!/usr/bin/jython
"""Basic tests for os.popen()

  Particularly useful for platforms that fake popen.
"""

import os
import sys
from test.test_support import TestSkipped, reap_children
from os import popen

# 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
def _do_test_commandline(cmdline, expected):
    cmd = '%s -c "import sys;print sys.argv" %s' % (python, cmdline)
    data = popen(cmd).read()
    got = eval(data)[1:] # strip off argv[0]
    if got != expected:
        print "Error in popen commandline handling."
        print " executed '%s', expected '%r', but got '%r'" \
                                                    % (cmdline, expected, got)

def _test_commandline():
    _do_test_commandline("foo bar", ["foo", "bar"])
    _do_test_commandline('foo "spam and eggs" "silly walk"', ["foo", "spam and eggs", "silly walk"])
    _do_test_commandline('foo "a \\"quoted\\" arg" bar', ["foo", 'a "quoted" arg', "bar"])
    print "popen seemed to process the command-line correctly"

def main():
    print "Test popen:"
    _test_commandline()
    reap_children()

main()