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

69 lines
1.5 KiB
Factor

IN: ui.gadgets.worlds.tests
USING: ui.gadgets ui.gadgets.packs ui.gadgets.worlds tools.test
namespaces models kernel ;
! 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 gadget-focus "g1" get eq? ] unit-test
<gadget> "g1" set
<gadget> "g2" set
"g1" get "g2" get swap add-gadget drop
[ ] [
"g2" get <test-world> "w" set
] unit-test
[ ] [ "g1" get request-focus ] unit-test
[ t ] [ "w" get gadget-focus "g2" get eq? ] unit-test
[ t ] [ "g2" get gadget-focus "g1" get eq? ] unit-test
[ f ] [ "g1" get gadget-focus ] unit-test
<gadget> "g1" set
<gadget> "g2" set
<gadget> "g3" set
"g1" get "g3" get swap add-gadget drop
"g2" get "g3" get swap 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 gadget-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
<focusing> over swap 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 gadget-focus "f" get gadget-child eq? ] unit-test
[ t ] [ "f" get gadget-child focusing? ] unit-test