;;; rcirc-tests.el --- Tests for rcirc -*- lexical-binding:t -*- ;; Copyright (C) 2019-2021 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 . ;;; Code: (require 'ert) (require 'rcirc) (require 'cl-lib) (defun rcirc-tests--parse-server-response (cmd text) (cl-letf* ((received-args nil) ((symbol-function (intern (concat "rcirc-handler-" cmd))) (lambda (_process sender args text) (setq received-args (list sender cmd args text)))) (rcirc-receive-message-functions nil) (rcirc-trap-errors-flag nil)) (rcirc-process-server-response nil text) received-args)) (defmacro rcirc-tests--server-response-parse-should-be (text expected-sender expected-cmd expected-args) (declare (debug t)) (macroexp-let2* nil ((cmd expected-cmd)) `(should (equal (rcirc-tests--parse-server-response ,cmd ,text) (list ,expected-sender ,cmd ,expected-args ,text))))) (ert-deftest rcirc-process-server-response () (rcirc-tests--server-response-parse-should-be "MODE #cchan +kl a:b :999" nil "MODE" '("#cchan" "+kl" "a:b" "999")) (rcirc-tests--server-response-parse-should-be "MODE #cchan +kl a:b 999" nil "MODE" '("#cchan" "+kl" "a:b" "999")) (rcirc-tests--server-response-parse-should-be "MODE #cchan +kl :a:b" nil "MODE" '("#cchan" "+kl" "a:b"))) (ert-deftest rcirc-rename-nicks () (should (equal (rcirc--make-new-nick "foo" 16) "foo`")) (should (equal (rcirc--make-new-nick "123456789012345" 16) "123456789012345`")) (should (equal (rcirc--make-new-nick "1234567890123456" 16) "123456789012345`")) (should (equal (rcirc--make-new-nick "123456789012345`" 16) "12345678901234``")) (should (equal (rcirc--make-new-nick "123456789012````" 16) "12345678901`````"))) ;;; rcirc-tests.el ends here