port keys.rkt to avoid separate mred process and racy frame
top-level window stuff that drdr doesn't like
This commit is contained in:
parent
6b2ff36cc9
commit
757a3c2463
|
@ -53,7 +53,7 @@ signal failures when there aren't any.
|
|||
- texts: text.rkt -- now runs directly via raco test.
|
||||
- pasteboards: |# pasteboard.rkt #|
|
||||
|
||||
- keybindings: |# keys.rkt #|
|
||||
- keybindings: keys.rkt -- now runs directly via raco test.
|
||||
|
||||
| This tests the misc (non-scheme) keybindings
|
||||
|
||||
|
|
|
@ -1,40 +1,24 @@
|
|||
#lang racket/base
|
||||
#lang racket/gui
|
||||
(require framework rackunit)
|
||||
|
||||
(require "test-suite-utils.rkt")
|
||||
|
||||
(module test racket/base)
|
||||
|
||||
(test
|
||||
'keymap:aug-keymap%/get-table
|
||||
(lambda (x)
|
||||
(equal? '((c:k "abc")) x))
|
||||
(lambda ()
|
||||
(queue-sexp-to-mred
|
||||
'(let ([k (make-object keymap:aug-keymap%)])
|
||||
(check-equal?
|
||||
(let ([k (make-object keymap:aug-keymap%)])
|
||||
(send k add-function "abc" void)
|
||||
(send k map-function "c:k" "abc")
|
||||
(hash-map (send k get-map-function-table) list)))))
|
||||
(hash-map (send k get-map-function-table) list))
|
||||
'((c:k "abc")))
|
||||
|
||||
(test
|
||||
'keymap:aug-keymap%/get-table/ht
|
||||
(lambda (x)
|
||||
(equal? x '((c:k "def"))))
|
||||
(lambda ()
|
||||
(queue-sexp-to-mred
|
||||
'(let ([k (make-object keymap:aug-keymap%)]
|
||||
(check-equal?
|
||||
(let ([k (make-object keymap:aug-keymap%)]
|
||||
[ht (make-hasheq)])
|
||||
(send k add-function "abc" void)
|
||||
(send k map-function "c:k" "abc")
|
||||
(hash-set! ht 'c:k "def")
|
||||
(hash-map (send k get-map-function-table/ht ht) list)))))
|
||||
(hash-map (send k get-map-function-table/ht ht) list))
|
||||
'((c:k "def")))
|
||||
|
||||
(test
|
||||
'keymap:aug-keymap%/get-table/chain1
|
||||
(lambda (x)
|
||||
(equal? x '((c:k "abc-k2"))))
|
||||
(lambda ()
|
||||
(queue-sexp-to-mred
|
||||
'(let ([k (make-object keymap:aug-keymap%)]
|
||||
(check-equal?
|
||||
(let ([k (make-object keymap:aug-keymap%)]
|
||||
[k1 (make-object keymap:aug-keymap%)]
|
||||
[k2 (make-object keymap:aug-keymap%)])
|
||||
(send k1 add-function "abc-k1" void)
|
||||
|
@ -43,60 +27,44 @@
|
|||
(send k2 map-function "c:k" "abc-k2")
|
||||
(send k chain-to-keymap k1 #t)
|
||||
(send k chain-to-keymap k2 #t)
|
||||
(hash-map (send k get-map-function-table) list)))))
|
||||
(hash-map (send k get-map-function-table) list))
|
||||
'((c:k "abc-k2")))
|
||||
|
||||
(test
|
||||
'keymap:aug-keymap%/get-table/chain/2
|
||||
(lambda (x)
|
||||
(equal? x '((c:k "abc-k"))))
|
||||
(lambda ()
|
||||
(queue-sexp-to-mred
|
||||
'(let ([k (make-object keymap:aug-keymap%)]
|
||||
(check-equal?
|
||||
(let ([k (make-object keymap:aug-keymap%)]
|
||||
[k1 (make-object keymap:aug-keymap%)])
|
||||
(send k1 add-function "abc-k1" void)
|
||||
(send k1 map-function "c:k" "abc-k1")
|
||||
(send k add-function "abc-k" void)
|
||||
(send k map-function "c:k" "abc-k")
|
||||
(send k chain-to-keymap k1 #t)
|
||||
(hash-map (send k get-map-function-table) list)))))
|
||||
(hash-map (send k get-map-function-table) list))
|
||||
'((c:k "abc-k")))
|
||||
|
||||
(test
|
||||
'keymap:aug-keymap%/get-table/normalize-case
|
||||
(lambda (x)
|
||||
(equal? x '((|esc;p| "abc-k2"))))
|
||||
(lambda ()
|
||||
(queue-sexp-to-mred
|
||||
'(let ([k (make-object keymap:aug-keymap%)]
|
||||
(check-equal?
|
||||
(let ([k (make-object keymap:aug-keymap%)]
|
||||
[k1 (make-object keymap:aug-keymap%)])
|
||||
(send k1 add-function "abc-k1" void)
|
||||
(send k1 map-function "esc;p" "abc-k1")
|
||||
(send k add-function "abc-k2" void)
|
||||
(send k map-function "ESC;p" "abc-k2")
|
||||
(send k chain-to-keymap k1 #t)
|
||||
(hash-map (send k get-map-function-table) list)))))
|
||||
(hash-map (send k get-map-function-table) list))
|
||||
'((|esc;p| "abc-k2")))
|
||||
|
||||
(test
|
||||
'keymap:aug-keymap%/all-but-last-bug
|
||||
(lambda (x)
|
||||
(equal? x '((s:a "shift-ah") (s:m "shift-em"))))
|
||||
(lambda ()
|
||||
(queue-sexp-to-mred
|
||||
'(let ([k (make-object keymap:aug-keymap%)])
|
||||
(check-equal?
|
||||
(let ([k (make-object keymap:aug-keymap%)])
|
||||
(send k add-function "shift-em" void)
|
||||
(send k add-function "shift-ah" void)
|
||||
(send k map-function "s:m" "shift-em")
|
||||
(send k map-function "s:a" "shift-ah")
|
||||
(sort (hash-map (send k get-map-function-table) list)
|
||||
string<?
|
||||
#:key (lambda (x) (format "~s" x)))))))
|
||||
#:key (lambda (x) (format "~s" x))))
|
||||
'((s:a "shift-ah") (s:m "shift-em")))
|
||||
|
||||
(test
|
||||
'keymap:aug-keymap%/longer-name
|
||||
(lambda (x)
|
||||
(equal? x '((|c:x;r| "swap if branches"))))
|
||||
(lambda ()
|
||||
(queue-sexp-to-mred
|
||||
'(let ()
|
||||
(check-equal?
|
||||
(let ()
|
||||
(define k0 (new keymap:aug-keymap%))
|
||||
(define k1 (new keymap:aug-keymap%))
|
||||
(define k2 (new keymap:aug-keymap%))
|
||||
|
@ -108,35 +76,26 @@
|
|||
(send k0 chain-to-keymap k2 #t)
|
||||
(sort (hash-map (send k0 get-map-function-table) list)
|
||||
string<?
|
||||
#:key (lambda (x) (format "~s" x)))))))
|
||||
|
||||
(define (test-canonicalize name str1 str2)
|
||||
(test
|
||||
(string->symbol (format "keymap:canonicalize-keybinding-string/~a" name))
|
||||
(lambda (x)
|
||||
(string=? x str2))
|
||||
(lambda ()
|
||||
(queue-sexp-to-mred
|
||||
`(keymap:canonicalize-keybinding-string ,str1)))))
|
||||
|
||||
(test-canonicalize 1 "c:a" "c:a")
|
||||
(test-canonicalize 2 "d:a" "d:a")
|
||||
(test-canonicalize 3 "m:a" "m:a")
|
||||
(test-canonicalize 4 "a:a" "a:a")
|
||||
(test-canonicalize 5 "s:a" "s:a")
|
||||
(test-canonicalize 6 "c:a" "c:a")
|
||||
(test-canonicalize 7 "s:m:d:c:a:a" "a:c:d:m:s:a")
|
||||
(test-canonicalize 8 "~s:~m:~d:~c:~a:a" "~a:~c:~d:~m:~s:a")
|
||||
(test-canonicalize 9 ":a" "~a:~c:~d:~m:~s:a")
|
||||
(test-canonicalize 10 ":d:a" "~a:~c:d:~m:~s:a")
|
||||
(test-canonicalize 11 "esc;s:a" "esc;s:a")
|
||||
(test-canonicalize 12 "s:a;esc" "s:a;esc")
|
||||
(test-canonicalize 13 "ESC;p" "esc;p")
|
||||
(test-canonicalize 14 "?:a:v" "?:a:v")
|
||||
(test-canonicalize 15 "a:?:v" "?:a:v")
|
||||
(test-canonicalize 16 "l:v" "l:v")
|
||||
(test-canonicalize 17 "c:l:v" "c:l:v")
|
||||
#:key (lambda (x) (format "~s" x))))
|
||||
'((|c:x;r| "swap if branches")))
|
||||
|
||||
(check-equal? (keymap:canonicalize-keybinding-string "c:a") "c:a")
|
||||
(check-equal? (keymap:canonicalize-keybinding-string "d:a") "d:a")
|
||||
(check-equal? (keymap:canonicalize-keybinding-string "m:a") "m:a")
|
||||
(check-equal? (keymap:canonicalize-keybinding-string "a:a") "a:a")
|
||||
(check-equal? (keymap:canonicalize-keybinding-string "s:a") "s:a")
|
||||
(check-equal? (keymap:canonicalize-keybinding-string "c:a") "c:a")
|
||||
(check-equal? (keymap:canonicalize-keybinding-string "s:m:d:c:a:a") "a:c:d:m:s:a")
|
||||
(check-equal? (keymap:canonicalize-keybinding-string "~s:~m:~d:~c:~a:a") "~a:~c:~d:~m:~s:a")
|
||||
(check-equal? (keymap:canonicalize-keybinding-string ":a") "~a:~c:~d:~m:~s:a")
|
||||
(check-equal? (keymap:canonicalize-keybinding-string ":d:a") "~a:~c:d:~m:~s:a")
|
||||
(check-equal? (keymap:canonicalize-keybinding-string "esc;s:a") "esc;s:a")
|
||||
(check-equal? (keymap:canonicalize-keybinding-string "s:a;esc") "s:a;esc")
|
||||
(check-equal? (keymap:canonicalize-keybinding-string "ESC;p") "esc;p")
|
||||
(check-equal? (keymap:canonicalize-keybinding-string "?:a:v") "?:a:v")
|
||||
(check-equal? (keymap:canonicalize-keybinding-string "a:?:v") "?:a:v")
|
||||
(check-equal? (keymap:canonicalize-keybinding-string "l:v") "l:v")
|
||||
(check-equal? (keymap:canonicalize-keybinding-string "c:l:v") "c:l:v")
|
||||
|
||||
;; a key-spec is (make-key-spec buff-spec buff-spec (listof ?) (listof ?) (listof ?))
|
||||
;; a key-spec represents a test case for a key; 'before' contains the
|
||||
|
@ -411,74 +370,88 @@
|
|||
(build-buff-spec "||" 1 1)
|
||||
'(((#\|))))))
|
||||
|
||||
(queue-sexp-to-mred `(send (make-object frame:basic% "dummy to trick frame group") show #t))
|
||||
(wait-for-frame "dummy to trick frame group")
|
||||
(define (queue-callback/wait t)
|
||||
(define c (make-channel))
|
||||
(queue-callback (λ () (channel-put c (t))))
|
||||
(channel-get c))
|
||||
|
||||
;; test-key : key-spec ->
|
||||
;; evaluates a test case represented as a key-spec
|
||||
(define (test-key key-spec i)
|
||||
(let* ([key-sequences
|
||||
(define (test-specs frame-name frame-class specs)
|
||||
(define f #f)
|
||||
(queue-callback/wait
|
||||
(λ ()
|
||||
(set! f (make-object frame-class frame-name))
|
||||
(send f show #t)))
|
||||
|
||||
(for ([key-spec (in-list specs)]
|
||||
[i (in-naturals)])
|
||||
(define key-sequences
|
||||
((case (system-type)
|
||||
[(macos macosx) key-spec-macos]
|
||||
[(unix) key-spec-unix]
|
||||
[(windows) key-spec-windows])
|
||||
key-spec)]
|
||||
[before (key-spec-before key-spec)]
|
||||
[after (key-spec-after key-spec)]
|
||||
[process-key-sequence
|
||||
(lambda (key-sequence)
|
||||
(let ([text-expect (buff-spec-string after)]
|
||||
[start-expect (buff-spec-start after)]
|
||||
[end-expect (buff-spec-end after)])
|
||||
(test (list key-sequence i)
|
||||
(lambda (x) (equal? x (vector text-expect start-expect end-expect)))
|
||||
`(let* ([qc (λ (t) (let ([c (make-channel)])
|
||||
(queue-callback (λ () (channel-put c (t))))
|
||||
(channel-get c)))]
|
||||
[text (qc (λ () (send (get-top-level-focus-window) get-editor)))])
|
||||
(qc (λ ()
|
||||
(send text set-overwrite-mode ,(buff-spec-overwrite? before))
|
||||
key-spec))
|
||||
(define before (key-spec-before key-spec))
|
||||
(define after (key-spec-after key-spec))
|
||||
(for ([key-sequence (in-list key-sequences)])
|
||||
(define text-expect (buff-spec-string after))
|
||||
(define start-expect (buff-spec-start after))
|
||||
(define end-expect (buff-spec-end after))
|
||||
(queue-callback
|
||||
(λ ()
|
||||
(define frame (test:get-active-top-level-window))
|
||||
(define text (send frame get-editor))
|
||||
(send text set-overwrite-mode (buff-spec-overwrite? before))
|
||||
(send text erase)
|
||||
(send text insert ,(buff-spec-string before))
|
||||
(send text set-position ,(buff-spec-start before) ,(buff-spec-end before))))
|
||||
,@(map (lambda (key) `(test:keystroke ',(car key) ',(cdr key)))
|
||||
key-sequence)
|
||||
(qc (λ ()
|
||||
(send text insert (buff-spec-string before))
|
||||
(send text set-position (buff-spec-start before) (buff-spec-end before))))
|
||||
(for ([key (in-list key-sequence)])
|
||||
(test:keystroke (car key) (cdr key)))
|
||||
(check-equal?
|
||||
(queue-callback/wait
|
||||
(λ ()
|
||||
(define frame (test:get-active-top-level-window))
|
||||
(define text (send frame get-editor))
|
||||
(vector (send text get-text)
|
||||
(send text get-start-position)
|
||||
(send text get-end-position))))))))])
|
||||
(for-each process-key-sequence key-sequences)))
|
||||
(send text get-end-position))))
|
||||
(vector text-expect start-expect end-expect)
|
||||
(~s (list key-sequence i)))))
|
||||
(queue-callback/wait (λ () (send f close))))
|
||||
|
||||
(let ([pref-ht (make-hash)])
|
||||
(parameterize ([test:use-focus-table #t]
|
||||
[preferences:low-level-get-preference
|
||||
(λ (sym [fail (λ () #f)])
|
||||
(hash-ref pref-ht sym fail))]
|
||||
[preferences:low-level-put-preferences
|
||||
(λ (syms vals)
|
||||
(for ([sym (in-list syms)]
|
||||
[val (in-list vals)])
|
||||
(hash-set! pref-ht sym val)))])
|
||||
;; needs to be inside the test:use-focus-table setting
|
||||
(parameterize ([current-eventspace (make-eventspace)])
|
||||
|
||||
(define (test-specs frame-name frame-class specs)
|
||||
(queue-sexp-to-mred `(send (make-object ,frame-class ,frame-name) show #t))
|
||||
(wait-for-frame frame-name)
|
||||
(for ([spec (in-list specs)]
|
||||
[i (in-naturals)])
|
||||
(test-key spec i))
|
||||
(queue-sexp-to-mred `(send (get-top-level-focus-window) close)))
|
||||
(define dummy #f)
|
||||
(queue-callback
|
||||
(λ ()
|
||||
(set! dummy (make-object frame:basic% "dummy to trick frame group"))
|
||||
(send dummy show #t)))
|
||||
|
||||
(define old-paren-adjusting-prefs
|
||||
(queue-sexp-to-mred `(list (preferences:get 'framework:fixup-open-parens)
|
||||
(preferences:get 'framework:automatic-parens))))
|
||||
|
||||
|
||||
(queue-sexp-to-mred `(preferences:set 'framework:fixup-open-parens #t))
|
||||
(queue-sexp-to-mred `(preferences:set 'framework:automatic-parens #f))
|
||||
(test-specs "global keybindings test" 'frame:text% global-specs)
|
||||
(test-specs "scheme mode keybindings test"
|
||||
'(class frame:editor%
|
||||
(preferences:set 'framework:fixup-open-parens #t)
|
||||
(preferences:set 'framework:automatic-parens #f)
|
||||
(test-specs "global keybindings test" frame:text% global-specs)
|
||||
(test-specs "racket mode keybindings test"
|
||||
(class frame:editor%
|
||||
(define/override (get-editor%) racket:text%)
|
||||
(super-new))
|
||||
scheme-specs)
|
||||
(queue-sexp-to-mred `(preferences:set 'framework:automatic-parens #t))
|
||||
(queue-sexp-to-mred `(preferences:set 'framework:fixup-open-parens #f))
|
||||
(test-specs "scheme mode automatic-parens on keybindings test"
|
||||
'(class frame:editor%
|
||||
|
||||
(preferences:set 'framework:automatic-parens #t)
|
||||
(preferences:set 'framework:fixup-open-parens #f)
|
||||
(test-specs "racket mode automatic-parens on keybindings test"
|
||||
(class frame:editor%
|
||||
(define/override (get-editor%) racket:text%)
|
||||
(super-new))
|
||||
automatic-scheme-specs)
|
||||
|
||||
(queue-sexp-to-mred
|
||||
`(begin (preferences:set 'framework:fixup-open-parens ,(list-ref old-paren-adjusting-prefs 0))
|
||||
(preferences:set 'framework:automatic-parens ,(list-ref old-paren-adjusting-prefs 1))))
|
||||
(queue-callback (λ () (send dummy show #f))))))
|
||||
|
|
Loading…
Reference in New Issue
Block a user