Mercurial > hg > xemacs-beta
view tests/gtk/event-stream-tests.el @ 4709:db7068430402
Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
are missing. This is done with Bill Perry's stated permission, in private
email to me.
author | Jerry James <james@xemacs.org> |
---|---|
date | Mon, 05 Oct 2009 11:08:59 -0600 |
parents | cef5f57bb9e2 |
children | ba07c880114a |
line wrap: on
line source
;; This file is part of XEmacs. ;; ;; XEmacs 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 2, or (at your option) any ;; later version. ;; ;; XEmacs 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 XEmacs; see the file COPYING. If not, write to ;; the Free Software Foundation, Inc., 51 Franklin Street - Fifth Floor, ;; Boston, MA 02111-1301, USA. */ ;also do this: make two frames, one viewing "*scratch*", the other "foo". ;in *scratch*, type (sit-for 20)^J ;wait a couple of seconds, move cursor to foo, type "a" ;a should be inserted in foo. Cursor highlighting should not change in ;the meantime. ;do it with sleep-for. move cursor into foo, then back into *scratch* ;before typing. ;repeat also with (accept-process-output nil 20) ;make sure ^G aborts sit-for, sleep-for and accept-process-output: (defun tst () (list (condition-case c (sleep-for 20) (quit c)) (read-char))) (tst)^Ja^G ==> ((quit) 97) with no signal (tst)^J^Ga ==> ((quit) 97) with no signal (tst)^Jabc^G ==> ((quit) 97) with no signal, and "bc" inserted in buffer ; with sit-for only do the 2nd test. ; Do all 3 tests with (accept-proccess-output nil 20) /* Additional test cases for accept-process-output, sleep-for, sit-for. Be sure you do all of the above checking for C-g and focus, too! ; Make sure that timer handlers are run during, not after sit-for: (defun timer-check () (add-timeout 2 #'(lambda (ignore) (message "timer ran")) nil) (sit-for 5) (message "after sit-for")) ; The first message should appear after 2 seconds, and the final message ; 3 seconds after that. ; repeat above test with (sleep-for 5) and (accept-process-output nil 5) ; Make sure that process filters are run during, not after sit-for. (defun fubar () (message "sit-for = %s" (sit-for 30))) (add-hook 'post-command-hook 'fubar) ; Now type M-x shell RET ; wait for the shell prompt then send: ls RET ; the output of ls should fill immediately, and not wait 30 seconds. ; repeat above test with (sleep-for 30) and (accept-process-output nil 30) ; Make sure that recursive invocations return immediately: (defmacro test-diff-time (start end) `(+ (* (- (car ,end) (car ,start)) 65536.0) (- (cadr ,end) (cadr ,start)) (/ (- (caddr ,end) (caddr ,start)) 1000000.0))) (defun testee (ignore) (sit-for 10)) (defun test-them () (let ((start (current-time)) end) (add-timeout 2 'testee nil) (sit-for 5) (add-timeout 2 'testee nil) (sleep-for 5) (add-timeout 2 'testee nil) (accept-process-output nil 5) (setq end (current-time)) (test-diff-time start end))) (test-them) should sit for 15 seconds.