mirror of
git://git.sv.gnu.org/emacs.git
synced 2026-01-09 13:10:57 -08:00
dired-do-shell-command: Fix check for wildcards
* lisp/dired-aux.el (dired-do-shell-command): Replace just '?', '*' and '`?' i.e., keep the whitespaces. * test/lisp/dired-aux-tests.el (dired-test-bug27496): Add test.
This commit is contained in:
parent
1b4f0a92ff
commit
bc3dcd524d
2 changed files with 45 additions and 1 deletions
44
test/lisp/dired-aux-tests.el
Normal file
44
test/lisp/dired-aux-tests.el
Normal file
|
|
@ -0,0 +1,44 @@
|
|||
;;; dired-aux-tests.el --- Test suite for dired-aux. -*- lexical-binding: t -*-
|
||||
|
||||
;; Copyright (C) 2017 Free Software Foundation, Inc.
|
||||
|
||||
;; This file is part of GNU Emacs.
|
||||
|
||||
;; GNU Emacs is free software: you can redistribute it and/or modify
|
||||
;; it under the terms of the GNU General Public License as published by
|
||||
;; the Free Software Foundation, either version 3 of the License, or
|
||||
;; (at your option) any later version.
|
||||
|
||||
;; GNU Emacs is distributed in the hope that it will be useful,
|
||||
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
;; GNU General Public License for more details.
|
||||
|
||||
;; You should have received a copy of the GNU General Public License
|
||||
;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
;;; Code:
|
||||
(require 'ert)
|
||||
(require 'dired-aux)
|
||||
|
||||
|
||||
(ert-deftest dired-test-bug27496 ()
|
||||
"Test for http://debbugs.gnu.org/27496 ."
|
||||
(skip-unless (executable-find shell-file-name))
|
||||
(let* ((foo (make-temp-file "foo"))
|
||||
(files (list foo)))
|
||||
(unwind-protect
|
||||
(cl-letf (((symbol-function 'y-or-n-p) 'error))
|
||||
(dired temporary-file-directory)
|
||||
(dired-goto-file foo)
|
||||
;; `dired-do-shell-command' returns nil on success.
|
||||
(should-error (dired-do-shell-command "ls ? ./?" nil files))
|
||||
(should-error (dired-do-shell-command "ls ./? ?" nil files))
|
||||
(should-not (dired-do-shell-command "ls ? ?" nil files))
|
||||
(should-error (dired-do-shell-command "ls * ./*" nil files))
|
||||
(should-not (dired-do-shell-command "ls * *" nil files))
|
||||
(should-not (dired-do-shell-command "ls ? ./`?`" nil files)))
|
||||
(delete-file foo))))
|
||||
|
||||
(provide 'dired-aux-tests)
|
||||
;; dired-aux-tests.el ends here
|
||||
Loading…
Add table
Add a link
Reference in a new issue