emacs/test/lisp/use-package/use-package-tests.el

2033 lines
64 KiB
EmacsLisp
Raw Permalink Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

;;; use-package-tests.el --- Tests for use-package.el -*- lexical-binding: t; -*-
;; Copyright (C) 2014-2024 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 <https://www.gnu.org/licenses/>.
;;; Code:
(require 'cl-lib)
(require 'ert)
(require 'use-package)
(setq use-package-always-ensure nil
use-package-verbose 'errors
use-package-expand-minimally t
;; These are needed for certain tests below where the `pcase' match
;; expression is large and contains holes, such as the :after tests.
max-lisp-eval-depth 8000
max-specpdl-size 8000)
(unless (fboundp 'macroexpand-1)
(defun macroexpand-1 (form &optional environment)
"Perform (at most) one step of macroexpansion."
(cond
((consp form)
(let* ((head (car form))
(env-expander (assq head environment)))
(if env-expander
(if (cdr env-expander)
(apply (cdr env-expander) (cdr form))
form)
(if (not (and (symbolp head) (fboundp head)))
form
(let ((def (autoload-do-load (symbol-function head) head 'macro)))
(cond
;; Follow alias, but only for macros, otherwise we may end up
;; skipping an important compiler-macro (e.g. cl--block-wrapper).
((and (symbolp def) (macrop def)) (cons def (cdr form)))
((not (consp def)) form)
(t
(if (eq 'macro (car def))
(apply (cdr def) (cdr form))
form))))))))
(t form))))
(defmacro expand-minimally (form)
`(let ((use-package-verbose 'errors)
(use-package-expand-minimally t))
(macroexpand-1 ',form)))
(defmacro expand-maximally (form)
`(let ((use-package-verbose 'debug)
(use-package-expand-minimally nil))
(macroexpand-1 ',form)))
(defmacro match-expansion (form &rest value)
`(should (pcase (expand-minimally ,form)
,@(mapcar #'(lambda (x) (list x t)) value))))
(defun fix-expansion ()
(interactive)
(save-excursion
(unless (looking-at "(match-expansion")
(backward-up-list))
(when (looking-at "(match-expansion")
(re-search-forward "(\\(use-package\\|bind-key\\)")
(goto-char (match-beginning 0))
(let ((decl (read (current-buffer))))
(kill-sexp)
(let (vars)
(catch 'exit
(save-excursion
(while (ignore-errors (backward-up-list) t)
(when (looking-at "(let\\s-+")
(goto-char (match-end 0))
(setq vars (read (current-buffer)))
(throw 'exit t)))))
(eval
`(let (,@ (append vars
'((use-package-verbose 'errors)
(use-package-expand-minimally t))))
(insert ?\n ?\` (pp-to-string (macroexpand-1 decl))))))))))
(bind-key "C-c C-u" #'fix-expansion emacs-lisp-mode-map)
(ert-deftest use-package-test-recognize-function ()
(should (use-package-recognize-function nil t))
(should-not (use-package-recognize-function nil))
(should (use-package-recognize-function t))
(should (use-package-recognize-function 'sym))
(should (use-package-recognize-function #'sym))
(should (use-package-recognize-function (lambda () ...)))
(should (use-package-recognize-function '(lambda () ...)))
(should (use-package-recognize-function #'(lambda () ...)))
(should-not (use-package-recognize-function 1))
(should-not (use-package-recognize-function "Hello"))
(should-not (use-package-recognize-function '(nil . nil))))
(ert-deftest use-package-test-normalize-function ()
(should (equal (use-package-normalize-function nil) nil))
(should (equal (use-package-normalize-function t) t))
(should (equal (use-package-normalize-function 'sym) 'sym))
(should (equal (use-package-normalize-function #'sym) 'sym))
(should (equal (use-package-normalize-function '(lambda () ...)) '(lambda () ...)))
(should (equal (use-package-normalize-function ''(lambda () ...)) '(lambda () ...)))
(should (equal (use-package-normalize-function '#'(lambda () ...)) '(lambda () ...)))
(should (equal (use-package-normalize-function 1) 1))
(should (equal (use-package-normalize-function "Hello") "Hello"))
(should (equal (use-package-normalize-function '(nil . nil)) '(nil . nil))))
(ert-deftest use-package-test/:disabled-1 ()
(match-expansion
(use-package foo :disabled t)
`()))
(ert-deftest use-package-test/:preface-1 ()
(match-expansion
(use-package foo :preface (t))
`(progn
(eval-and-compile
(t))
(require 'foo nil nil))))
(ert-deftest use-package-test/:preface-2 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :preface (t))
`(progn
(eval-and-compile
(eval-when-compile
(with-demoted-errors
"Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t))))
(t))
(require 'foo nil nil)))))
(ert-deftest use-package-test/:preface-3 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo
:preface (preface)
:init (init)
:config (config)
:functions func
:defines def)
`(progn
(eval-and-compile
(defvar def)
(declare-function func "foo")
(eval-when-compile
(with-demoted-errors
"Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t))))
(preface))
(init)
(require 'foo nil nil)
(config)
t))))
(ert-deftest use-package-test/:preface-4 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo
:preface (preface)
:init (init)
:config (config)
:functions func
:defines def
:defer t)
`(progn
(eval-and-compile
(defvar def)
(declare-function func "foo")
(eval-when-compile
(with-demoted-errors
"Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t))))
(preface))
(init)
(eval-after-load 'foo
'(progn
(config)
t))))))
(ert-deftest use-package-test/:pin-1 ()
(match-expansion
(use-package foo :pin foo)
`(progn
(use-package-pin-package 'foo "foo")
(require 'foo nil nil))))
(ert-deftest use-package-test/:pin-2 ()
(match-expansion
(use-package foo :pin "foo")
`(progn
(use-package-pin-package 'foo "foo")
(require 'foo nil nil))))
(ert-deftest use-package-test-normalize/:ensure ()
(cl-flet ((norm (&rest args)
(apply #'use-package-normalize/:ensure
'foopkg :ensure args)))
(should (equal (norm '(t)) '(t)))
(should (equal (norm '(nil)) '(nil)))
(should (equal (norm '(sym)) '(sym)))
(should-error (norm '(1)))
(should-error (norm '("Hello")))))
(ert-deftest use-package-test/:ensure-1 ()
(let ((use-package-always-ensure nil))
(match-expansion
(use-package foo :ensure t)
`(progn
(use-package-ensure-elpa 'foo '(t) 'nil)
(require 'foo nil nil)))))
(ert-deftest use-package-test/:ensure-2 ()
(let ((use-package-always-ensure t))
(match-expansion
(use-package foo :ensure t)
`(progn
(use-package-ensure-elpa 'foo '(t) 'nil)
(require 'foo nil nil)))))
(ert-deftest use-package-test/:ensure-3 ()
(let ((use-package-always-ensure nil))
(match-expansion
(use-package foo :ensure nil)
`(progn
(use-package-ensure-elpa 'foo '(nil) 'nil)
(require 'foo nil nil)))))
(ert-deftest use-package-test/:ensure-4 ()
(let ((use-package-always-ensure t))
(match-expansion
(use-package foo :ensure nil)
`(progn
(use-package-ensure-elpa 'foo '(nil) 'nil)
(require 'foo nil nil)))))
(ert-deftest use-package-test/:ensure-5 ()
(let ((use-package-always-ensure nil))
(match-expansion
(use-package foo :load-path "foo")
`(progn
(eval-and-compile
(add-to-list 'load-path ,(pred stringp)))
(require 'foo nil nil)))))
(ert-deftest use-package-test/:ensure-6 ()
(let ((use-package-always-ensure t))
(match-expansion
(use-package foo :load-path "foo")
`(progn
(eval-and-compile
(add-to-list 'load-path ,(pred stringp)))
(require 'foo nil nil)))))
(ert-deftest use-package-test/:ensure-7 ()
(let ((use-package-always-ensure nil))
(match-expansion
(use-package foo :ensure nil :load-path "foo")
`(progn
(use-package-ensure-elpa 'foo '(nil) 'nil)
(eval-and-compile
(add-to-list 'load-path ,(pred stringp)))
(require 'foo nil nil)))))
(ert-deftest use-package-test/:ensure-8 ()
(let ((use-package-always-ensure t))
(match-expansion
(use-package foo :ensure nil :load-path "foo")
`(progn
(use-package-ensure-elpa 'foo '(nil) 'nil)
(eval-and-compile
(add-to-list 'load-path ,(pred stringp)))
(require 'foo nil nil)))))
(ert-deftest use-package-test/:ensure-9 ()
(let ((use-package-always-ensure nil))
(match-expansion
(use-package foo :ensure t :load-path "foo")
`(progn
(use-package-ensure-elpa 'foo '(t) 'nil)
(eval-and-compile
(add-to-list 'load-path ,(pred stringp)))
(require 'foo nil nil)))))
(ert-deftest use-package-test/:ensure-10 ()
(let ((use-package-always-ensure t))
(match-expansion
(use-package foo :ensure t :load-path "foo")
`(progn
(use-package-ensure-elpa 'foo '(t) 'nil)
(eval-and-compile
(add-to-list 'load-path ,(pred stringp)))
(require 'foo nil nil)))))
(ert-deftest use-package-test/:ensure-11 ()
(let (tried-to-install)
(cl-letf (((symbol-function #'use-package-ensure-elpa)
(lambda (name ensure state &optional no-refresh)
(when ensure
(setq tried-to-install name))))
((symbol-function #'require) #'ignore))
(use-package foo :ensure t)
(should (eq tried-to-install 'foo)))))
(ert-deftest use-package-test/:ensure-12 ()
(let ((use-package-always-ensure t))
(match-expansion
(use-package foo :ensure bar)
`(progn
(use-package-ensure-elpa 'foo '(bar) 'nil)
(require 'foo nil nil)))))
(ert-deftest use-package-test/:ensure-13 ()
(let ((use-package-always-ensure t))
(match-expansion
(use-package foo :ensure bar :ensure quux)
`(progn
(use-package-ensure-elpa 'foo '(bar quux) 'nil)
(require 'foo nil nil)))))
(ert-deftest use-package-test/:ensure-14 ()
(match-expansion
(use-package ess-site
:ensure ess1
:ensure ess2
:ensure (ess3 :pin "melpa-unstable")
:pin melpa-stable)
`(progn
(use-package-pin-package 'ess-site "melpa-stable")
(use-package-ensure-elpa 'ess-site
'(ess1 ess2
(ess3 . "melpa-unstable"))
'nil)
(require 'ess-site nil nil))))
(ert-deftest use-package-test/:ensure-15 ()
(let ((use-package-always-ensure t))
(match-expansion
(use-package foo
:pin "elpa"
:ensure bar
:ensure (quux :pin "melpa"))
`(progn
(use-package-pin-package 'foo "elpa")
(use-package-ensure-elpa 'foo
'(bar
(quux . "melpa"))
'nil)
(require 'foo nil nil)))))
(ert-deftest use-package-test/:if-1 ()
(match-expansion
(use-package foo :if t)
`(when t
(require 'foo nil nil))))
(ert-deftest use-package-test/:if-2 ()
(match-expansion
(use-package foo :if (and t t))
`(when (and t t)
(require 'foo nil nil))))
(ert-deftest use-package-test/:if-3 ()
(match-expansion
(use-package foo :if nil)
`(when nil
(require 'foo nil nil))))
(ert-deftest use-package-test/:when-1 ()
(match-expansion
(use-package foo :when t)
`(when t
(require 'foo nil nil))))
(ert-deftest use-package-test/:when-2 ()
(match-expansion
(use-package foo :when (and t t))
`(when (and t t)
(require 'foo nil nil))))
(ert-deftest use-package-test/:when-3 ()
(match-expansion
(use-package foo :when nil)
`(when nil
(require 'foo nil nil))))
(ert-deftest use-package-test/:unless-1 ()
(match-expansion
(use-package foo :unless t)
`(when (not t)
(require 'foo nil nil))))
(ert-deftest use-package-test/:unless-2 ()
(match-expansion
(use-package foo :unless (and t t))
`(when (not (and t t))
(require 'foo nil nil))))
(ert-deftest use-package-test/:unless-3 ()
(match-expansion
(use-package foo :unless nil)
`(unless nil
(require 'foo nil nil))))
(ert-deftest use-package-test/:requires-1 ()
(match-expansion
(use-package foo :requires bar)
`(when (featurep 'bar)
(require 'foo nil nil))))
(ert-deftest use-package-test/:requires-2 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :requires bar)
`(when (featurep 'bar)
(eval-and-compile
(eval-when-compile
(with-demoted-errors
"Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t)))))
(require 'foo nil nil)))))
(ert-deftest use-package-test/:requires-3 ()
(match-expansion
(use-package foo :requires (bar quux))
`(when (not (member nil (mapcar #'featurep '(bar quux))))
(require 'foo nil nil))))
(ert-deftest use-package-test/:requires-4 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :requires bar)
`(when (featurep 'bar)
(eval-and-compile
(eval-when-compile
(with-demoted-errors "Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t)))))
(require 'foo nil nil)))))
(ert-deftest use-package-test/:load-path-1 ()
(match-expansion
(use-package foo :load-path "bar")
`(progn
(eval-and-compile
(add-to-list 'load-path
,(pred (apply-partially
#'string=
(expand-file-name
"bar" user-emacs-directory)))))
(require 'foo nil nil))))
(ert-deftest use-package-test/:load-path-2 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :load-path "bar")
`(progn
(eval-and-compile
(add-to-list 'load-path
,(pred (apply-partially
#'string=
(expand-file-name
"bar" user-emacs-directory)))))
(eval-and-compile
(eval-when-compile
(with-demoted-errors "Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t)))))
(require 'foo nil nil)))))
(ert-deftest use-package-test/:load-path-3 ()
(match-expansion
(use-package foo :load-path ("bar" "quux"))
`(progn
(eval-and-compile
(add-to-list 'load-path
,(pred (apply-partially
#'string=
(expand-file-name
"bar" user-emacs-directory)))))
(eval-and-compile
(add-to-list 'load-path
,(pred (apply-partially
#'string=
(expand-file-name
"quux" user-emacs-directory)))))
(require 'foo nil nil))))
(ert-deftest use-package-test/:load-path-4 ()
(match-expansion
(use-package foo :load-path (lambda () (list "bar" "quux")))
`(progn
(eval-and-compile
(add-to-list 'load-path
,(pred (apply-partially
#'string=
(expand-file-name
"bar" user-emacs-directory)))))
(eval-and-compile
(add-to-list 'load-path
,(pred (apply-partially
#'string=
(expand-file-name
"quux" user-emacs-directory)))))
(require 'foo nil nil))))
(ert-deftest use-package-test/:no-require-1 ()
(match-expansion
(use-package foo :no-require t)
`nil))
(ert-deftest use-package-test/:no-require-2 ()
(match-expansion
(use-package foo :no-require t :config (config))
`(progn
(config)
t)))
(ert-deftest use-package-test/:no-require-3 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :no-require t)
`(eval-and-compile
(eval-when-compile
(with-demoted-errors "Cannot load foo: %S" nil nil))))))
(defun use-package-test-normalize-bind (&rest args)
(apply #'use-package-normalize-binder 'foo :bind args))
(ert-deftest use-package-test-normalize/:bind-1 ()
(should (equal (use-package-test-normalize-bind
'(("C-a" . alpha)))
'(("C-a" . alpha)))))
(ert-deftest use-package-test-normalize/:bind-2 ()
(should (equal (use-package-test-normalize-bind
'(("C-a" . alpha)
:map foo-map
("C-b" . beta)))
'(("C-a" . alpha)
:map foo-map
("C-b" . beta)))))
(ert-deftest use-package-test-normalize/:bind-3 ()
(should (equal (use-package-test-normalize-bind
'(:map foo-map
("C-a" . alpha)
("C-b" . beta)))
'(:map foo-map
("C-a" . alpha)
("C-b" . beta)))))
(ert-deftest use-package-test/:bind-1 ()
(match-expansion
(use-package foo :bind ("C-k" . key1) ("C-u" . key2))
`(progn
(unless
(fboundp 'key1)
(autoload #'key1 "foo" nil t))
(unless
(fboundp 'key2)
(autoload #'key2 "foo" nil t))
(bind-keys :package foo
("C-k" . key1)
("C-u" . key2)))))
(ert-deftest use-package-test/:bind-2 ()
(match-expansion
(use-package foo :bind (("C-k" . key1) ("C-u" . key2)))
`(progn
(unless (fboundp 'key1)
(autoload #'key1 "foo" nil t))
(unless (fboundp 'key2)
(autoload #'key2 "foo" nil t))
(bind-keys :package foo
("C-k" . key1)
("C-u" . key2)))))
(ert-deftest use-package-test/:bind-3 ()
(match-expansion
(use-package foo :bind (:map my-map ("C-k" . key1) ("C-u" . key2)))
`(progn
(unless
(fboundp 'key1)
(autoload #'key1 "foo" nil t))
(unless
(fboundp 'key2)
(autoload #'key2 "foo" nil t))
(bind-keys :package foo :map my-map
("C-k" . key1)
("C-u" . key2)))))
(ert-deftest use-package-test/:bind-4 ()
(should-error
(match-expansion
(use-package foo :bind :map my-map ("C-k" . key1) ("C-u" . key2))
`(bind-keys :package foo))))
(ert-deftest use-package-test/:bind-5 ()
(match-expansion
(use-package foo :bind ("C-k" . key1) (:map my-map ("C-u" . key2)))
`(progn
(unless (fboundp 'key1)
(autoload #'key1 "foo" nil t))
(unless (fboundp 'key2)
(autoload #'key2 "foo" nil t))
(bind-keys :package foo
("C-k" . key1)
:map my-map
("C-u" . key2)))))
(ert-deftest use-package-test/:bind-6 ()
(match-expansion
(use-package foo
:bind
("C-k" . key1)
(:map my-map ("C-u" . key2))
(:map my-map2 ("C-u" . key3)))
`(progn
(unless (fboundp 'key1)
(autoload #'key1 "foo" nil t))
(unless (fboundp 'key2)
(autoload #'key2 "foo" nil t))
(unless (fboundp 'key3)
(autoload #'key3 "foo" nil t))
(bind-keys :package foo
("C-k" . key1)
:map my-map ("C-u" . key2)
:map my-map2 ("C-u" . key3)))))
(ert-deftest use-package-test/:bind-7 ()
(match-expansion
(use-package foo
:ensure
:bind ("C-c r" . browse-at-remote))
`(progn
(use-package-ensure-elpa 'foo '(t) 'nil)
(unless (fboundp 'browse-at-remote)
(autoload #'browse-at-remote "foo" nil t))
(bind-keys :package foo ("C-c r" . browse-at-remote)))))
(ert-deftest use-package-test/:bind-8 ()
(match-expansion
(use-package foo
:ensure
:bind (:map foo-map
(("C-c r" . foo)
("C-c r" . bar))))
`(progn
(use-package-ensure-elpa 'foo '(t) 'nil)
(unless (fboundp 'foo)
(autoload #'foo "foo" nil t))
(unless (fboundp 'bar)
(autoload #'bar "foo" nil t))
(bind-keys :package foo :map foo-map
("C-c r" . foo)
("C-c r" . bar)))))
(ert-deftest use-package-test/:bind*-1 ()
(match-expansion
(use-package foo :bind* ("C-k" . key))
`(progn
(unless (fboundp 'key)
(autoload #'key "foo" nil t))
(bind-keys* :package foo ("C-k" . key)))))
(ert-deftest use-package-test/:bind-keymap-1 ()
(match-expansion
(use-package foo :bind-keymap ("C-k" . key))
`(bind-key "C-k"
#'(lambda nil
(interactive)
(use-package-autoload-keymap 'key 'foo nil)))))
(ert-deftest use-package-test/:bind-keymap*-1 ()
(match-expansion
(use-package foo :bind-keymap* ("C-k" . key))
`(bind-key* "C-k"
#'(lambda ()
(interactive)
(use-package-autoload-keymap 'key 'foo t)))))
(ert-deftest use-package-test/:interpreter-1 ()
(match-expansion
(use-package foo :interpreter "interp")
`(progn
(unless (fboundp 'foo)
(autoload #'foo "foo" nil t))
(add-to-list 'interpreter-mode-alist '("interp" . foo)))))
(ert-deftest use-package-test/:interpreter-2 ()
(match-expansion
(use-package foo :interpreter ("interp" . fun))
`(progn
(unless (fboundp 'fun)
(autoload #'fun "foo" nil t))
(add-to-list 'interpreter-mode-alist '("interp" . fun)))))
(ert-deftest use-package-test-normalize/:mode ()
(cl-flet ((norm (&rest args)
(apply #'use-package-normalize/:mode
'foopkg :mode args)))
(should (equal (norm '(".foo"))
'((".foo" . foopkg))))
(should (equal (norm '(".foo" ".bar"))
'((".foo" . foopkg) (".bar" . foopkg))))
(should (equal (norm '((".foo" ".bar")))
'((".foo" . foopkg) (".bar" . foopkg))))
(should (equal (norm '((".foo")))
'((".foo" . foopkg))))
(should (equal (norm '((".foo" . foo) (".bar" . bar)))
'((".foo" . foo) (".bar" . bar))))))
(ert-deftest use-package-test/:mode-1 ()
(match-expansion
(use-package foo :mode "interp")
`(progn
(unless (fboundp 'foo)
(autoload #'foo "foo" nil t))
(add-to-list 'auto-mode-alist '("interp" . foo)))))
(ert-deftest use-package-test/:mode-2 ()
(match-expansion
(use-package foo :mode ("interp" . fun))
`(progn
(unless (fboundp 'fun)
(autoload #'fun "foo" nil t))
(add-to-list 'auto-mode-alist '("interp" . fun)))))
(ert-deftest use-package-test/:magic-1 ()
(match-expansion
(use-package foo :magic "interp")
`(progn
(unless (fboundp 'foo)
(autoload #'foo "foo" nil t))
(add-to-list 'magic-mode-alist '("interp" . foo)))))
(ert-deftest use-package-test/:magic-2 ()
(match-expansion
(use-package foo :magic ("interp" . fun))
`(progn
(unless (fboundp 'fun)
(autoload #'fun "foo" nil t))
(add-to-list 'magic-mode-alist '("interp" . fun)))))
(ert-deftest use-package-test/:magic-fallback-1 ()
(match-expansion
(use-package foo :magic-fallback "interp")
`(progn
(unless (fboundp 'foo)
(autoload #'foo "foo" nil t))
(add-to-list 'magic-fallback-mode-alist '("interp" . foo)))))
(ert-deftest use-package-test/:magic-fallback-2 ()
(match-expansion
(use-package foo :magic-fallback ("interp" . fun))
`(progn
(unless (fboundp 'fun)
(autoload #'fun "foo" nil t))
(add-to-list 'magic-fallback-mode-alist '("interp" . fun)))))
(ert-deftest use-package-test/:commands-1 ()
(match-expansion
(use-package foo :commands bar)
`(unless (fboundp 'bar)
(autoload #'bar "foo" nil t))))
(ert-deftest use-package-test/:commands-2 ()
(match-expansion
(use-package foo :commands (bar quux))
`(progn
(unless (fboundp 'bar)
(autoload #'bar "foo" nil t))
(unless (fboundp 'quux)
(autoload #'quux "foo" nil t)))))
(ert-deftest use-package-test/:commands-3 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :commands (bar quux))
`(progn
(eval-and-compile
(eval-when-compile
(with-demoted-errors "Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t)))))
(unless (fboundp 'bar)
(autoload #'bar "foo" nil t))
(eval-when-compile
(declare-function bar "foo"))
(unless (fboundp 'quux)
(autoload #'quux "foo" nil t))
(eval-when-compile
(declare-function quux "foo"))))))
(ert-deftest use-package-test/:commands-4 ()
(match-expansion
(use-package foo :commands bar :init (bar))
`(progn
(unless
(fboundp 'bar)
(autoload #'bar "foo" nil t))
(bar))))
(ert-deftest use-package-test/:commands-5 ()
(match-expansion
(use-package gnus-harvest
:load-path "foo"
:commands gnus-harvest-install
:demand t
:config
(if (featurep 'message-x)
(gnus-harvest-install 'message-x)
(gnus-harvest-install)))
`(progn
(eval-and-compile
(add-to-list 'load-path ,(pred stringp)))
(require 'gnus-harvest nil nil)
(if (featurep 'message-x)
(gnus-harvest-install 'message-x)
(gnus-harvest-install))
t)))
(ert-deftest use-package-test/:commands-6 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package gnus-harvest
:load-path "foo"
:commands gnus-harvest-install
:demand t
:config
(if (featurep 'message-x)
(gnus-harvest-install 'message-x)
(gnus-harvest-install)))
`(progn
(eval-and-compile
(add-to-list 'load-path ,(pred stringp)))
(eval-and-compile
(eval-when-compile
(with-demoted-errors "Cannot load gnus-harvest: %S" nil
(unless (featurep 'gnus-harvest)
(load "gnus-harvest" nil t)))))
(eval-when-compile
(declare-function gnus-harvest-install "gnus-harvest"))
(require 'gnus-harvest nil nil)
(if
(featurep 'message-x)
(gnus-harvest-install 'message-x)
(gnus-harvest-install))
t))))
(ert-deftest use-package-test/:autoload-1 ()
(match-expansion
(use-package foo :autoload bar)
`(unless (fboundp 'bar)
(autoload #'bar "foo"))))
(ert-deftest use-package-test/:defines-1 ()
(match-expansion
(use-package foo :defines bar)
`(require 'foo nil nil)))
(ert-deftest use-package-test/:defines-2 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :defines bar)
`(progn
(eval-and-compile
(defvar bar)
(eval-when-compile
(with-demoted-errors
"Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t)))))
(require 'foo nil nil)))))
(ert-deftest use-package-test/:functions-1 ()
(match-expansion
(use-package foo :functions bar)
`(require 'foo nil nil)))
(ert-deftest use-package-test/:functions-2 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :functions bar)
`(progn
(eval-and-compile
(declare-function bar "foo")
(eval-when-compile
(with-demoted-errors
"Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t)))))
(require 'foo nil nil)))))
(ert-deftest use-package-test/:functions-3 ()
(match-expansion
(use-package foo :defer t :functions bar)
`nil))
(ert-deftest use-package-test/:functions-4 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :defer t :functions bar)
`(eval-and-compile
(declare-function bar "foo")
(eval-when-compile
(with-demoted-errors "Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t))))))))
(ert-deftest use-package-test/:functions-5 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :defer t :config (config) :functions bar)
`(progn
(eval-and-compile
(declare-function bar "foo")
(eval-when-compile
(with-demoted-errors
"Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t)))))
(eval-after-load 'foo
'(progn
(config)
t))))))
(ert-deftest use-package-test/:defer-1 ()
(match-expansion
(use-package foo)
`(require 'foo nil nil)))
(ert-deftest use-package-test/:defer-2 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo)
`(progn
(eval-and-compile
(eval-when-compile
(with-demoted-errors "Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t)))))
(require 'foo nil nil)))))
(ert-deftest use-package-test/:defer-3 ()
(match-expansion
(use-package foo :defer t)
`nil))
(ert-deftest use-package-test/:defer-4 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :defer t)
`(eval-and-compile
(eval-when-compile
(with-demoted-errors "Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t))))))))
(ert-deftest use-package-test-normalize/:hook ()
(cl-flet ((norm (&rest args)
(apply #'use-package-normalize/:hook
'foopkg :hook args)))
(should-error (norm nil))
(should (equal (norm '(bar))
'((bar . foopkg-mode))))
(should (equal (norm '((bar . foopkg)))
'((bar . foopkg))))
(should (equal (norm '((bar . baz)))
'((bar . baz))))
(should (equal (norm '(((bar baz) . quux)))
'(((bar baz) . quux))))
(should (equal (norm '(bar baz))
'(((bar baz) . foopkg-mode))))
(should (equal (norm '((bar baz) (quux bow)))
'(((bar baz) . foopkg-mode) ((quux bow) . foopkg-mode))))
(should (equal (norm '((bar . baz) (quux . bow)))
'((bar . baz) (quux . bow))))
(should (equal (norm '(((bar1 bar2) . baz) ((quux1 quux2) . bow)))
'(((bar1 bar2) . baz) ((quux1 quux2) . bow))))))
(ert-deftest use-package-test/:hook-1 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo
:bind (("C-a" . key))
:hook (hook . fun))
`(progn
(eval-and-compile
(eval-when-compile
(with-demoted-errors
"Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t)))))
(unless
(fboundp 'key)
(autoload #'key "foo" nil t))
(eval-when-compile
(declare-function key "foo"))
(unless
(fboundp 'fun)
(autoload #'fun "foo" nil t))
(eval-when-compile
(declare-function fun "foo"))
(add-hook 'hook-hook #'fun)
(bind-keys :package foo ("C-a" . key))))))
(ert-deftest use-package-test/:hook-2 ()
(match-expansion
(use-package foo
:hook (hook . fun))
`(progn
(unless (fboundp 'fun)
(autoload #'fun "foo" nil t))
(add-hook 'hook-hook #'fun))))
(ert-deftest use-package-test/:hook-3 ()
(let ((use-package-hook-name-suffix nil))
(match-expansion
(use-package foo
:hook (hook . fun))
`(progn
(unless (fboundp 'fun)
(autoload #'fun "foo" nil t))
(add-hook 'hook #'fun)))))
(ert-deftest use-package-test/:hook-4 ()
(let ((use-package-hook-name-suffix "-special"))
(match-expansion
(use-package foo
:hook (hook . fun))
`(progn
(unless (fboundp 'fun)
(autoload #'fun "foo" nil t))
(add-hook 'hook-special #'fun)))))
(ert-deftest use-package-test/:hook-5 ()
(match-expansion
(use-package erefactor
:load-path "foo"
:after elisp-mode
:load t
:hook (emacs-lisp-mode
. (lambda ()
(bind-key "\C-c\C-v" erefactor-map emacs-lisp-mode-map))))
`(progn
(eval-and-compile
(add-to-list 'load-path ,(pred stringp)))
(eval-after-load 'elisp-mode
'(progn
(require 'erefactor nil nil)
(add-hook
'emacs-lisp-mode-hook
#'(lambda nil
(bind-key "" erefactor-map emacs-lisp-mode-map))))))))
(ert-deftest use-package-test/:hook-6 ()
(match-expansion
(use-package erefactor
:load-path "foo"
:after elisp-mode
:hook (emacs-lisp-mode . function))
`(progn
(eval-and-compile
(add-to-list 'load-path ,(pred stringp)))
(eval-after-load 'elisp-mode
'(progn
(unless (fboundp 'function)
(autoload #'function "erefactor" nil t))
(add-hook 'emacs-lisp-mode-hook #'function))))))
(ert-deftest use-package-test/:hook-7 ()
(match-expansion
(use-package erefactor
:load-path "foo"
:after elisp-mode
:hook (emacs-lisp-mode . (lambda () (function))))
`(progn
(eval-and-compile
(add-to-list 'load-path ,(pred stringp)))
(eval-after-load 'elisp-mode
'(progn
(require 'erefactor nil nil)
(add-hook 'emacs-lisp-mode-hook #'(lambda nil (function))))))))
(ert-deftest use-package-test-normalize/:custom ()
(cl-flet ((norm (&rest args)
(apply #'use-package-normalize/:custom
'foopkg :custom args)))
(should-error (norm nil))
(should-error (norm '(bar)))
;; (should-error (norm '((foo bar baz quux))))
(should (equal (norm '(foo bar)) '((foo bar))))
;; (should-error (norm '(foo bar baz)))
;; (should (equal (norm '(foo bar "baz"))
;; '((foo bar baz))))
))
(ert-deftest use-package-test/:custom-1 ()
(match-expansion
(use-package foo :custom (foo bar))
`(progn
(let
((custom--inhibit-theme-enable nil))
(unless (memq 'use-package custom-known-themes)
(deftheme use-package)
(enable-theme 'use-package)
(setq custom-enabled-themes (remq 'use-package custom-enabled-themes)))
(custom-theme-set-variables 'use-package
'(foo bar nil nil "Customized with use-package foo")))
(require 'foo nil nil))))
(ert-deftest use-package-test/:custom-with-comment1 ()
(match-expansion
(use-package foo :custom (foo bar "commented"))
`(progn
(let
((custom--inhibit-theme-enable nil))
(unless (memq 'use-package custom-known-themes)
(deftheme use-package)
(enable-theme 'use-package)
(setq custom-enabled-themes (remq 'use-package custom-enabled-themes)))
(custom-theme-set-variables 'use-package
'(foo bar nil nil "commented")))
(require 'foo nil nil))))
(ert-deftest use-package-test/:custom-face-1 ()
(match-expansion
(use-package foo :custom-face (foo ((t (:background "#e4edfc")))))
`(progn
(apply #'face-spec-set (backquote (foo ((t (:background "#e4edfc"))))))
(require 'foo nil nil))))
(ert-deftest use-package-test/:custom-face-2 ()
(match-expansion
(use-package example
:custom-face
(example-1-face ((t (:foreground "LightPink"))))
(example-2-face ((t (:foreground "LightGreen")))))
`(progn
(apply #'face-spec-set
(backquote (example-1-face ((t (:foreground "LightPink"))))))
(apply #'face-spec-set
(backquote (example-2-face ((t (:foreground "LightGreen"))))))
(require 'example nil nil))))
(ert-deftest use-package-test/:custom-face-3 ()
(match-expansion
(use-package foo :custom-face (foo ((t (:background "#e4edfc"))) face-defspec-spec))
`(progn
(apply #'face-spec-set (backquote (foo ((t (:background "#e4edfc"))) face-defspec-spec)))
(require 'foo nil nil))))
(ert-deftest use-package-test/:init-1 ()
(match-expansion
(use-package foo :init (init))
`(progn
(init)
(require 'foo nil nil))))
(ert-deftest use-package-test/:init-2 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :init (init))
`(progn
(eval-and-compile
(eval-when-compile
(with-demoted-errors "Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t)))))
(init)
(require 'foo nil nil)))))
(ert-deftest use-package-test/:catch-1 ()
(match-expansion
(use-package foo :catch t)
`(progn
(defvar ,_
#'(lambda (keyword err)
(let ((msg (format "%s/%s: %s" 'foo keyword
(error-message-string err))))
(display-warning 'use-package msg :error))))
(condition-case-unless-debug err
(require 'foo nil nil)
(error
(funcall ,_ :catch err))))))
(ert-deftest use-package-test/:catch-2 ()
(match-expansion
(use-package foo :catch nil)
`(require 'foo nil nil)))
(ert-deftest use-package-test/:catch-3 ()
(match-expansion
(use-package foo :catch (lambda (keyword error)))
`(progn
(defvar ,_ (lambda (keyword error)))
(condition-case-unless-debug err
(require 'foo nil nil)
(error
(funcall ,_ :catch err))))))
(ert-deftest use-package-test/:after-1 ()
(match-expansion
(use-package foo :after bar)
`(eval-after-load 'bar
'(require 'foo nil nil))))
(ert-deftest use-package-test/:after-2 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :after bar)
`(progn
(eval-and-compile
(eval-when-compile
(with-demoted-errors "Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t)))))
(eval-after-load 'bar
'(require 'foo nil nil))))))
(ert-deftest use-package-test/:after-3 ()
(match-expansion
(use-package foo :after (bar quux))
`(eval-after-load 'quux
'(eval-after-load 'bar
'(require 'foo nil nil)))))
(ert-deftest use-package-test/:after-4 ()
(match-expansion
(use-package foo :after (:all bar quux))
`(eval-after-load 'quux
'(eval-after-load 'bar
'(require 'foo nil nil)))))
(ert-deftest use-package-test/:after-5 ()
(match-expansion
(use-package foo :after (:any bar quux))
`(progn
(defvar ,_ nil)
(defvar ,_ nil)
(defvar ,_
#'(lambda nil
(if ,_ ,_
(setq ,_ t ,_
(require 'foo nil nil)))))
(eval-after-load 'bar
'(funcall ,_))
(eval-after-load 'quux
'(funcall ,_)))))
(ert-deftest use-package-test/:after-6 ()
(match-expansion
(use-package foo :after (:all (:any bar quux) bow))
`(progn
(defvar ,_ nil)
(defvar ,_ nil)
(defvar ,_
#'(lambda nil
(if ,_ ,_
(setq ,_ t ,_
(require 'foo nil nil)))))
(eval-after-load 'bow
'(progn
(eval-after-load 'bar
'(funcall ,_))
(eval-after-load 'quux
'(funcall ,_)))))))
(ert-deftest use-package-test/:after-7 ()
(match-expansion
(use-package foo :after (:any (:all bar quux) bow))
`(progn
(defvar ,_ nil)
(defvar ,_ nil)
(defvar ,_
#'(lambda nil
(if ,_ ,_
(setq ,_ t ,_
(require 'foo nil nil)))))
(eval-after-load 'quux
'(eval-after-load 'bar
'(funcall ,_)))
(eval-after-load 'bow
'(funcall ,_)))))
(ert-deftest use-package-test/:after-8 ()
(match-expansion
(use-package foo :after (:all (:any bar quux) (:any bow baz)))
`(progn
(defvar ,_ nil)
(defvar ,_ nil)
(defvar ,_
#'(lambda nil
(if ,_ ,_
(setq ,_ t ,_
(require 'foo nil nil)))))
(eval-after-load 'bow
'(progn
(eval-after-load 'bar
'(funcall ,_))
(eval-after-load 'quux
'(funcall ,_))))
(eval-after-load 'baz
'(progn
(eval-after-load 'bar
'(funcall ,_))
(eval-after-load 'quux
'(funcall ,_)))))))
(ert-deftest use-package-test/:after-9 ()
(match-expansion
(use-package foo :after (:any (:all bar quux) (:all bow baz)))
`(progn
(defvar ,_ nil)
(defvar ,_ nil)
(defvar ,_
#'(lambda nil
(if ,_ ,_
(setq ,_ t ,_
(require 'foo nil nil)))))
(eval-after-load 'quux
'(eval-after-load 'bar
'(funcall ,_)))
(eval-after-load 'baz
'(eval-after-load 'bow
'(funcall ,_))))))
(ert-deftest use-package-test/:after-10 ()
(match-expansion
(use-package foo :after (:any (:all bar quux) (:any bow baz)))
`(progn
(defvar ,_ nil)
(defvar ,_ nil)
(defvar ,_
#'(lambda nil
(if ,_ ,_
(setq ,_ t ,_
(require 'foo nil nil)))))
(eval-after-load 'quux
'(eval-after-load 'bar
'(funcall ,_)))
(eval-after-load 'bow
'(funcall ,_))
(eval-after-load 'baz
'(funcall ,_)))))
(ert-deftest use-package-test/:demand-1 ()
(match-expansion
(use-package foo :demand t)
`(require 'foo nil nil)))
(ert-deftest use-package-test/:demand-2 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :demand t)
`(progn
(eval-and-compile
(eval-when-compile
(with-demoted-errors "Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t)))))
(require 'foo nil nil)))))
(ert-deftest use-package-test/:demand-3 ()
(match-expansion
(use-package foo :demand t :config (config))
`(progn
(require 'foo nil nil)
(config)
t)))
(ert-deftest use-package-test/:demand-4 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :demand t :config (config))
`(progn
(eval-and-compile
(eval-when-compile
(with-demoted-errors "Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t)))))
(require 'foo nil nil)
(config)
t))))
(ert-deftest use-package-test/:demand-5 ()
;; #529 - :demand should not override an explicit use of :after
(match-expansion
(use-package foo :demand t :after bar)
`(eval-after-load 'bar
'(require 'foo nil nil))))
(ert-deftest use-package-test/:demand-6 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :demand t :after bar)
`(progn
(eval-and-compile
(eval-when-compile
(with-demoted-errors "Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t)))))
(eval-after-load 'bar
'(require 'foo nil nil))))))
(ert-deftest use-package-test/:demand-7 ()
(match-expansion
(use-package counsel
:load-path "foo"
:after ivy
:demand t
:diminish
:bind (("C-*" . counsel-org-agenda-headlines)
("M-x" . counsel-M-x))
:commands (counsel-minibuffer-history
counsel-find-library
counsel-unicode-char)
:preface (preface-code)
:init
;; This is actually wrong, but it's just part of the example.
(define-key minibuffer-local-map (kbd "M-r")
'counsel-minibuffer-history))
`(progn
(eval-and-compile
(add-to-list 'load-path ,(pred stringp)))
(eval-and-compile
(preface-code))
(eval-after-load 'ivy
'(progn
(define-key minibuffer-local-map (kbd "M-r")
'counsel-minibuffer-history)
(require 'counsel nil nil)
(if (fboundp 'diminish)
(diminish 'counsel-mode))
(bind-keys :package counsel
("C-*" . counsel-org-agenda-headlines)
("M-x" . counsel-M-x)))))))
(ert-deftest use-package-test/:config-1 ()
(match-expansion
(use-package foo :config (config))
`(progn
(require 'foo nil nil)
(config)
t)))
(ert-deftest use-package-test/:config-2 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :config (config))
`(progn
(eval-and-compile
(eval-when-compile
(with-demoted-errors "Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t)))))
(require 'foo nil nil)
(config)
t))))
(ert-deftest use-package-test/:config-3 ()
(match-expansion
(use-package foo :defer t :config (config))
`(eval-after-load 'foo
'(progn
(config)
t))))
(ert-deftest use-package-test/:config-4 ()
(let ((byte-compile-current-file t))
(match-expansion
(use-package foo :defer t :config (config))
`(progn
(eval-and-compile
(eval-when-compile
(with-demoted-errors "Cannot load foo: %S" nil
(unless (featurep 'foo)
(load "foo" nil t)))))
(eval-after-load 'foo
'(progn
(config)
t))))))
(ert-deftest use-package-test-normalize/:diminish ()
(should (equal (use-package-normalize-diminish 'foopkg :diminish nil)
'(foopkg-mode)))
(should (equal (use-package-normalize-diminish 'foopkg :diminish 'bar)
'(bar)))
(should (equal (use-package-normalize-diminish 'foopkg :diminish "bar")
'((foopkg-mode . "bar"))))
(should (equal (use-package-normalize-diminish 'foopkg :diminish 'foo-mode)
'(foo-mode)))
(should (equal (use-package-normalize-diminish 'foopkg :diminish '(foo . "bar"))
'((foo . "bar")))))
(ert-deftest use-package-test/:diminish-1 ()
(match-expansion
(use-package foo :diminish nil)
`(progn
(require 'foo nil nil)
(if (fboundp 'diminish)
(diminish 'foo-mode)))))
(ert-deftest use-package-test/:diminish-2 ()
(match-expansion
(use-package foo :diminish bar)
`(progn
(require 'foo nil nil)
(if (fboundp 'diminish)
(diminish 'bar)))))
(ert-deftest use-package-test/:diminish-3 ()
(match-expansion
(use-package foo :diminish "bar")
`(progn
(require 'foo nil nil)
(if (fboundp 'diminish)
(diminish 'foo-mode "bar")))))
(ert-deftest use-package-test/:diminish-4 ()
(match-expansion
(use-package foo :diminish (foo . "bar"))
`(progn
(require 'foo nil nil)
(if (fboundp 'diminish)
(diminish 'foo "bar")))))
(ert-deftest use-package-test-normalize/:delight ()
(should (equal `((foo-mode nil foo))
(use-package-normalize/:delight 'foo :delight nil)))
(should (equal `((foo-mode nil foo-mode))
(use-package-normalize/:delight 'foo-mode :delight nil)))
(should (equal `((bar-mode nil foo))
(use-package-normalize/:delight 'foo :delight '(bar-mode))))
(should (equal `((bar-mode nil :major))
(use-package-normalize/:delight 'foo :delight '((bar-mode nil :major)))))
(should (equal `((foo-mode "abc" foo))
(use-package-normalize/:delight 'foo :delight '("abc"))))
(should (equal `((foo-mode (:eval 1) foo))
(use-package-normalize/:delight 'foo :delight '('(:eval 1)))))
(should (equal (use-package-normalize/:delight 'foo :delight '((a-mode) (b-mode " b")))
`((a-mode nil foo) (b-mode " b" foo))))
(should-error (use-package-normalize/:delight 'foo :delight '((:eval 1)))))
(ert-deftest use-package-test/:delight-1 ()
(match-expansion
(use-package foo :delight)
`(progn
(require 'foo nil nil)
(if (fboundp 'delight)
(delight '((foo-mode nil foo)))))))
(ert-deftest use-package-test/:delight-2 ()
(should-error
(match-expansion
(use-package foo :delight nil)
`(progn
(require 'foo nil nil)
(if (fboundp 'diminish)
(diminish 'foo-mode))))))
(ert-deftest use-package-test/:delight-3 ()
(match-expansion
(use-package foo :delight bar)
`(progn
(require 'foo nil nil)
(if (fboundp 'delight)
(delight '((bar nil foo)))))))
(ert-deftest use-package-test/:delight-4 ()
(match-expansion
(use-package foo :delight "bar")
`(progn
(require 'foo nil nil)
(if (fboundp 'delight)
(delight '((foo-mode "bar" foo)))))))
(ert-deftest use-package-test/:delight-5 ()
(should-error
(match-expansion
(use-package foo :delight (foo . "bar"))
`(progn
(require 'foo nil nil)
(if (fboundp 'diminish)
(diminish 'foo "bar"))))))
(ert-deftest use-package-test/:delight-6 ()
(match-expansion
(use-package foo :delight (foo "bar"))
`(progn
(require 'foo nil nil)
(if (fboundp 'delight)
(delight '((foo "bar" foo)))))))
(ert-deftest use-package-test/334-1 ()
(let (foo1-map foo2-map
bar1-func1
bar1-func2
bar2-func1
bar2-func2
bar3-func1
bar3-func2
bar4-func1
bar4-func2)
(match-expansion
(bind-keys :map foo1-map
("Y" . foo1)
:prefix "y"
:prefix-map bar1-prefix-map
("y" . bar1-func1)
("f" . bar1-func2)
:prefix "y"
:prefix-map bar2-prefix-map
("y" . bar2-func1)
("f" . bar2-func2)
:map foo2-map
("Y" . foo2)
:prefix "y"
:prefix-map bar3-prefix-map
("y" . bar3-func1)
("f" . bar3-func2)
:prefix "y"
:prefix-map bar4-prefix-map
("y" . bar4-func1)
("f" . bar4-func2))
`(progn
(bind-key "Y" #'foo1 foo1-map nil)
(defvar bar1-prefix-map)
(define-prefix-command 'bar1-prefix-map)
(bind-key "y" 'bar1-prefix-map foo1-map nil)
(bind-key "y" #'bar1-func1 bar1-prefix-map nil)
(bind-key "f" #'bar1-func2 bar1-prefix-map nil)
(defvar bar2-prefix-map)
(define-prefix-command 'bar2-prefix-map)
(bind-key "y" 'bar2-prefix-map foo1-map nil)
(bind-key "y" #'bar2-func1 bar2-prefix-map nil)
(bind-key "f" #'bar2-func2 bar2-prefix-map nil)
(bind-key "Y" #'foo2 foo2-map nil)
(defvar bar3-prefix-map)
(define-prefix-command 'bar3-prefix-map)
(bind-key "y" 'bar3-prefix-map foo2-map nil)
(bind-key "y" #'bar3-func1 bar3-prefix-map nil)
(bind-key "f" #'bar3-func2 bar3-prefix-map nil)
(defvar bar4-prefix-map)
(define-prefix-command 'bar4-prefix-map)
(bind-key "y" 'bar4-prefix-map foo2-map nil)
(bind-key "y" #'bar4-func1 bar4-prefix-map nil)
(bind-key "f" #'bar4-func2 bar4-prefix-map nil)))))
(ert-deftest use-package-test/334-2 ()
(let (w3m-lnum-mode-map
w3m-print-current-url
w3m-lnum-print-this-url
w3m-print-this-url)
(match-expansion
(bind-keys :map w3m-lnum-mode-map
:prefix "y"
:prefix-map w3m-y-prefix-map
("y" . w3m-print-current-url)
("f" . w3m-lnum-print-this-url)
("t" . w3m-print-this-url))
`(progn
(defvar w3m-y-prefix-map)
(define-prefix-command 'w3m-y-prefix-map)
(bind-key "y" 'w3m-y-prefix-map w3m-lnum-mode-map nil)
(bind-key "y" #'w3m-print-current-url w3m-y-prefix-map nil)
(bind-key "f" #'w3m-lnum-print-this-url w3m-y-prefix-map nil)
(bind-key "t" #'w3m-print-this-url w3m-y-prefix-map nil)))))
(ert-deftest use-package-test/482-1 ()
(match-expansion
(use-package simple
:bind-keymap ("C-t " . my/transpose-map)
:bind (:map my/transpose-map
("w" . transpose-words)))
`(progn
(unless (fboundp 'transpose-words)
(autoload #'transpose-words "simple" nil t))
(bind-key "C-t "
#'(lambda nil
(interactive)
(use-package-autoload-keymap 'my/transpose-map 'simple nil)))
(bind-keys :package simple :map my/transpose-map
("w" . transpose-words)))))
(ert-deftest use-package-test/482-2 ()
(match-expansion
(use-package simple
:bind (:prefix-map my/transpose-map
:prefix "C-t"
("w" . transpose-words)))
`(progn
(unless (fboundp 'transpose-words)
(autoload #'transpose-words "simple" nil t))
(bind-keys :package simple
:prefix-map my/transpose-map
:prefix "C-t"
("w" . transpose-words)))))
(ert-deftest use-package-test/482-3 ()
(match-expansion
(bind-keys :package simple
:prefix-map my/transpose-map
:prefix "C-t"
("w" . transpose-words))
`(progn
(defvar my/transpose-map)
(define-prefix-command 'my/transpose-map)
(bind-key "C-t" 'my/transpose-map nil nil)
(bind-key "w" #'transpose-words my/transpose-map nil))))
(ert-deftest use-package-test/538 ()
(match-expansion
(use-package mu4e
:commands (mu4e)
:bind (("<f9>" . mu4e))
:init
:config
(config))
`(progn
(unless (fboundp 'mu4e)
(autoload #'mu4e "mu4e" nil t))
(eval-after-load 'mu4e
'(progn (config) t))
(bind-keys :package mu4e ("<f9>" . mu4e)))))
(ert-deftest use-package-test/543 ()
(match-expansion
(use-package hydra
:ensure)
`(progn
(use-package-ensure-elpa 'hydra '(t) 'nil)
(require 'hydra nil nil))))
(ert-deftest use-package-test/545 ()
(match-expansion
(use-package spacemacs-theme
:ensure t
:init ; or :config
(load-theme 'spacemacs-dark t)
)
`(progn
(use-package-ensure-elpa 'spacemacs-theme '(t) 'nil)
(load-theme 'spacemacs-dark t)
(require 'spacemacs-theme nil nil))
))
(ert-deftest use-package-test/550 ()
(match-expansion
(use-package company-try-hard
:ensure t
:bind
("C-c M-/" . company-try-hard)
(:map company-active-map
("C-c M-/" . company-try-hard)))
`(progn
(use-package-ensure-elpa 'company-try-hard
'(t)
'nil)
(unless
(fboundp 'company-try-hard)
(autoload #'company-try-hard "company-try-hard" nil t))
(bind-keys :package company-try-hard
("C-c M-/" . company-try-hard)
:map company-active-map
("C-c M-/" . company-try-hard)))))
(ert-deftest use-package-test/558 ()
(match-expansion
(bind-keys* :package org-ref
("C-c C-r" . org-ref-helm-insert-cite-link))
`(bind-key "C-c C-r" #'org-ref-helm-insert-cite-link override-global-map nil)))
(ert-deftest use-package-test/560 ()
(cl-letf (((symbol-function #'executable-find) #'ignore))
(let (notmuch-command)
(match-expansion
(use-package notmuch
:preface (setq-default notmuch-command (executable-find "notmuch"))
:if notmuch-command
:requires foo
:load-path "foo"
:defines var)
`(progn
(eval-and-compile
(add-to-list 'load-path ,(pred stringp)))
(when (featurep 'foo)
(eval-and-compile
(setq-default notmuch-command
(executable-find "notmuch")))
(when (symbol-value 'notmuch-command)
(require 'notmuch nil nil))))))))
(ert-deftest use-package-test/572-1 ()
(let ((use-package-always-defer t))
(match-expansion
(use-package auth-password-store
:after auth-source
:init
(setq auth-sources '(password-store)))
`(eval-after-load 'auth-source
'(setq auth-sources '(password-store))))))
(ert-deftest use-package-test/572-2 ()
(let ((use-package-always-defer t))
(match-expansion
(use-package ivy-hydra :after ivy)
`nil)))
(ert-deftest use-package-test/572-3 ()
(let ((use-package-always-defer t)
(use-package-defaults
(let ((defaults (copy-alist use-package-defaults)))
(setcdr (assq :defer defaults)
'(use-package-always-defer
(lambda (name args)
(and use-package-always-defer
(not (plist-member args :after))
(not (plist-member args :defer))
(not (plist-member args :demand))))))
defaults)))
(match-expansion
(use-package ivy-hydra :after ivy)
`(eval-after-load 'ivy
'(require 'ivy-hydra nil nil)))))
(ert-deftest use-package-test/575-1 ()
(match-expansion
(use-package helm
:defer t
:after (:any ido dired)
:config
(message "test. helm start"))
`(progn
(defvar ,_ nil)
(defvar ,_ nil)
(defvar ,_
#'(lambda nil
(if ,_ ,_
(setq ,_ t ,_
(eval-after-load 'helm
'(progn
(message "test. helm start")
t))))))
(eval-after-load 'ido
'(funcall ,_))
(eval-after-load 'dired
'(funcall ,_)))))
(ert-deftest use-package-test/575-2 ()
(match-expansion
(use-package helm
:defer t
:bind ("C-c d" . helm-mini)
:config
(message "test. helm start"))
`(progn
(unless (fboundp 'helm-mini)
(autoload #'helm-mini "helm" nil t))
(eval-after-load 'helm
'(progn
(message "test. helm start")
t))
(bind-keys :package helm ("C-c d" . helm-mini)))))
(ert-deftest use-package-test/585 ()
(match-expansion
(use-package bug
:bind (:map bug-map ("C-a" . alpha))
:bind (("C-b" . beta)))
`(progn
(unless (fboundp 'alpha)
(autoload #'alpha "bug" nil t))
(unless (fboundp 'beta)
(autoload #'beta "bug" nil t))
(bind-keys :package bug :map bug-map
("C-a" . alpha))
(bind-keys :package bug
("C-b" . beta)))))
(ert-deftest use-package-test/589 ()
(let ((use-package-verbose t)
(use-package-expand-minimally t)
debug-on-error
warnings)
(cl-letf (((symbol-function #'display-warning)
(lambda (_ msg _) (push msg warnings))))
(progn
(macroexpand-1
'(use-package ediff :defer t (setq my-var t)))
(should (= (and (> (length warnings) 0)
(string-match ":defer wants exactly one argument"
(car warnings))) 44))))))
(ert-deftest use-package-test/591 ()
(let ((use-package-defaults
(cons '(:if (lambda (name _) `(locate-library ,name)) t)
use-package-defaults)))
(match-expansion
(use-package nonexistent
:hook lisp-mode)
`(when (locate-library nonexistent)
(unless (fboundp 'nonexistent-mode)
(autoload #'nonexistent-mode "nonexistent" nil t))
(add-hook 'lisp-mode-hook #'nonexistent-mode)))))
(ert-deftest bind-key/:prefix-map ()
(match-expansion
(bind-keys :prefix "<f1>"
:prefix-map my/map)
`(progn
(defvar my/map)
(define-prefix-command 'my/map)
(bind-key "<f1>" 'my/map nil nil))))
(ert-deftest bind-key/845 ()
(defvar test-map (make-keymap))
(bind-key "<f1>" 'ignore 'test-map)
(should (eq (lookup-key test-map (kbd "<f1>")) 'ignore))
(let ((binding (cl-find "<f1>" personal-keybindings :test 'string= :key 'caar)))
(message "test-map %s" test-map)
(message "binding %s" binding)
(should (eq (cdar binding) 'test-map))
(should (eq (nth 1 binding) 'ignore))
(should (eq (nth 2 binding) nil))))
(ert-deftest use-package-test/:vc-1 ()
(match-expansion
(use-package foo :vc (:url "bar"))
'(progn (use-package-vc-install '(foo (:url "bar") :last-release) nil)
(require 'foo nil nil))))
(ert-deftest use-package-test/:vc-2 ()
(match-expansion
(use-package foo
:vc (baz . (:url "baz" :vc-backend "Git"
:main-file qux.el :rev "rev-string")))
'(progn (use-package-vc-install '(baz
(:url "baz" :vc-backend Git :main-file "qux.el")
"rev-string")
nil)
(require 'foo nil nil))))
(ert-deftest use-package-test/:vc-3 ()
(match-expansion
(use-package foo :vc (bar . "baz"))
'(progn (use-package-vc-install '(bar "baz") nil)
(require 'foo nil nil))))
(ert-deftest use-package-test/:vc-4 ()
(match-expansion
(use-package foo :vc (bar . (:url "baz" :rev :newest)))
'(progn (use-package-vc-install '(bar (:url "baz") nil) nil)
(require 'foo nil nil))))
(ert-deftest use-package-test/:vc-5 ()
(let ((load-path? '(pred (apply-partially
#'string=
(expand-file-name "bar" user-emacs-directory)))))
(match-expansion
(use-package foo :vc other-name :load-path "bar")
`(progn (eval-and-compile
(add-to-list 'load-path ,load-path?))
(use-package-vc-install '(other-name) ,load-path?)
(require 'foo nil nil)))))
(ert-deftest use-package-test-handler/:vc-6 ()
(let ((byte-compile-current-file "use-package-core.el")
tried-to-install)
(cl-letf (((symbol-function #'use-package-vc-install)
(lambda (arg &optional local-path)
(setq tried-to-install arg))))
(should (equal
(use-package-handler/:vc 'foo nil 'some-pkg '(:init (foo)) nil)
'(foo)))
(should (eq tried-to-install 'some-pkg)))))
(ert-deftest use-package-test-normalize/:vc ()
(should (equal '(foo "version-string")
(use-package-normalize/:vc 'foo :vc '("version-string"))))
(should (equal '(bar "version-string")
(use-package-normalize/:vc 'foo :vc '((bar . "version-string")))))
(should (equal '(foo (:url "bar") "baz")
(use-package-normalize/:vc 'foo :vc '((:url "bar" :rev "baz")))))
(should (equal '(foo)
(use-package-normalize/:vc 'foo :vc '(t))))
(should (equal '(foo)
(use-package-normalize/:vc 'foo :vc nil)))
(should (equal '(bar)
(use-package-normalize/:vc 'foo :vc '(bar))))
(should (equal
'(foo (:ignored-files ("a" "b" "c")) :last-release)
(use-package-normalize/:vc 'foo :vc '((:ignored-files "a" "b" "c")))))
(should (equal
(use-package-normalize/:vc 'foo :vc '((:ignored-files "a")))
(use-package-normalize/:vc 'foo :vc '((:ignored-files ("a"))))))
(should (equal (use-package-normalize/:vc 'foo :vc '((:ignored-files "a" "b" "c")))
(use-package-normalize/:vc 'foo :vc '((:ignored-files ("a" "b" "c")))))))
;; Local Variables:
;; no-byte-compile: t
;; no-update-autoloads: t
;; End:
;;; use-package-tests.el ends here