gui/collects/tests/framework/exit.ss
Robby Findler f055d3d3ad ...
original commit: ef63af74dbac8a38dc51d9518b5b2b5536a29735
2000-06-26 02:33:21 +00:00

102 lines
3.4 KiB
Scheme

(test 'exit/no-prompt
(lambda (x)
(and (eq? x 'passed)
(not (mred-running?))))
(lambda ()
(with-handlers ([eof-result? (lambda (x) 'passed)])
(send-sexp-to-mred '(preferences:set 'framework:verify-exit #f))
(send-sexp-to-mred '(begin (exit:exit) (sleep/yield 1)))
'failed)))
(test 'exit/prompt
(lambda (x) (and (eq? x 'passed)
(not (mred-running?))))
(lambda ()
(with-handlers ([eof-result? (lambda (x) 'passed)])
(send-sexp-to-mred '(begin (preferences:set 'framework:verify-exit #t)
(test:run-one (lambda () (exit:exit)))))
(wait-for-frame "Warning")
(wait-for-new-frame `(test:button-push
,(case (system-type)
[(windows) "Exit"]
[else "Quit"])))
'failed)))
(test 'exit/prompt/no-twice
(lambda (x) (and (eq? x 'passed)
(not (mred-running?))))
(let ([exit/push-button
(lambda (button)
(send-sexp-to-mred '(begin (preferences:set 'framework:verify-exit #t)
(test:run-one (lambda () (exit:exit)))))
(wait-for-frame "Warning")
(wait-for-new-frame `(test:button-push ,button)))])
(lambda ()
(exit/push-button "Cancel")
(exit/push-button "Cancel")
(with-handlers ([eof-result? (lambda (x) 'passed)])
(exit/push-button (case (system-type)
[(windows) "Exit"]
[else "Quit"]))
'failed))))
(test 'exit/esc-cancel
(lambda (x) (and (eq? x 'passed)
(not (mred-running?))))
(let ([exit/wait-for-warning
(lambda ()
(send-sexp-to-mred '(begin (preferences:set 'framework:verify-exit #t)
(test:run-one (lambda () (exit:exit)))))
(wait-for-frame "Warning"))])
(lambda ()
(exit/wait-for-warning)
(wait-for-new-frame `(test:close-top-level-window (get-top-level-focus-window)))
(exit/wait-for-warning)
(with-handlers ([eof-result? (lambda (x) 'passed)])
(wait-for-new-frame `(test:button-push
,(case (system-type)
[(windows) "Exit"]
[else "Quit"])))
'failed))))
(define tmp-file (build-path (find-system-path 'temp-dir) "framework-exit-test-suite"))
;; need to test "on" callbacks
(test 'exit-callback-called
(lambda (x)
(begin0 (and (file-exists? tmp-file) (not (mred-running?)))
(when (file-exists? tmp-file) (delete-file tmp-file))))
(lambda ()
(when (file-exists? tmp-file) (delete-file tmp-file))
(with-handlers ([eof-result? (lambda (x) 'passed)])
(send-sexp-to-mred
`(begin
(preferences:set 'framework:verify-exit #f)
(exit:insert-can?-callback (lambda () (call-with-output-file ,tmp-file void) #t))
(begin (exit:exit) (sleep/yield 1)))))))
(test 'exit-callback-removed
(lambda (x) (and (eq? x 'passed) (not (mred-running?))))
(lambda ()
(with-handlers ([eof-result? (lambda (x) 'passed)])
(send-sexp-to-mred
`(begin
(preferences:set 'framework:verify-exit #f)
((exit:insert-can?-callback (lambda () (error 'called-exit-callback))))
(begin (exit:exit) (sleep/yield 1)))))))
(test 'exit-callback-stops-exit
(lambda (x) (eq? x 'passed))
(lambda ()
(begin0
(send-sexp-to-mred
`(begin
(preferences:set 'framework:verify-exit #f)
(let ([rm-callback (exit:insert-can?-callback (lambda () #f))])
(exit:exit)
(rm-callback)
'passed)))
(with-handlers ([eof-result? (lambda (x) 'passed)])
(send-sexp-to-mred
`(exit:exit))))))