factor/extra/cursors/cursors-tests.factor

69 lines
1.9 KiB
Factor

! Copyright (C) 2010 Joe Groff.
! See http://factorcode.org/license.txt for BSD license.
USING: accessors cursors kernel make math sequences sorting tools.test ;
FROM: cursors => each map assoc-each assoc>map ;
IN: cursors.tests
{ { 1 2 3 4 } } [
[ T{ linear-cursor f 1 1 } T{ linear-cursor f 5 1 } [ value>> , ] -each ]
{ } make
] unit-test
{ T{ linear-cursor f 3 1 } } [
T{ linear-cursor f 1 1 } T{ linear-cursor f 5 1 } [ value>> 3 mod zero? ] -find
] unit-test
{ T{ linear-cursor f 5 1 } } [
T{ linear-cursor f 1 1 } T{ linear-cursor f 5 1 } [ value>> 6 = ] -find
] unit-test
{ { 1 3 } } [
[ T{ linear-cursor f 1 2 } T{ linear-cursor f 5 2 } [ value>> , ] -each ]
{ } make
] unit-test
{ B{ 1 2 3 4 5 } } [ [ { 1 2 3 4 5 } [ , ] each ] B{ } make ] unit-test
{ B{ } } [ [ { } [ , ] each ] B{ } make ] unit-test
{ { 2 4 6 8 10 } } [ { 1 2 3 4 5 } [ 2 * ] map ] unit-test
{ { "roses: lutefisk" "tulips: lox" } }
[
[
H{ { "roses" "lutefisk" } { "tulips" "lox" } }
[ ": " glue , ] assoc-each
] { } make natural-sort
] unit-test
{ { "roses: lutefisk" "tulips: lox" } }
[
H{ { "roses" "lutefisk" } { "tulips" "lox" } }
[ ": " glue ] { } assoc>map natural-sort
] unit-test
: compile-test-each ( xs -- )
[ , ] each ;
: compile-test-map ( xs -- ys )
[ 2 * ] map ;
: compile-test-assoc-each ( xs -- )
[ ": " glue , ] assoc-each ;
: compile-test-assoc>map ( xs -- ys )
[ ": " glue ] { } assoc>map ;
{ B{ 1 2 3 4 5 } } [ [ { 1 2 3 4 5 } compile-test-each ] B{ } make ] unit-test
{ { 2 4 6 8 10 } } [ { 1 2 3 4 5 } compile-test-map ] unit-test
{ { "roses: lutefisk" "tulips: lox" } }
[
[ H{ { "roses" "lutefisk" } { "tulips" "lox" } } compile-test-assoc-each ]
{ } make natural-sort
] unit-test
{ { "roses: lutefisk" "tulips: lox" } }
[
H{ { "roses" "lutefisk" } { "tulips" "lox" } } compile-test-assoc>map
natural-sort
] unit-test