]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
[2.7] bpo-14546: Fix the argument handling in Tools/scripts/lll.py (GH-13026) (GH...
authorZackery Spytz <zspytz@gmail.com>
Thu, 2 May 2019 19:29:22 +0000 (13:29 -0600)
committerVictor Stinner <vstinner@redhat.com>
Thu, 2 May 2019 19:29:21 +0000 (15:29 -0400)
(cherry picked from commit c4e78b116f9a4299f3b3bfbbd18ef49782bb1143)

Lib/test/test_tools.py
Misc/NEWS.d/next/Tools-Demos/2019-04-30-14-30-29.bpo-14546.r38Y-6.rst [new file with mode: 0644]
Tools/scripts/lll.py

index 51e4fd61c77aa0e9b4d459a65acf2bc7dda35ab1..39116b3a79d5f2644647be8dd671497d7460d0d8 100644 (file)
@@ -445,6 +445,33 @@ class FixcidTests(unittest.TestCase):
         return output.getvalue()
 
 
+class LllTests(unittest.TestCase):
+
+    script = os.path.join(scriptsdir, 'lll.py')
+
+    @unittest.skipUnless(hasattr(os, 'symlink'), 'Requires symlink support')
+    def test_lll_multiple_dirs(self):
+        dir1 = tempfile.mkdtemp()
+        dir2 = tempfile.mkdtemp()
+        self.addCleanup(test_support.rmtree, dir1)
+        self.addCleanup(test_support.rmtree, dir2)
+        fn1 = os.path.join(dir1, 'foo1')
+        fn2 = os.path.join(dir2, 'foo2')
+        for fn, dir in (fn1, dir1), (fn2, dir2):
+            open(fn, 'w').close()
+            os.symlink(fn, os.path.join(dir, 'symlink'))
+
+        rc, out, err = assert_python_ok(self.script, dir1, dir2)
+        self.assertEqual(out,
+            '{dir1}:\n'
+            'symlink -> {fn1}\n'
+            '\n'
+            '{dir2}:\n'
+            'symlink -> {fn2}\n'
+            .format(dir1=dir1, fn1=fn1, dir2=dir2, fn2=fn2)
+        )
+
+
 def test_main():
     test_support.run_unittest(*[obj for obj in globals().values()
                                     if isinstance(obj, type)])
diff --git a/Misc/NEWS.d/next/Tools-Demos/2019-04-30-14-30-29.bpo-14546.r38Y-6.rst b/Misc/NEWS.d/next/Tools-Demos/2019-04-30-14-30-29.bpo-14546.r38Y-6.rst
new file mode 100644 (file)
index 0000000..b8659b8
--- /dev/null
@@ -0,0 +1 @@
+Fix the argument handling in Tools/scripts/lll.py.
index 9902d9d394b26b8ab2debc17ea6afe604e175042..c6de245ab4e4166130753568e07082d1c63a425b 100755 (executable)
@@ -13,8 +13,7 @@ def lll(dirname):
             full = os.path.join(dirname, name)
             if os.path.islink(full):
                 print name, '->', os.readlink(full)
-def main():
-    args = sys.argv[1:]
+def main(args):
     if not args: args = [os.curdir]
     first = 1
     for arg in args:
@@ -22,7 +21,7 @@ def main():
             if not first: print
             first = 0
             print arg + ':'
-    lll(arg)
+        lll(arg)
 
 if __name__ == '__main__':
-    main()
+    main(sys.argv[1:])