diff options
author | Stefan Monnier <monnier@iro.umontreal.ca> | 2022-09-25 16:15:16 -0400 |
---|---|---|
committer | Stefan Monnier <monnier@iro.umontreal.ca> | 2022-09-25 16:15:16 -0400 |
commit | 650c20f1ca4e07591a727e1cfcc74b3363d15985 (patch) | |
tree | 85d11f6437cde22f410c25e0e5f71a3131ebd07d /test/lisp/net/rcirc-tests.el | |
parent | 8869332684c2302b5ba1ead4568bbc7ba1c0183e (diff) | |
parent | 4b85ae6a24380fb67a3315eaec9233f17a872473 (diff) | |
download | emacs-650c20f1ca4e07591a727e1cfcc74b3363d15985.tar.gz emacs-650c20f1ca4e07591a727e1cfcc74b3363d15985.tar.bz2 emacs-650c20f1ca4e07591a727e1cfcc74b3363d15985.zip |
Merge 'master' into noverlay
Diffstat (limited to 'test/lisp/net/rcirc-tests.el')
-rw-r--r-- | test/lisp/net/rcirc-tests.el | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/test/lisp/net/rcirc-tests.el b/test/lisp/net/rcirc-tests.el new file mode 100644 index 00000000000..0ba4f2b86e5 --- /dev/null +++ b/test/lisp/net/rcirc-tests.el @@ -0,0 +1,66 @@ +;;; rcirc-tests.el --- Tests for rcirc -*- lexical-binding:t -*- + +;; Copyright (C) 2019-2022 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 '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 |