mirror of https://github.com/python/cpython
Tests for the "commands" module, contributed by Nick Mathewson.
This closes SF patch #440291.
This commit is contained in:
parent
1586136193
commit
4c81d60fcb
|
@ -0,0 +1,45 @@
|
||||||
|
'''
|
||||||
|
Tests for commands module
|
||||||
|
Nick Mathewson
|
||||||
|
'''
|
||||||
|
import unittest
|
||||||
|
import os, tempfile, re
|
||||||
|
|
||||||
|
from test_support import TestSkipped, run_unittest
|
||||||
|
from commands import *
|
||||||
|
|
||||||
|
# The module says:
|
||||||
|
# "NB This only works (and is only relevant) for UNIX."
|
||||||
|
#
|
||||||
|
# Actually, getoutput should work on any platform with an os.popen, but
|
||||||
|
# I'll take the comment as given, and skip this suite.
|
||||||
|
|
||||||
|
if os.name != 'posix':
|
||||||
|
raise TestSkipped('Not posix; skipping test_commands')
|
||||||
|
|
||||||
|
|
||||||
|
class CommandTests(unittest.TestCase):
|
||||||
|
|
||||||
|
def test_getoutput(self):
|
||||||
|
self.assertEquals(getoutput('echo xyzzy'), 'xyzzy')
|
||||||
|
self.assertEquals(getstatusoutput('echo xyzzy'), (0, 'xyzzy'))
|
||||||
|
|
||||||
|
# we use mktemp in the next line to get a filename which we
|
||||||
|
# _know_ won't exist. This is guaranteed to fail.
|
||||||
|
status, output = getstatusoutput('cat ' + tempfile.mktemp())
|
||||||
|
self.assertNotEquals(status, 0)
|
||||||
|
|
||||||
|
def test_getstatus(self):
|
||||||
|
# This pattern should match 'ls -ld /bin/ls' on any posix
|
||||||
|
# system, however perversely configured.
|
||||||
|
pat = r'''-..x..x..x # It is executable.
|
||||||
|
\s+\d+ # It has some number of links.
|
||||||
|
\s+\w+\s+\w+ # It has a user and group, which may
|
||||||
|
# be named anything.
|
||||||
|
[^/]* # Skip the date.
|
||||||
|
/bin/ls # and end with the name of the file.
|
||||||
|
'''
|
||||||
|
|
||||||
|
self.assert_(re.match(pat, getstatus("/bin/ls"), re.VERBOSE))
|
||||||
|
|
||||||
|
run_unittest(CommandTests)
|
Loading…
Reference in New Issue