factor/basis/ui/gadgets/worlds/worlds-tests.factor

69 lines
1.4 KiB
Factor

USING: ui.gadgets ui.gadgets.packs ui.gadgets.worlds tools.test
namespaces models kernel accessors ;
IN: ui.gadgets.worlds.tests
! Test focus behavior
<gadget> "g1" set
: <test-world> ( gadget -- world )
"Hi" f <world> ;
[ ] [
"g1" get <test-world> "w" set
] unit-test
[ ] [ "g1" get request-focus ] unit-test
[ t ] [ "w" get focus>> "g1" get eq? ] unit-test
<gadget> "g1" set
<gadget> "g2" set
"g2" get "g1" get add-gadget drop
[ ] [
"g2" get <test-world> "w" set
] unit-test
[ ] [ "g1" get request-focus ] unit-test
[ t ] [ "w" get focus>> "g2" get eq? ] unit-test
[ t ] [ "g2" get focus>> "g1" get eq? ] unit-test
[ f ] [ "g1" get focus>> ] unit-test
<gadget> "g1" set
<gadget> "g2" set
<gadget> "g3" set
"g3" get "g1" get add-gadget drop
"g3" get "g2" get add-gadget drop
[ ] [
"g3" get <test-world> "w" set
] unit-test
[ ] [ "g1" get request-focus ] unit-test
[ ] [ "g2" get unparent ] unit-test
[ t ] [ "g3" get focus>> "g1" get eq? ] unit-test
[ t ] [ <gadget> dup <test-world> focusable-child eq? ] unit-test
TUPLE: focusing < gadget ;
: <focusing>
focusing new-gadget ;
TUPLE: focus-test < gadget ;
: <focus-test>
focus-test new-gadget
dup <focusing> add-gadget drop ;
M: focus-test focusable-child* gadget-child ;
<focus-test> "f" set
[ ] [ "f" get <test-world> request-focus ] unit-test
[ t ] [ "f" get focus>> "f" get gadget-child eq? ] unit-test
[ t ] [ "f" get gadget-child focusing? ] unit-test