mirror of
https://github.com/python/cpython.git
synced 2025-08-04 08:59:19 +00:00
fix regression in netrc comment handling (closes #12009)
This commit is contained in:
parent
e6eafa2ade
commit
1df0f214a9
4 changed files with 105 additions and 44 deletions
|
@ -1,54 +1,107 @@
|
|||
|
||||
import netrc, os, unittest, sys
|
||||
import netrc, os, unittest, sys, textwrap
|
||||
from test import 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 = support.TESTFN
|
||||
|
||||
class NetrcTestCase(unittest.TestCase):
|
||||
|
||||
def setUp(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)
|
||||
|
||||
def test_case_1(self):
|
||||
self.assertEqual(self.nrc.hosts['foo'], ('log1', 'acct1', 'pass1'))
|
||||
self.assertEqual(self.nrc.hosts['default'], ('log2', None, 'pass2'))
|
||||
def make_nrc(self, test_data):
|
||||
test_data = textwrap.dedent(test_data)
|
||||
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):
|
||||
self.assertEqual(self.nrc.macros, {'macro1':['line1\n', 'line2\n'],
|
||||
'macro2':['line3\n', 'line4\n']})
|
||||
nrc = self.make_nrc("""\
|
||||
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():
|
||||
support.run_unittest(NetrcTestCase)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue