175 lines
4.5 KiB
Factor
Executable File
175 lines
4.5 KiB
Factor
Executable File
IN: models.tests
|
|
USING: arrays generic kernel math models namespaces sequences assocs
|
|
tools.test ;
|
|
|
|
TUPLE: model-tester hit? ;
|
|
|
|
: <model-tester> model-tester new ;
|
|
|
|
M: model-tester model-changed nip t swap set-model-tester-hit? ;
|
|
|
|
[ T{ model-tester f t } ]
|
|
[
|
|
T{ model-tester f f } 3 <model> 2dup add-connection
|
|
5 swap set-model
|
|
] unit-test
|
|
|
|
3 <model> "model-a" set
|
|
4 <model> "model-b" set
|
|
"model-a" get "model-b" get 2array <compose> "model-c" set
|
|
|
|
"model-c" get activate-model
|
|
[ { 3 4 } ] [ "model-c" get model-value ] unit-test
|
|
"model-c" get deactivate-model
|
|
|
|
T{ model-tester f f } "tester" set
|
|
|
|
[ T{ model-tester f t } { 6 4 } ]
|
|
[
|
|
"tester" get "model-c" get add-connection
|
|
6 "model-a" get set-model
|
|
"tester" get
|
|
"model-c" get model-value
|
|
] unit-test
|
|
|
|
f <history> "history" set
|
|
|
|
"history" get add-history
|
|
|
|
[ t ] [ "history" get history-back empty? ] unit-test
|
|
[ t ] [ "history" get history-forward empty? ] unit-test
|
|
|
|
"history" get add-history
|
|
3 "history" get set-model
|
|
|
|
[ t ] [ "history" get history-back empty? ] unit-test
|
|
[ t ] [ "history" get history-forward empty? ] unit-test
|
|
|
|
"history" get add-history
|
|
4 "history" get set-model
|
|
|
|
[ f ] [ "history" get history-back empty? ] unit-test
|
|
[ t ] [ "history" get history-forward empty? ] unit-test
|
|
|
|
"history" get go-back
|
|
|
|
[ 3 ] [ "history" get model-value ] unit-test
|
|
|
|
[ t ] [ "history" get history-back empty? ] unit-test
|
|
[ f ] [ "history" get history-forward empty? ] unit-test
|
|
|
|
"history" get go-forward
|
|
|
|
[ 4 ] [ "history" get model-value ] unit-test
|
|
|
|
[ f ] [ "history" get history-back empty? ] unit-test
|
|
[ t ] [ "history" get history-forward empty? ] unit-test
|
|
|
|
! Test multiple filters
|
|
3 <model> "x" set
|
|
"x" get [ 2 * ] <filter> dup "z" set
|
|
[ 1+ ] <filter> "y" set
|
|
[ ] [ "y" get activate-model ] unit-test
|
|
[ t ] [ "z" get "x" get model-connections memq? ] unit-test
|
|
[ 7 ] [ "y" get model-value ] unit-test
|
|
[ ] [ 4 "x" get set-model ] unit-test
|
|
[ 9 ] [ "y" get model-value ] unit-test
|
|
[ ] [ "y" get deactivate-model ] unit-test
|
|
[ f ] [ "z" get "x" get model-connections memq? ] unit-test
|
|
|
|
3 <model> "x" set
|
|
"x" get [ sq ] <filter> "y" set
|
|
|
|
4 "x" get set-model
|
|
|
|
"y" get activate-model
|
|
[ 16 ] [ "y" get model-value ] unit-test
|
|
"y" get deactivate-model
|
|
|
|
! Test compose
|
|
[ ] [
|
|
1 <model> "a" set
|
|
2 <model> "b" set
|
|
"a" get "b" get 2array <compose> "c" set
|
|
] unit-test
|
|
|
|
[ ] [ "c" get activate-model ] unit-test
|
|
|
|
[ { 1 2 } ] [ "c" get model-value ] unit-test
|
|
|
|
[ ] [ 3 "b" get set-model ] unit-test
|
|
|
|
[ { 1 3 } ] [ "c" get model-value ] unit-test
|
|
|
|
[ ] [ { 4 5 } "c" get set-model ] unit-test
|
|
|
|
[ { 4 5 } ] [ "c" get model-value ] unit-test
|
|
|
|
[ ] [ "c" get deactivate-model ] unit-test
|
|
|
|
! Test mapping
|
|
[ ] [
|
|
[
|
|
1 <model> "one" set
|
|
2 <model> "two" set
|
|
] H{ } make-assoc
|
|
<mapping> "m" set
|
|
] unit-test
|
|
|
|
[ ] [ "m" get activate-model ] unit-test
|
|
|
|
[ H{ { "one" 1 } { "two" 2 } } ] [
|
|
"m" get model-value
|
|
] unit-test
|
|
|
|
[ ] [
|
|
H{ { "one" 3 } { "two" 4 } }
|
|
"m" get set-model
|
|
] unit-test
|
|
|
|
[ H{ { "one" 3 } { "two" 4 } } ] [
|
|
"m" get model-value
|
|
] unit-test
|
|
|
|
[ H{ { "one" 5 } { "two" 4 } } ] [
|
|
5 "one" "m" get mapping-assoc at set-model
|
|
"m" get model-value
|
|
] unit-test
|
|
|
|
[ ] [ "m" get deactivate-model ] unit-test
|
|
|
|
! Test <range>
|
|
: setup-range 0 0 0 255 <range> ;
|
|
|
|
! clamp-value should not go past range ends
|
|
[ 0 ] [ -10 setup-range clamp-value ] unit-test
|
|
[ 255 ] [ 2000 setup-range clamp-value ] unit-test
|
|
[ 14 ] [ 14 setup-range clamp-value ] unit-test
|
|
|
|
! range min/max/page values should be correct
|
|
[ 0 ] [ setup-range range-page-value ] unit-test
|
|
[ 0 ] [ setup-range range-min-value ] unit-test
|
|
[ 255 ] [ setup-range range-max-value ] unit-test
|
|
|
|
! should be able to set the value within the range and get back
|
|
[ 15 ] [ setup-range 15 over set-range-value range-value ] unit-test
|
|
[ 0 ] [ setup-range -15 over set-range-value range-value ] unit-test
|
|
[ 255 ] [ setup-range 4000 over set-range-value range-value ] unit-test
|
|
|
|
! should be able to change the range min/max/page value
|
|
[ 1 ] [ setup-range 1 over set-range-page-value range-page-value ] unit-test
|
|
[ 50 ] [ setup-range 50 over set-range-min-value range-min-value ] unit-test
|
|
[ 4000 ] [ setup-range 4000 over set-range-max-value range-max-value ] unit-test
|
|
|
|
! should be able to move by positive and negative values
|
|
[ 30 ] [ setup-range 30 over move-by range-value ] unit-test
|
|
[ 0 ] [ setup-range 30 over move-by -30 over move-by range-value ] unit-test
|
|
|
|
! should be able to move by a page of 10
|
|
[ 10 ] [
|
|
setup-range 10 over set-range-page-value
|
|
1 over move-by-page range-value
|
|
] unit-test
|
|
|
|
|