summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoão Távora <joaotavora@gmail.com>2021-09-20 11:55:41 +0100
committerJoão Távora <joaotavora@gmail.com>2021-09-20 11:57:07 +0100
commitbf3276240e6990bd904813bafe07a8a69a5916af (patch)
tree6a2771a8c78b668b8d1631db25251349e8c31ccf
parentb0c34e3c207be0450fddd70620c600cd546751f2 (diff)
downloademacs-scratch/electric-pair-cleanup-and-49518-bugfix.tar.gz
Improve Python triple-quote pairing tests for electric-pair-modescratch/electric-pair-cleanup-and-49518-bugfix
These tests were once passing incorrectly, i.e. the auto-pairing functionality they purport to guard wasn't really working. Added a new test in hopes that regressions can be spotted in the future for the now-working functionality of Python triple-quote auto-pairing via electric-pair-mode. bug#49518 * test/lisp/progmodes/python-tests.el (python-triple-double-quote-pairing): Rename from python-triple-quote-pairing. (python-triple-single-quote-pairing): New test.
-rw-r--r--test/lisp/progmodes/python-tests.el29
1 files changed, 28 insertions, 1 deletions
diff --git a/test/lisp/progmodes/python-tests.el b/test/lisp/progmodes/python-tests.el
index a172f0f8e9c..6ab9c62746e 100644
--- a/test/lisp/progmodes/python-tests.el
+++ b/test/lisp/progmodes/python-tests.el
@@ -5282,7 +5282,7 @@ urlpatterns = patterns('',
(should (= (current-indentation) 23))))
(or eim (electric-indent-mode -1)))))
-(ert-deftest python-triple-quote-pairing ()
+(ert-deftest python-triple-double-quote-pairing ()
(let ((epm electric-pair-mode))
(unwind-protect
(progn
@@ -5309,6 +5309,33 @@ urlpatterns = patterns('',
"\"\n\"\"\"\n"))))
(or epm (electric-pair-mode -1)))))
+(ert-deftest python-triple-single-quote-pairing ()
+ (let ((epm electric-pair-mode))
+ (unwind-protect
+ (progn
+ (python-tests-with-temp-buffer
+ "''\n"
+ (or epm (electric-pair-mode 1))
+ (goto-char (1- (point-max)))
+ (python-tests-self-insert ?')
+ (should (string= (buffer-string)
+ "''''''\n"))
+ (should (= (point) 4)))
+ (python-tests-with-temp-buffer
+ "\n"
+ (python-tests-self-insert (list ?' ?' ?'))
+ (should (string= (buffer-string)
+ "''''''\n"))
+ (should (= (point) 4)))
+ (python-tests-with-temp-buffer
+ "'\n''\n"
+ (goto-char (1- (point-max)))
+ (python-tests-self-insert ?')
+ (should (= (point) (1- (point-max))))
+ (should (string= (buffer-string)
+ "'\n'''\n"))))
+ (or epm (electric-pair-mode -1)))))
+
;;; Hideshow support