diff options
| author | Benjamin Peterson <benjamin@python.org> | 2011-06-10 11:32:52 -0500 | 
|---|---|---|
| committer | Benjamin Peterson <benjamin@python.org> | 2011-06-10 11:32:52 -0500 | 
| commit | 1df0f214a9fdb4dde7506576b144cf6a7fd01b65 (patch) | |
| tree | 5e2be8076884a09ef53577d9053c73d0e7570c62 /Lib/test/test_netrc.py | |
| parent | e6eafa2ade22dc687eee78374fa93d4b9ab7a2c1 (diff) | |
| download | cpython-git-1df0f214a9fdb4dde7506576b144cf6a7fd01b65.tar.gz | |
fix regression in netrc comment handling (closes #12009)
Diffstat (limited to 'Lib/test/test_netrc.py')
| -rw-r--r-- | Lib/test/test_netrc.py | 131 | 
1 files changed, 92 insertions, 39 deletions
| diff --git a/Lib/test/test_netrc.py b/Lib/test/test_netrc.py index da7ec050d2..ef70e3754a 100644 --- a/Lib/test/test_netrc.py +++ b/Lib/test/test_netrc.py @@ -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) | 
