mirror of
https://github.com/python/cpython.git
synced 2025-11-21 11:19:43 +00:00
merge 2.7.2 release branch with fix for #12009
This commit is contained in:
commit
8b8162d868
4 changed files with 107 additions and 44 deletions
12
Lib/netrc.py
12
Lib/netrc.py
|
|
@ -41,8 +41,12 @@ class netrc:
|
||||||
if not tt:
|
if not tt:
|
||||||
break
|
break
|
||||||
elif tt[0] == '#':
|
elif tt[0] == '#':
|
||||||
fp.readline();
|
# seek to beginning of comment, in case reading the token put
|
||||||
continue;
|
# us on a new line, and then skip the rest of the line.
|
||||||
|
pos = len(tt) + 1
|
||||||
|
lexer.instream.seek(-pos, 1)
|
||||||
|
lexer.instream.readline()
|
||||||
|
continue
|
||||||
elif tt == 'machine':
|
elif tt == 'machine':
|
||||||
entryname = lexer.get_token()
|
entryname = lexer.get_token()
|
||||||
elif tt == 'default':
|
elif tt == 'default':
|
||||||
|
|
@ -68,8 +72,8 @@ class netrc:
|
||||||
self.hosts[entryname] = {}
|
self.hosts[entryname] = {}
|
||||||
while 1:
|
while 1:
|
||||||
tt = lexer.get_token()
|
tt = lexer.get_token()
|
||||||
if (tt=='' or tt == 'machine' or
|
if (tt.startswith('#') or
|
||||||
tt == 'default' or tt =='macdef'):
|
tt in {'', 'machine', 'default', 'macdef'}):
|
||||||
if password:
|
if password:
|
||||||
self.hosts[entryname] = (login, account, password)
|
self.hosts[entryname] = (login, account, password)
|
||||||
lexer.push_token(tt)
|
lexer.push_token(tt)
|
||||||
|
|
|
||||||
|
|
@ -1,54 +1,107 @@
|
||||||
|
import netrc, os, unittest, sys, textwrap
|
||||||
import netrc, os, unittest, sys
|
|
||||||
from test import test_support
|
from test import test_support
|
||||||
|
|
||||||
TEST_NETRC = """
|
|
||||||
|
|
||||||
#this is a comment
|
|
||||||
#this is a comment
|
|
||||||
# this is a comment
|
|
||||||
|
|
||||||
machine foo login log1 password pass1 account acct1
|
|
||||||
machine bar login log1 password pass# account acct1
|
|
||||||
|
|
||||||
macdef macro1
|
|
||||||
line1
|
|
||||||
line2
|
|
||||||
|
|
||||||
macdef macro2
|
|
||||||
line3
|
|
||||||
line4
|
|
||||||
|
|
||||||
default login log2 password pass2
|
|
||||||
|
|
||||||
"""
|
|
||||||
|
|
||||||
temp_filename = test_support.TESTFN
|
temp_filename = test_support.TESTFN
|
||||||
|
|
||||||
class NetrcTestCase(unittest.TestCase):
|
class NetrcTestCase(unittest.TestCase):
|
||||||
|
|
||||||
def setUp (self):
|
def tearDown(self):
|
||||||
mode = 'w'
|
|
||||||
if sys.platform not in ['cygwin']:
|
|
||||||
mode += 't'
|
|
||||||
fp = open(temp_filename, mode)
|
|
||||||
fp.write(TEST_NETRC)
|
|
||||||
fp.close()
|
|
||||||
self.nrc = netrc.netrc(temp_filename)
|
|
||||||
|
|
||||||
def tearDown (self):
|
|
||||||
os.unlink(temp_filename)
|
os.unlink(temp_filename)
|
||||||
|
|
||||||
def test_case_1(self):
|
def make_nrc(self, test_data):
|
||||||
self.assertEqual(self.nrc.hosts['foo'], ('log1', 'acct1', 'pass1'))
|
test_data = textwrap.dedent(test_data)
|
||||||
self.assertEqual(self.nrc.hosts['default'], ('log2', None, 'pass2'))
|
mode = 'w'
|
||||||
|
if sys.platform != 'cygwin':
|
||||||
|
mode += 't'
|
||||||
|
with open(temp_filename, mode) as fp:
|
||||||
|
fp.write(test_data)
|
||||||
|
return netrc.netrc(temp_filename)
|
||||||
|
|
||||||
|
def test_default(self):
|
||||||
|
nrc = self.make_nrc("""\
|
||||||
|
machine host1.domain.com login log1 password pass1 account acct1
|
||||||
|
default login log2 password pass2
|
||||||
|
""")
|
||||||
|
self.assertEqual(nrc.hosts['host1.domain.com'],
|
||||||
|
('log1', 'acct1', 'pass1'))
|
||||||
|
self.assertEqual(nrc.hosts['default'], ('log2', None, 'pass2'))
|
||||||
|
|
||||||
def test_macros(self):
|
def test_macros(self):
|
||||||
self.assertEqual(self.nrc.macros, {'macro1':['line1\n', 'line2\n'],
|
nrc = self.make_nrc("""\
|
||||||
'macro2':['line3\n', 'line4\n']})
|
macdef macro1
|
||||||
|
line1
|
||||||
|
line2
|
||||||
|
|
||||||
|
macdef macro2
|
||||||
|
line3
|
||||||
|
line4
|
||||||
|
""")
|
||||||
|
self.assertEqual(nrc.macros, {'macro1': ['line1\n', 'line2\n'],
|
||||||
|
'macro2': ['line3\n', 'line4\n']})
|
||||||
|
|
||||||
|
def _test_passwords(self, nrc, passwd):
|
||||||
|
nrc = self.make_nrc(nrc)
|
||||||
|
self.assertEqual(nrc.hosts['host.domain.com'], ('log', 'acct', passwd))
|
||||||
|
|
||||||
|
def test_password_with_leading_hash(self):
|
||||||
|
self._test_passwords("""\
|
||||||
|
machine host.domain.com login log password #pass account acct
|
||||||
|
""", '#pass')
|
||||||
|
|
||||||
|
def test_password_with_trailing_hash(self):
|
||||||
|
self._test_passwords("""\
|
||||||
|
machine host.domain.com login log password pass# account acct
|
||||||
|
""", 'pass#')
|
||||||
|
|
||||||
|
def test_password_with_internal_hash(self):
|
||||||
|
self._test_passwords("""\
|
||||||
|
machine host.domain.com login log password pa#ss account acct
|
||||||
|
""", 'pa#ss')
|
||||||
|
|
||||||
|
def _test_comment(self, nrc, passwd='pass'):
|
||||||
|
nrc = self.make_nrc(nrc)
|
||||||
|
self.assertEqual(nrc.hosts['foo.domain.com'], ('bar', None, passwd))
|
||||||
|
self.assertEqual(nrc.hosts['bar.domain.com'], ('foo', None, 'pass'))
|
||||||
|
|
||||||
|
def test_comment_before_machine_line(self):
|
||||||
|
self._test_comment("""\
|
||||||
|
# comment
|
||||||
|
machine foo.domain.com login bar password pass
|
||||||
|
machine bar.domain.com login foo password pass
|
||||||
|
""")
|
||||||
|
|
||||||
|
def test_comment_before_machine_line_no_space(self):
|
||||||
|
self._test_comment("""\
|
||||||
|
#comment
|
||||||
|
machine foo.domain.com login bar password pass
|
||||||
|
machine bar.domain.com login foo password pass
|
||||||
|
""")
|
||||||
|
|
||||||
|
def test_comment_before_machine_line_hash_only(self):
|
||||||
|
self._test_comment("""\
|
||||||
|
#
|
||||||
|
machine foo.domain.com login bar password pass
|
||||||
|
machine bar.domain.com login foo password pass
|
||||||
|
""")
|
||||||
|
|
||||||
|
def test_comment_at_end_of_machine_line(self):
|
||||||
|
self._test_comment("""\
|
||||||
|
machine foo.domain.com login bar password pass # comment
|
||||||
|
machine bar.domain.com login foo password pass
|
||||||
|
""")
|
||||||
|
|
||||||
|
def test_comment_at_end_of_machine_line_no_space(self):
|
||||||
|
self._test_comment("""\
|
||||||
|
machine foo.domain.com login bar password pass #comment
|
||||||
|
machine bar.domain.com login foo password pass
|
||||||
|
""")
|
||||||
|
|
||||||
|
def test_comment_at_end_of_machine_line_pass_has_hash(self):
|
||||||
|
self._test_comment("""\
|
||||||
|
machine foo.domain.com login bar password #pass #comment
|
||||||
|
machine bar.domain.com login foo password pass
|
||||||
|
""", '#pass')
|
||||||
|
|
||||||
def test_parses_passwords_with_hash_character(self):
|
|
||||||
self.assertEqual(self.nrc.hosts['bar'], ('log1', 'acct1', 'pass#'))
|
|
||||||
|
|
||||||
def test_main():
|
def test_main():
|
||||||
test_support.run_unittest(NetrcTestCase)
|
test_support.run_unittest(NetrcTestCase)
|
||||||
|
|
|
||||||
|
|
@ -566,6 +566,7 @@ Paul Moore
|
||||||
Derek Morr
|
Derek Morr
|
||||||
James A Morrison
|
James A Morrison
|
||||||
Pablo Mouzo
|
Pablo Mouzo
|
||||||
|
Ruslan Mstoi
|
||||||
Sjoerd Mullender
|
Sjoerd Mullender
|
||||||
Sape Mullender
|
Sape Mullender
|
||||||
Michael Muller
|
Michael Muller
|
||||||
|
|
|
||||||
|
|
@ -44,6 +44,11 @@ What's New in Python 2.7.2?
|
||||||
|
|
||||||
*Release date: 2011-06-XX*
|
*Release date: 2011-06-XX*
|
||||||
|
|
||||||
|
Library
|
||||||
|
-------
|
||||||
|
|
||||||
|
- Issue #12009: Fixed regression in netrc file comment handling.
|
||||||
|
|
||||||
Extension Modules
|
Extension Modules
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue